Terminologia do GraphQL
A API do GraphQL do GitHub representa uma mudança estrutural e conceitual API REST do GitHub. Você provavelmente encontrará uma nova terminologia na documentação de referência da API do GraphQL.
Esquema
Um esquema define um sistema de tipos da API do GraphQL. Ele descreve o conjunto completo de dados possíveis (objetos, campos, relações, tudo) que um cliente pode acessar. As chamadas do cliente são validadas e executadas com base no esquema. Um cliente pode encontrar informações sobre o esquema através da introspecção. Um esquema reside no servidor da API do GraphQL. Para obter mais informações, consulte "Descobrindo a API do GraphQL".
Campo
Um campo é uma unidade de dados que você pode recuperar de um objeto. Conforme a documentação oficial do GraphQL afirma: "A linguagem de consulta do GraphQL consiste, basicamente, em selecionar campos em objetos."
A especificação oficial do também afirmam sobre os campos:
Todas as operações do GraphQL devem especificar suas seleções para os campos que retornam valores escalares a fim de garantir uma resposta de forma não ambígua.
Isso significa que se você tentar retornar um campo que não é escalar, a validação do esquema causará um erro. Você deve adicionar subcampos aninhados até que todos os campos retornam escalares.
Argumento
Um argumento é um conjunto de pares de chave-valor anexados a um campo específico. Alguns campos exigem um argumento. As Mutações exigem um objeto de entrada como argumento.
Implementação
Um esquema do GraphQL pode usar o termo implementos para definir como um objeto herda de uma interface.
Aqui está um exemplo criado de um esquema que define a interface X
e o objeto Y
:
interface X {
some_field: String!
other_field: String!
}
type Y implements X {
some_field: String!
other_field: String!
new_field: String!
}
Este significa que o objeto Y
exige os mesmos mesmos tipos de campo/argumento/retorno que a interface X
, ao mesmo tempo que adiciona novos campos específicos para o objeto Y
. (O sinal !
significa que o campo é obrigatório).
Na documentação de referência, você descobrirá que:
-
Cada objeto lista a(s) interface(s) das quais herda em Implementos.
-
Cada interface lista os objetos dos quais herdam em Implementações.
Conexão
As conexões permitem que você consulte objetos relacionados às consultas como parte da mesma chamada. Com as conexões, você pode usar uma única chamada do GraphQL quando você teria que usar várias chamadas para uma API REST. Para obter mais informações, consulte "Migrando da REST para o GraphQL".
É útil imaginar um gráfico: pontos conectados por linhas. Os pontos são nós e as linhas são bordas. Uma conexão define uma relação entre os nós.
Borda
As bordas representam conexões entre os nós. Quando você consulta uma conexão, você atravessa suas bordas para chegar a seus nós. Cada campo da borda
tem um campo nó
e um campo de cursor
. Os cursores são usados para paginação.
Nó
Nó é um termo genérico para um objeto. Você pode procurar um nó diretamente pode acessar nós relacionados através de uma conexão. Se você especificar um nó
que não retorna um escalar, você deverá incluir subcampos até que todos os campos retornem escalares. Para obter informações sobre acesso a IDs de nó através da API REST e usá-los em consultas do GraphQL, consulte "Usando IDs globais de nó".
Descobrindo a API do GraphQL
O GraphQL é introspectivo. Isso significa que você pode consultar um esquema do GraphQL para obter informações sobre ele.
-
Consulte
__schema
para listar todos os tipos definidos no esquema e obter informações sobre cada um:query { __schema { types { name kind description fields { name } } } }
-
Consulte
__type
para obter informações sobre qualquer tipo:query { __type(name: "Repository") { name kind description fields { name } } }
-
Você também pode executar uma consulta de introspeção do esquema através de uma solicitação do
GET
:$ curl -H "Authorization: bearer token" http(s)://[hostname]/api/graphql
Observação: Se você receber a resposta
"message": "Bad credentials"
ou401 Unauthorized
, verifique se você está usando um token válido. Para mais informação, consulte "Criando um token de acesso pessoal."Os resultados estão no JSON,. Portanto, recomendamos que sejam impressos para facilitar a leitura e pesquisa. Você pode usar uma ferramenta de linha de comando como jq ou canalizar os resultados em
python -m json.tool
para essa finalidade.Como alternativa, você pode passar o tipo de mídia
idl
para retornar os resultados no formato IDL, que é uma versão condensada do esquema:$ curl -H "Authorization: bearer token" -H "Accept: application/vnd.github.v4.idl" \ http(s)://[hostname]/api/graphql
Observação: A consulta de introspecção é provavelmente a única solicitação do
GET
que você irá executar no GraphQL. Se passar um texto, o método de solicitação do GraphQL éPOST
, seja uma consulta ou mutação.Para obter mais informações sobre como realizar consultas, consulte "Formando de chamadas com o GraphQL".