Skip to content

Commit

Permalink
feat: rename
Browse files Browse the repository at this point in the history
  • Loading branch information
Samuel Vazquez committed Nov 11, 2024
1 parent 9cb3919 commit e8736f5
Show file tree
Hide file tree
Showing 6 changed files with 200 additions and 4 deletions.
2 changes: 1 addition & 1 deletion bun/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { QueryPlannerService } from '../shared/query-planner-service';

const port = 3001;
const queryPlannerService = new QueryPlannerService(
await Bun.file('./shared/supergraph.graphql').text()
await Bun.file('./shared/schema.graphql').text()
);

Bun.serve({
Expand Down
2 changes: 1 addition & 1 deletion deno/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import fs from 'node:fs';

const port = 3002;
const queryPlannerService = new QueryPlannerService(
fs.readFileSync('./shared/supergraph.graphql', 'utf-8')
fs.readFileSync('./shared/schema.graphql', 'utf-8')
);

Deno.serve({ port }, async (req) => {
Expand Down
2 changes: 1 addition & 1 deletion node/server.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import fs from 'fs';

const port = 3000;
const queryPlannerService = new QueryPlannerService(
fs.readFileSync('./shared/supergraph.graphql', 'utf-8')
fs.readFileSync('./shared/schema.graphql', 'utf-8')
);

express()
Expand Down
2 changes: 1 addition & 1 deletion rust/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ use tokio::net::TcpListener;
use tower::{load_shed, timeout::error, BoxError, ServiceBuilder};

const PORT: i32 = 3004;
const FILENAME: &str = "./supergraph/supergraph.graphql";
const FILENAME: &str = "./supergraph/schema.graphql";

#[derive(Deserialize)]
#[serde(rename_all = "camelCase")]
Expand Down
98 changes: 98 additions & 0 deletions rust/supergraph/schema.graphql
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
schema
@link(url: "https://specs.apollo.dev/link/v1.0")
@link(url: "https://specs.apollo.dev/join/v0.3", for: EXECUTION)
{
query: Query
mutation: Mutation
}

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 {
ACCOUNTS @join__graph(name: "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/")
}

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 Mutation
@join__type(graph: PRODUCTS)
@join__type(graph: REVIEWS)
{
createProduct(upc: ID!, name: String): Product @join__field(graph: PRODUCTS)
createReview(upc: ID!, id: ID!, body: String): Review @join__field(graph: REVIEWS)
}

type Product
@join__type(graph: ACCOUNTS, key: "upc", extension: true)
@join__type(graph: INVENTORY, key: "upc")
@join__type(graph: PRODUCTS, key: "upc")
@join__type(graph: REVIEWS, key: "upc")
{
upc: String!
weight: Int @join__field(graph: INVENTORY, external: true) @join__field(graph: PRODUCTS)
price: Int @join__field(graph: INVENTORY, external: true) @join__field(graph: PRODUCTS)
inStock: Boolean @join__field(graph: INVENTORY)
shippingEstimate: Int @join__field(graph: INVENTORY, requires: "price weight")
name: String @join__field(graph: PRODUCTS)
reviews: [Review] @join__field(graph: REVIEWS)
reviewsForAuthor(authorID: ID!): [Review] @join__field(graph: REVIEWS)
}

type Query
@join__type(graph: ACCOUNTS)
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
@join__type(graph: REVIEWS)
{
me: User @join__field(graph: ACCOUNTS)
recommendedProducts: [Product] @join__field(graph: ACCOUNTS)
topProducts(first: Int = 5): [Product] @join__field(graph: PRODUCTS)
}

type Review
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
body: String
author: User @join__field(graph: REVIEWS, provides: "username")
product: Product
}

type User
@join__type(graph: ACCOUNTS, key: "id")
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
name: String @join__field(graph: ACCOUNTS)
username: String @join__field(graph: ACCOUNTS) @join__field(graph: REVIEWS, external: true)
reviews: [Review] @join__field(graph: REVIEWS)
}
98 changes: 98 additions & 0 deletions shared/schema.graphql
Original file line number Diff line number Diff line change
@@ -0,0 +1,98 @@
schema
@link(url: "https://specs.apollo.dev/link/v1.0")
@link(url: "https://specs.apollo.dev/join/v0.3", for: EXECUTION)
{
query: Query
mutation: Mutation
}

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 {
ACCOUNTS @join__graph(name: "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/")
}

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 Mutation
@join__type(graph: PRODUCTS)
@join__type(graph: REVIEWS)
{
createProduct(upc: ID!, name: String): Product @join__field(graph: PRODUCTS)
createReview(upc: ID!, id: ID!, body: String): Review @join__field(graph: REVIEWS)
}

type Product
@join__type(graph: ACCOUNTS, key: "upc", extension: true)
@join__type(graph: INVENTORY, key: "upc")
@join__type(graph: PRODUCTS, key: "upc")
@join__type(graph: REVIEWS, key: "upc")
{
upc: String!
weight: Int @join__field(graph: INVENTORY, external: true) @join__field(graph: PRODUCTS)
price: Int @join__field(graph: INVENTORY, external: true) @join__field(graph: PRODUCTS)
inStock: Boolean @join__field(graph: INVENTORY)
shippingEstimate: Int @join__field(graph: INVENTORY, requires: "price weight")
name: String @join__field(graph: PRODUCTS)
reviews: [Review] @join__field(graph: REVIEWS)
reviewsForAuthor(authorID: ID!): [Review] @join__field(graph: REVIEWS)
}

type Query
@join__type(graph: ACCOUNTS)
@join__type(graph: INVENTORY)
@join__type(graph: PRODUCTS)
@join__type(graph: REVIEWS)
{
me: User @join__field(graph: ACCOUNTS)
recommendedProducts: [Product] @join__field(graph: ACCOUNTS)
topProducts(first: Int = 5): [Product] @join__field(graph: PRODUCTS)
}

type Review
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
body: String
author: User @join__field(graph: REVIEWS, provides: "username")
product: Product
}

type User
@join__type(graph: ACCOUNTS, key: "id")
@join__type(graph: REVIEWS, key: "id")
{
id: ID!
name: String @join__field(graph: ACCOUNTS)
username: String @join__field(graph: ACCOUNTS) @join__field(graph: REVIEWS, external: true)
reviews: [Review] @join__field(graph: REVIEWS)
}

0 comments on commit e8736f5

Please sign in to comment.