Biblioteka queries
Biblioteka queriesWzbogacanie danych z zewnętrznego API

Wzbogacanie danych z zewnętrznego API

Jeśli musimy pobrać dane z zewnętrznego API, ale potrzebujemy je w jakiś sposób zmodyfikować (na przykład podać wartość domyślną, gdy jakieś pole jest puste), możemy użyć Gato GraphQL do implementacji bramki API, która transformuje wpisy zgodnie z wymaganiami.

Na przykład, wywołując endpoint REST API /users z jakiegoś serwisu WordPress, możemy dodać wartość domyślną, gdy pole url jest puste, oraz dodatkową właściwość link z kodem HTML:

query FilterDataFromWordPressAPI(
  # eg: https://somesite.com/wp-json/wp/v2/users/?_fields=id,name,url
  $endpointURL: URL!
) {
  usersWithLinkAndDefaultURL: _sendJSONObjectCollectionHTTPRequest(
    input: {
      url: $endpointURL
    }
  )
    # Set a default URL for users without any
    @underEachArrayItem
      @underJSONObjectProperty(
        by: {
          key: "url"
        }
      )
        @default(
          value: "https://mysite.com"
          condition: IS_EMPTY
        )
 
    # Add a new "link" entry on the JSON object
    @underEachArrayItem(
      affectDirectivesUnderPos: [1, 2, 3, 4],
      passValueOnwardsAs: "userListItem"
    )
      @applyField(
        name: "_objectProperty",
        arguments: {
          object: $userListItem,
          by: {
            key: "name"
          }
        },
        passOnwardsAs: "userName"
      )
      @applyField(
        name: "_objectProperty",
        arguments: {
          object: $userListItem,
          by: {
            key: "url"
          }
        },
        passOnwardsAs: "userURL"
      )
      @applyField(
        name: "_sprintf",
        arguments: {
          string: "<a href=\"%s\">%s</a>",
          values: [$userURL, $userName]
        },
        passOnwardsAs: "userLink"
      )
      @applyField(
        name: "_objectAddEntry",
        arguments: {
          object: $userListItem,
          key: "link",
          value: $userLink
        },
        setResultInResponse: true
      )
}