Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/linbudu599/graphql-explorer-server
GraphQL Stack Example: Apollo Server & TypeGraphQL & TypeORM
https://github.com/linbudu599/graphql-explorer-server
apollo-server graphql starter-template typegraphql typeorm typestack
Last synced: 9 days ago
JSON representation
GraphQL Stack Example: Apollo Server & TypeGraphQL & TypeORM
- Host: GitHub
- URL: https://github.com/linbudu599/graphql-explorer-server
- Owner: linbudu599
- License: mit
- Created: 2020-09-03T04:42:48.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-09-21T17:41:35.000Z (over 1 year ago)
- Last Synced: 2025-02-06T19:14:06.729Z (15 days ago)
- Topics: apollo-server, graphql, starter-template, typegraphql, typeorm, typestack
- Language: TypeScript
- Homepage:
- Size: 19.9 MB
- Stars: 7
- Watchers: 2
- Forks: 1
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# GraphQL-Explorer-Server
data:image/s3,"s3://crabby-images/400e6/400e63373ca118d4ab2817c055a5510b2b16a929" alt="GitHub Workflow Status"
data:image/s3,"s3://crabby-images/6e46f/6e46f9b5e0aed845cec31fce6ab628d67c481c28" alt="Codecov"
data:image/s3,"s3://crabby-images/f43d9/f43d93703d4ba8bf5ef61da9e552685117d36cd7" alt="GitHub last commit"
data:image/s3,"s3://crabby-images/b109c/b109cab30b8f5309c3de71d00b558d431f0301e1" alt="David"data:image/s3,"s3://crabby-images/74f76/74f76ddd23e83477284f1d4f59c23bf5b3b0a815" alt="GitHub package.json dependency version (subfolder of monorepo)"
data:image/s3,"s3://crabby-images/736bc/736bc63338029ce5f007b753d8431667186522f9" alt="GitHub package.json dependency version (subfolder of monorepo)"
data:image/s3,"s3://crabby-images/6f885/6f8850db3e8b175d4caa3da3968bba5e257d5aa3" alt="GitHub package.json dependency version (subfolder of monorepo)"This is a **demo** which contains `GraphQL` and framework based on it(or work with it perfectly), including these for now:
## ๐ย Explore
```bash
npm install
npm run dev
```## ๐ตย Available Scripts
- `dev`: develop server by [nodemon](https://github.com/remy/nodemon).
- `build`: compile server code by [tsc](https://github.com/microsoft/TypeScript).
- `prebuild`: Generation of `GenQL` & `Prisma Client`.
- `postbuild`: copy generated `Prisma Client ` files, run `prisma db push` to create SQLite file.
- `build:vercel`: build scripts on Vercel Functions.
- `start`: run in prod by [nodemon](https://github.com/remy/nodemon)(recommended to run before deployment).
- `clean`: remove `/dist`(build output) & `api-dist`(Vercel build output) directory.
- `test`: run test cases by [Jest](https://github.com/facebook/jest).
- `pm2`: run in prod by [PM2](https://github.com/Unitech/pm2).
- `stress-test`: run pressure test to server, see [stress-fork.js](./st-fork.js) & [stress-main.js](./st-main.js).
- `voyager`: represent GraphQL API as an interactive graph by [GraphQL-Voyager](https://github.com/APIs-guru/graphql-voyager), **require local server to be active**.
- `gen:code`: generate type definitions from GraphQL schema by [GraphQL-Code-Generator](https://github.com/dotansimha/graphql-code-generator).
- `gen:docs`: generate documentation site from GraphQL schema by [GraphDoc](https://github.com/2fd/graphdoc).
- `gen`: generate docs & code, as `gen:code` & `gen:docs` require local server alive, **this command will use NodeJS `child_process` mod to handle server setup.**
- `serve:docs`: generate & serve documentation site by [serve](https://github.com/vercel/serve).
- `commit`: commit code by [custom commitlint config](.cz-config.js).
- `prettier`: prettier all `.ts` / `.json` / `.graphql` ext file.
- `typecheck`: check TypeScript type definitions.
- `seed:config`: check [typeorm-seeding](https://github.com/w3tecch/typeorm-seeding) config.
- `seed:run`: start seeding data in `/server/entity/seeds`.
- `genql`: generate GraphQL query builder by [GenQL](https://github.com/remorses/genql).
- `prisma:*` [Prisma 2](https://www.prisma.io/) Related Commands.### Main
- [x] GraphQL
- [x] TypeGraphQL
- [x] Apollo-Server
- [x] DataLoader (Supported By [TypeGraphQL-DataLoader](https://github.com/slaypni/type-graphql-dataloader))
- [x] TypeORM + SQLite3
- [x] Prisma 2(As replacement for TypeORM)
- [ ] Subscription### Other Powerful Tools
- [x] [GraphQLDoc](https://github.com/2fd/graphdoc)
- [x] [GraphQL-Voyager](https://github.com/APIs-guru/graphql-voyager)
- [x] [GenQL](https://github.com/remorses/genql)
- [x] [GraphQL-Code-Generator](https://github.com/dotansimha/graphql-code-generator)## Features
- [x] TypeORM Entity Relations [Setup](./server/entities): 1-1 1-m m-n
- [x] Most API of TypeGraphQL: InputType / InterfaceType / AuthChecker / Middlewares / Containers / ...
- [x] Configurated Apollo-Server With [Plugins](./server/plugins)
- [x] Visualized API Graph by GraphQLDoc & GraphQL-Voyager
- [x] Useful [Directives](./server/directives) & [Decorators](./server/decorators)## ๐๏ธ ย Server & Docs Deployment
- [x] [Docs by Surge](http://graphql-explorer-docs.surge.sh/)
- [x] [Voyager by Surge](http://graphql-explorer-voyager.surge.sh/) **(Require Local Server To Be Active)**
- [x] [Voyager on Remote Server](http://voyager.linbudu.top/)
- [x] [Simple Example on Vercel Fucntions](https://graphql-faas.vercel.app/api/sample), see [Query Example](./api/sample/query.graphql)
- [x] [Simple Example of Vercel Fucntions, with MySQL](https://graphql-faas.linbudu599.vercel.app/api/graphql)
- [x] [Full Server Deployed at ALI Cloud ECS](http://47.97.183.158:4399/graphql)
- [x] [Apollo Engine(**private**)](https://studio.apollographql.com/graph/My-Graph-innqj/explorer?schemaTag=current)## ๐ย Document
see offcial docs for more information.
- [GraphQL](https://graphql.org/)
- [Apollo-GraphQL](https://www.apollographql.com/docs/)
- [TypeGraphQL](https://typegraphql.com/)
- [TypeStack](https://github.com/typestack)
- [TypeORM](https://github.com/typeorm)
- [Prisma](https://www.prisma.io/)