-
Notifications
You must be signed in to change notification settings - Fork 0
/
schema.graphql
76 lines (70 loc) · 1.74 KB
/
schema.graphql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
"""
Um tipo enum para declarar exatamente quais status
são possíveis para um cluster
"""
enum Status {
UNHEALTHY
HEALTHY
}
"""
Um tipo da categoria objeto é uma coleção de valores (scalar)
e/ou outros objetos
"""
type Cluster {
"""
Esse campo é obrigatório porque seu tipo termina com uma exclamação
"""
name: String!
kubernetesVersion: String!
owner: Customer!
"""
Ao invés de usar uma string aqui e deixar o campo status aberto, nós fechamos
as possibilidades usando um Enum
"""
status: Status!
}
type Customer {
id: ID!
name: String!
"""
Esse campo não tem exclamação, ele é opcional e pode ser nulo
"""
description: String
isActive: Boolean!
"""
Quando temos uma lista de objetos você geralmente usa duas exclamações: uma
para indicar que a lista não vai ser nula e a interna para indicar que nenhum
elemento da lista pode ser nulo
"""
clusters: [Cluster!]!
}
"""
As operações de consulta e escrita podem receber parâmetros, uma forma de
agrupar esses parâmetros e documentá-los melhor é através do uso de um tipo
input
"""
input DeactivateCustomerInput {
customerId: ID!
}
"""
É uma boa prática você "envelopar" o retorno de suas mutações em tipos
específicos, isso facilita a evolução gradual do schema
"""
type DeactivateCustomerPayload {
customer: Customer
}
"""
O tipo com nome "Mutation" é especial, ele define quais operações de escrita
são suportadas pelo seu servidor de GraphQL
"""
type Mutation {
deactivateCustomer(input: DeactivateCustomerInput!): DeactivateCustomerPayload!
}
"""
O tipo com nome "Query" funciona de forma similar à "Mutation", mas descreve
as operações de consulta
"""
type Query {
myClusters: [Cluster!]!
allClusters: [Cluster!]!
}