Queries-Bibliothek
Queries-BibliothekDaten von einer externen API anreichern

Daten von einer externen API anreichern

Wenn wir Daten von einer externen API abrufen müssen, diese aber irgendwie anpassen möchten (z. B. einen Standardwert setzen, wenn ein Feld leer ist), können wir Gato GraphQL verwenden, um ein API-Gateway zu implementieren, das die Einträge nach Bedarf transformiert.

Wenn wir zum Beispiel den REST API-Endpunkt /users einer WordPress-Website aufrufen, können wir einen Standardwert setzen, wenn das Feld url leer ist, und eine zusätzliche Eigenschaft link mit dem HTML-Code hinzufügen:

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
      )
}