-
Notifications
You must be signed in to change notification settings - Fork 0
/
supergraph.graphql
87 lines (71 loc) · 2.67 KB
/
supergraph.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
77
78
79
80
81
82
83
84
85
86
87
schema
@link(url: "https://specs.apollo.dev/link/v1.0")
@link(url: "https://specs.apollo.dev/join/v0.3", for: EXECUTION)
{
query: Query
}
directive @join__enumValue(graph: join__Graph!) repeatable on ENUM_VALUE
directive @join__field(graph: join__Graph, requires: join__FieldSet, provides: join__FieldSet, type: String, external: Boolean, override: String, usedOverridden: 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, resolvable: Boolean! = true, isInterfaceObject: Boolean! = false) repeatable on OBJECT | INTERFACE | UNION | ENUM | INPUT_OBJECT | SCALAR
directive @join__unionMember(graph: join__Graph!, member: String!) repeatable on UNION
directive @link(url: String, as: String, for: link__Purpose, import: [link__Import]) repeatable on SCHEMA
scalar join__FieldSet
enum join__Graph {
PRODUCTS @join__graph(name: "products", url: "http://127.0.0.1:3075/")
REVIEWS @join__graph(name: "reviews", url: "http://127.0.0.1:3085/")
USERS @join__graph(name: "users", url: "http://127.0.0.1:3065/")
}
scalar link__Import
enum link__Purpose {
"""
`SECURITY` features provide metadata necessary to securely resolve fields.
"""
SECURITY
"""
`EXECUTION` features provide metadata necessary for operation execution.
"""
EXECUTION
}
"""Define the Product entity so that we can extend it."""
type Product
@join__type(graph: PRODUCTS, key: "id")
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
name: String! @join__field(graph: PRODUCTS)
price: String! @join__field(graph: PRODUCTS)
reviews: [Review!]! @join__field(graph: REVIEWS)
}
type Query
@join__type(graph: PRODUCTS)
@join__type(graph: REVIEWS)
@join__type(graph: USERS)
{
product(id: ID!): Product! @join__field(graph: PRODUCTS)
products: [Product!]! @join__field(graph: PRODUCTS)
review(id: ID!): Review! @join__field(graph: REVIEWS)
reviews: [Review!]! @join__field(graph: REVIEWS)
me: User! @join__field(graph: USERS)
users: [User!]! @join__field(graph: USERS)
}
type Review
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
body: String!
author: User!
product: Product!
}
"""Define the User entity so that we can extend it."""
type User
@join__type(graph: PRODUCTS, key: "id")
@join__type(graph: REVIEWS, key: "id")
@join__type(graph: USERS, key: "id")
{
id: ID!
purchases: [Product!]! @join__field(graph: PRODUCTS)
reviews: [Review!]! @join__field(graph: REVIEWS)
name: String! @join__field(graph: USERS)
}