-
-
Save jaydenseric/dccd8719ee41741df6d221815a0b0394 to your computer and use it in GitHub Desktop.
Custom fragment matcher and schema fetching script for `apollo-cache-inmemory`.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| GRAPHQL_URI=http://localhost:3001/graphql |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| { | |
| "schemaPath": "schema.graphql", | |
| "extensions": { | |
| "endpoints": { | |
| "development": "${env:GRAPHQL_URI}" | |
| } | |
| } | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| import InMemoryCache from 'apollo-cache-inmemory' | |
| import createFragmentMatcher from './fragment-matcher' | |
| import implementations from './schema-implementations.json' | |
| const cache = new InMemoryCache({ | |
| fragmentMatcher: createFragmentMatcher(implementations) | |
| }) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| export default implementations => ({ | |
| match: ({ id }, typename, { store }) => { | |
| const cached = store[id] | |
| if (!cached) return false | |
| if (!cached.__typename) | |
| throw new Error( | |
| `Missing __typename to match fragment: ${JSON.stringify(cached)}` | |
| ) | |
| return ( | |
| typename === cached.__typename || | |
| (implementations[typename] && | |
| implementations[typename].includes(cached.__typename)) | |
| ) | |
| } | |
| }) |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| { | |
| "dependencies": { | |
| "apollo-cache-inmemory": "^0.2.0-beta.5", | |
| "dotenv-cli": "^1.4.0" | |
| }, | |
| "devDependencies": { | |
| "graphql-config": "^1.0.7" | |
| }, | |
| "scripts": { | |
| "update-schema": "dotenv node update-schema" | |
| } | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| { | |
| "Person": [ | |
| "Student", | |
| "Teacher" | |
| ] | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| interface Person { | |
| id: ID! | |
| name: String! | |
| } | |
| type Student implements Person { | |
| id: ID! | |
| name: String! | |
| } | |
| type Teacher implements Person { | |
| id: ID! | |
| name: String! | |
| } |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| const { getGraphQLProjectConfig, writeSchema } = require('graphql-config') | |
| const { writeFile } = require('fs') | |
| const { promisify } = require('util') | |
| const writeFileAsync = promisify(writeFile) | |
| const projectConfig = getGraphQLProjectConfig() | |
| const endpoint = projectConfig.endpointsExtension.getEndpoint('development') | |
| endpoint | |
| .resolveSchema() | |
| .then(schema => { | |
| const updateSchema = writeSchema(projectConfig.schemaPath, schema) | |
| const updateImplementations = writeFileAsync( | |
| 'schema-implementations.json', | |
| `${JSON.stringify(schema._implementations, null, 2)}\n` | |
| ) | |
| Promise.all([updateSchema, updateImplementations]) | |
| .then(() => console.log('Updated schema.')) | |
| .catch(console.error) | |
| }) | |
| .catch(console.error) |
Author
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Following on from this discussion.
The
update-schemascript simultaneously generatesschema-implementations.jsonfor the custom fragment matcher, as well asschema.graphqlforeslint-plugin-graphqland other tools that refer to.graphqlconfigfrom a remote GraphQL API..graphqlconfigcan be configured for a.graphqlor.jsonschema; I choose to use.graphqlbecause it is about 7 thousand lines smaller for versioning and easier to read.To my knowledge,
schema._implementationsworks for both unions and interfaces but I could be wrong, since we don't use unions and I havn't tested it.