Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/StarpTech/graphql-registry
GraphQL registry - single source of truth for registering and tracking your graph.
https://github.com/StarpTech/graphql-registry
graphql graphql-schema registry schema
Last synced: 2 months ago
JSON representation
GraphQL registry - single source of truth for registering and tracking your graph.
- Host: GitHub
- URL: https://github.com/StarpTech/graphql-registry
- Owner: StarpTech
- License: agpl-3.0
- Created: 2021-04-20T22:17:13.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2023-12-13T15:51:39.000Z (about 1 year ago)
- Last Synced: 2024-11-13T07:04:31.932Z (2 months ago)
- Topics: graphql, graphql-schema, registry, schema
- Language: TypeScript
- Homepage:
- Size: 2.11 MB
- Stars: 86
- Watchers: 7
- Forks: 8
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-list - graphql-registry - single source of truth for registering and tracking your graph. | StarpTech | 60 | (TypeScript)
README
---
> **Note**: Are you looking for a Complete API Management for GraphQL Federation? 🔎 Have a look at: [WunderGraph Cosmo](https://github.com/wundergraph/cosmo)
Includes Schema Registry, analytics, metrics, tracing, and routing. Available for 100% on-prem deployment or as a [Managed Service](https://cosmo.wundergraph.com/login). Apache 2.0 licensed, ensuring no vendor lock-in 🪄---
> There should be a **single source of truth** for registering and tracking the graph.
## Features
- Create multiple graphs (for example, staging and production, or different development branches)
- Stores versioned schemas for all GraphQL-federated services
- Serves schema for GraphQL gateway based on provided services & their versions
- Serves a supergraph schema for the GraphQL gateway
- Validates new schema to be compatible with other running services
- Validates that all client operations are supported by your schema
- Calculates a schema coverage report from GraphQL operations
- Validates if a schema update produce a breaking, dangerous or safe change
- Lightweight authorization concept based on JWT.[**Read more**](https://principledgraphql.com/integrity#3-track-the-schema-in-a-registry)
## Examples
- [Federation](./examples/mercurius-federation) with Mercurius.
- [Federation](./examples/apollo-federation) with Apollo Gateway.
- [Managed Federation](./examples/apollo-managed-federation) with Apollo Gateway.## API
Try all endpoints in [insomnia](https://insomnia.rest/run/?label=GraphQL%20Registry&uri=https%3A%2F%2Fraw.githubusercontent.com%2FStarpTech%2Fgraphql-registry%2Fmain%2Finsomnia.json) or read the api [documentation](./docs/api.md).
## Development
Copy `.env.example` to `.env`
```sh
# Install project
npm install
# Start postgres
docker-compose up postgres
# Create db schema
npm run migrate:up
# Watch mode
npm run dev
# Run tests
npm run test
```## Benchmark
Run a benchmark with:
```sh
docker-compose up postgres
docker-compose up --build app
docker-compose run k6 run /benchmark/composed-schema.js
```Our benchmark suite is running in the CI.
## Deployment
GraphQL-Registry uses by default postgres as database.
```sh
# Bootstrap database
npm install && npm run migrate:up
# Run service
docker run -e DATABASE_URL="" starptech/graphql-registry:latest -p 3000:3000
```[Available](/src/core/env.schema.ts) environment variables.
## Alpha version
GraphQL Registry is currently highly under development. It means that we are still working on essential features like production-ready schema management, graph metrics and development tooling. GraphQL Registry can be evaluated anytime. Every feature is covered by integration tests. We rely on your feedback and sponsorship. Feel free to open an issue or feature request!
## Contributing
❤️ contributions!
I will happily accept your pull request if it:
- has tests
- looks reasonable
- follows the [code of conduct](./CODE_OF_CONDUCT.md)### License
GraphQL Registry is open-source under the GNU Affero General Public License Version 3 (AGPLv3) or any later version. You can [find it here](LICENSE).
Why AGPLv3 and not MIT? Read the blog post from [plausible](https://plausible.io/blog/open-source-licenses) to learn more about our motivations.