forked from apollographql/supergraph-demo-fed2
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsupergraph.graphql
More file actions
123 lines (104 loc) · 3.42 KB
/
supergraph.graphql
File metadata and controls
123 lines (104 loc) · 3.42 KB
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
schema
@core(feature: "https://specs.apollo.dev/core/v0.2")
@core(feature: "https://specs.apollo.dev/join/v0.2", for: EXECUTION)
{
query: Query
}
directive @core(feature: String!, as: String, for: core__Purpose) repeatable on SCHEMA
directive @join__field(graph: join__Graph!, requires: join__FieldSet, provides: join__FieldSet, type: String, external: Boolean) repeatable on FIELD_DEFINITION | INPUT_FIELD_DEFINITION
directive @join__graph(name: String!, url: String!) on ENUM_VALUE
directive @join__implements(graph: join__Graph!, interface: String!) repeatable on OBJECT | INTERFACE
directive @join__type(graph: join__Graph!, key: join__FieldSet, extension: Boolean! = false) repeatable on OBJECT | INTERFACE | UNION | ENUM | INPUT_OBJECT | SCALAR
enum core__Purpose {
"""
`SECURITY` features provide metadata necessary to securely resolve fields.
"""
SECURITY
"""
`EXECUTION` features provide metadata necessary for operation execution.
"""
EXECUTION
}
type DeliveryEstimates
@join__type(graph: INVENTORY)
{
estimatedDelivery: String
fastestDelivery: String
}
scalar join__FieldSet
enum join__Graph {
INVENTORY @join__graph(name: "inventory", url: "http://inventory:4000/graphql")
PRODUCTS @join__graph(name: "products", url: "http://products:4000/graphql")
USERS @join__graph(name: "users", url: "http://users:4000/graphql")
}
type Product implements ProductItf & SkuItf
@join__implements(graph: INVENTORY, interface: "ProductItf")
@join__implements(graph: PRODUCTS, interface: "ProductItf")
@join__implements(graph: PRODUCTS, interface: "SkuItf")
@join__type(graph: INVENTORY, key: "id")
@join__type(graph: PRODUCTS, key: "id")
@join__type(graph: PRODUCTS, key: "sku package")
@join__type(graph: PRODUCTS, key: "sku variation { id }")
{
id: ID!
dimensions: ProductDimension @join__field(graph: INVENTORY, external: true) @join__field(graph: PRODUCTS)
delivery(zip: String): DeliveryEstimates @join__field(graph: INVENTORY, requires: "dimensions { size weight }")
sku: String @join__field(graph: PRODUCTS)
package: String @join__field(graph: PRODUCTS)
variation: ProductVariation @join__field(graph: PRODUCTS)
createdBy: User @join__field(graph: PRODUCTS)
}
type ProductDimension
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
{
size: String
weight: Float
}
interface ProductItf implements SkuItf
@join__implements(graph: PRODUCTS, interface: "SkuItf")
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
{
id: ID!
dimensions: ProductDimension
delivery(zip: String): DeliveryEstimates @join__field(graph: INVENTORY)
sku: String @join__field(graph: PRODUCTS)
package: String @join__field(graph: PRODUCTS)
variation: ProductVariation @join__field(graph: PRODUCTS)
createdBy: User @join__field(graph: PRODUCTS)
}
type ProductVariation
@join__type(graph: PRODUCTS)
{
id: ID!
}
type Query
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
@join__type(graph: USERS)
{
allProducts: [ProductItf] @join__field(graph: PRODUCTS)
product(id: ID!): ProductItf @join__field(graph: PRODUCTS)
}
enum ShippingClass
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
{
STANDARD
EXPRESS
OVERNIGHT
}
interface SkuItf
@join__type(graph: PRODUCTS)
{
sku: String
}
type User
@join__type(graph: PRODUCTS, key: "email")
@join__type(graph: USERS, key: "email")
{
email: ID!
totalProductsCreated: Int
name: String @join__field(graph: USERS)
}