schema
@link(url: "https://specs.apollo.dev/link/v1.0")
@link(url: "https://specs.apollo.dev/join/v0.5", for: EXECUTION)
@link(url: "https://specs.apollo.dev/connect/v0.2", for: EXECUTION)
@join__directive(
graphs: [CONNECTORS]
name: "link"
args: { url: "https://specs.apollo.dev/connect/v0.2", import: ["@source", "@connect"] }
)
@join__directive(
graphs: [CONNECTORS]
name: "source"
args: {
name: "withconfig"
http: { baseURL: "http://localhost:4001/api" }
errors: { message: "error.message", extensions: "code: error.code\n status: $status\n fromSource: $('a')" }
}
)
@join__directive(
graphs: [CONNECTORS]
name: "source"
args: { name: "withoutconfig", http: { baseURL: "http://localhost:4001/api" } }
)
@join__directive(
graphs: [CONNECTORS]
name: "source"
args: {
name: "withpartialconfig"
http: { baseURL: "http://localhost:4001/api" }
errors: { extensions: "code: error.code\n status: $status\n fromSource: $('a')" }
}
) {
query: Query
}
directive @join__directive(
graphs: [join__Graph!]
name: String!
args: join__DirectiveArguments
) repeatable on SCHEMA | OBJECT | INTERFACE | FIELD_DEFINITION
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
overrideLabel: String
contextArguments: [join__ContextArgument!]
) 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
input join__ContextArgument {
name: String!
type: String!
context: String!
selection: join__FieldValue!
}
scalar join__DirectiveArguments
scalar join__FieldSet
scalar join__FieldValue
enum join__Graph {
CONNECTORS @join__graph(name: "connectors", url: "http://none")
}
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
}
type Query @join__type(graph: CONNECTORS) {
only_source: [User!]!
@join__directive(
graphs: [CONNECTORS]
name: "connect"
args: { source: "withconfig", http: { GET: "/users" }, selection: "id name username" }
)
only_connect: [User!]!
@join__directive(
graphs: [CONNECTORS]
name: "connect"
args: {
source: "withoutconfig"
http: { GET: "/users" }
selection: "id name username"
errors: { message: "error.message", extensions: "code: error.code\n status: $status" }
}
)
both_source_and_connect: [User!]!
@join__directive(
graphs: [CONNECTORS]
name: "connect"
args: {
source: "withconfig"
http: { GET: "/users" }
selection: "id name username"
errors: { message: "error.message", extensions: "code: error.code\n fromConnect: $('b')" }
}
)
partial_source_and_partial_connect: [User!]!
@join__directive(
graphs: [CONNECTORS]
name: "connect"
args: {
source: "withpartialconfig"
http: { GET: "/users" }
selection: "id name username"
errors: { message: "error.message" }
}
)
}
type User @join__type(graph: CONNECTORS) {
id: ID!
name: String
username: String
}