Interrogare i dati di WordPress
Interrogare i dati di WordPressUtenti

Utenti

Questi sono esempi di queries per recuperare i dati degli utenti e autenticarli.

Recuperare gli utenti

Un singolo utente con i suoi articoli:

query {
  user(by: { id: 1 }) {
    name
    email
    url
    posts {
      id
      title
      excerpt
    }
  }
}

Un elenco di 5 utenti, ordinati per nome:

query {
  users(
    pagination: { limit: 5 }
    sort: { by: NAME, order: ASC }
  ) {
    id
    displayName
    websiteURL
  }
}

Un elenco di utenti predefiniti, con i loro avatar:

{
  users(filter: { ids: [2, 3, 5] }) {
    id
    displayName
    url
    avatar(size: 150) {
      size
      src
    }
  }
}

Filtrare gli utenti per nome:

query {
  users(filter: { searchBy: { name: "le" } }) {
    id
    name
    email
  }
}

Contare i risultati degli utenti:

query {
  userCount(
    filter: { searchBy: { name: "le" } }
  )
}

Paginare gli utenti:

query {
  users(
    pagination: {
      limit: 5,
      offset: 5
    }
  ) {
    id
    name
  }
}

Recuperare valori meta:

query {
  users {
    id
    name
    metaValue(
      key: "last_name",
    )
  }
}

Recuperare ruoli e capacità

Per saperne di più, consulta la guida Interrogare i campi di dati "sensibili".

Ottenere i roles e le capabilities degli utenti:

query {
  users {
    id
    displayName
    roles {
      name
      capabilities
    }
  }
}

Autenticazione e disconnessione dell'utente

L'autenticazione dell'utente è necessaria per eseguire le mutazioni (creare un articolo, aggiungere un commento, ecc.).

Questa query autentica l'utente:

mutation {
  loginUser(
    by: {
      credentials: {
        usernameOrEmail: "test",
        password: "pass"
      }
    }
  ) {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
      ...on GenericErrorPayload {
        code
      }
    }
    userID
  }
}

Per recuperare l'utente autenticato:

query {
  me {
    id
    name
  }
}

Disconnettere l'utente:

mutation {
  logoutUser {
    status
    errors {
      __typename
      ...on ErrorPayload {
        message
      }
      ...on GenericErrorPayload {
        code
      }
    }
    userID
  }
}