schema @core(feature: "https://specs.apollo.dev/core/v0.2"), @core(feature: "https://specs.apollo.dev/join/v0.1", for: EXECUTION) @core(feature: "https://specs.apollo.dev/inaccessible/v0.1", for: SECURITY) { query: Query mutation: Mutation } directive @core(as: String, feature: String!, for: core__Purpose) repeatable on SCHEMA directive @join__field(graph: join__Graph, requires: join__FieldSet, provides: join__FieldSet) on FIELD_DEFINITION directive @join__type(graph: join__Graph!, key: join__FieldSet) repeatable on OBJECT | INTERFACE directive @join__owner(graph: join__Graph!) on OBJECT | INTERFACE directive @join__graph(name: String!, url: String!) on ENUM_VALUE directive @tag(name: String!) repeatable on FIELD_DEFINITION | INTERFACE | OBJECT | UNION directive @inaccessible on OBJECT | FIELD_DEFINITION | INTERFACE | UNION enum core__Purpose { """ `EXECUTION` features provide metadata necessary to for operation execution. """ EXECUTION """ `SECURITY` features provide metadata necessary to securely resolve fields. """ SECURITY } scalar join__FieldSet enum join__Graph { ACCOUNTS @join__graph(name: "invalidation-subgraph-type-accounts", url: "https://accounts.demo.starstuff.dev") INVENTORY @join__graph(name: "inventory", url: "https://inventory.demo.starstuff.dev") PRODUCTS @join__graph(name: "products", url: "https://products.demo.starstuff.dev") REVIEWS @join__graph(name: "reviews", url: "https://reviews.demo.starstuff.dev") } type Mutation { updateMyAccount: User @join__field(graph: ACCOUNTS) createProduct(name: String, upc: ID!): Product @join__field(graph: PRODUCTS) createReview(body: String, id: ID!, upc: ID!): Review @join__field(graph: REVIEWS) } type Product @join__owner(graph: PRODUCTS) @join__type(graph: PRODUCTS, key: "upc") @join__type(graph: INVENTORY, key: "upc") @join__type(graph: REVIEWS, key: "upc") { inStock: Boolean @join__field(graph: INVENTORY) @tag(name: "private") @inaccessible name: String @join__field(graph: PRODUCTS) price: Int @join__field(graph: PRODUCTS) reviews: [Review] @join__field(graph: REVIEWS) reviewsForAuthor(authorID: ID!): [Review] @join__field(graph: REVIEWS) shippingEstimate: Int @join__field(graph: INVENTORY, requires: "price weight") upc: String! @join__field(graph: PRODUCTS) weight: Int @join__field(graph: PRODUCTS) } type Query { me: User @join__field(graph: ACCOUNTS) topProducts(first: Int = 5): [Product] @join__field(graph: PRODUCTS) } type Review @join__owner(graph: REVIEWS) @join__type(graph: REVIEWS, key: "id") { author: User @join__field(graph: REVIEWS, provides: "username") body: String @join__field(graph: REVIEWS) id: ID! @join__field(graph: REVIEWS) product: Product @join__field(graph: REVIEWS) } type User @join__owner(graph: ACCOUNTS) @join__type(graph: ACCOUNTS, key: "id") @join__type(graph: REVIEWS, key: "id") { id: ID! @join__field(graph: ACCOUNTS) name: String @join__field(graph: ACCOUNTS) reviews: [Review] @join__field(graph: REVIEWS) username: String @join__field(graph: ACCOUNTS) }