Coderen met een API
Coderen met een APIMeerdere resources injecteren in WP-CLI

Meerdere resources injecteren in WP-CLI

In de gids WP-CLI aanvullen haalden we slechts één gebruikers-ID op (en injecteerden dat in WP-CLI). Laten we nu meerdere gebruikers-ID's ophalen tijdens het uitvoeren van één GraphQL-query.

In deze GraphQL-query:

  • We verwijderen het pagination-argument uit de query, om de lijst van alle gebruikers met een Spaanse locale op te halen
  • We gebruiken Multiple Query Execution om een lijst van gebruikers-ID's te exporteren onder de dynamische variabele $userIDs
  • We drukken de elementen van deze array af met _arrayJoin, waarbij de items worden samengevoegd met een spatie ertussen, onder de alias spanishLocaleUserIDs
  • We voeren de operatie FormatAndPrintData uit
# This query is stored in file "find-multiple-users-with-spanish-locale.gql"
query RetrieveData {
  users(
    filter: {
      metaQuery: {
        key: "locale",
        compareBy: {
          stringValue: {
            value: "es_[A-Z]+"
            operator: REGEXP
          }
        }
      }
    }
  ) {
    id @export(as: "userIDs", type: LIST)
    name
    locale: metaValue(key: "locale")
  }
}
 
query FormatAndPrintData @depends(on: "RetrieveData") {
  spanishLocaleUserIDs: _arrayJoin(
    array: $userIDs,
    separator: " "
  )
}

Het antwoord op deze query zal zijn:

{
  "data": {
    "users": [
      {
        "id": 3,
        "name": "Subscriber Bennett",
        "locale": "es_AR"
      },
      {
        "id": 2,
        "name": "Blogger Davenport",
        "locale": "es_ES"
      }
    ],
    "spanishLocaleUserIDs": "3 2"
  }
}

Bij het uitvoeren van de query moet het woordenboek in de body van het verzoek de naam van de uit te voeren operatie aangeven ("FormatAndPrintData"):

GRAPHQL_QUERY=$(cat find-multiple-users-with-spanish-locale.gql)
GRAPHQL_BODY="{\"operationName\": \"FormatAndPrintData\", \"query\": \"$(echo $GRAPHQL_QUERY | tr '\n' ' ' | sed 's/"/\\"/g')\"}"
GRAPHQL_RESPONSE=$(curl \
  -X POST \
  -H "Content-Type: application/json" \
  -d $GRAPHQL_BODY \
  https://mysite.com/graphql/)

We moeten ook de reguliere expressie aanpassen (vanwege de nieuwe alias, de spatie tussen de ID's en de aanhalingstekens rondom deze string):

SPANISH_LOCALE_USER_IDS=$(echo $GRAPHQL_RESPONSE \
  | grep -E -o '"spanishLocaleUserIDs\":"((\d|\s)+)"' \
  | cut -d':' -f2- | cut -d'"' -f2- | rev | cut -d'"' -f2- | rev)

Door de inhoud van de variabele SPANISH_LOCALE_USER_IDS af te drukken, krijgen we alle ID's, gescheiden door een spatie:

echo $SPANISH_LOCALE_USER_IDS
# Response:
# 3 2

We kunnen nu alle ID's samen injecteren in het WP-CLI-commando (als het dat ondersteunt), of ze doorlopen en het commando voor elk van hen uitvoeren:

for USER_ID in $(echo $SPANISH_LOCALE_USER_IDS); do wp user update "$(echo $USER_ID)" --locale=fr_FR; done