Consultar dados do WordPress
Consultar dados do WordPressUsuários

Usuários

Estes são exemplos de queries para buscar dados de usuários e autenticá-los.

Buscando usuários

Um único usuário com seus posts:

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

Uma lista de 5 usuários, ordenados por nome:

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

Uma lista de usuários predefinidos, com seus avatares:

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

Filtrando usuários por nome:

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

Contando resultados de usuários:

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

Paginando usuários:

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

Buscando valores meta:

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

Buscando roles e capabilities

Obtendo as roles e capabilities dos usuários:

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

Autenticando e desconectando o usuário

A autenticação do usuário é necessária para executar mutations (criar um post, adicionar um comentário, etc.).

Esta query autentica o usuário:

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

Para recuperar o usuário autenticado:

query {
  me {
    id
    name
  }
}

Desconectar o usuário:

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