{"id":13440483,"url":"https://github.com/kriasoft/graphql-starter-kit","last_synced_at":"2025-05-13T16:07:31.227Z","repository":{"id":37467540,"uuid":"69668139","full_name":"kriasoft/graphql-starter-kit","owner":"kriasoft","description":"💥  Monorepo template (seed project) pre-configured with GraphQL API, PostgreSQL, React, and Joy UI.","archived":false,"fork":false,"pushed_at":"2024-11-10T20:45:45.000Z","size":154215,"stargazers_count":3939,"open_issues_count":9,"forks_count":559,"subscribers_count":76,"default_branch":"main","last_synced_at":"2025-04-20T12:26:56.661Z","etag":null,"topics":["api","boilerplate","cloud-run","graphql","graphql-yoga","hackathon","jotai","joy-ui","monorepo","nodejs","postgres","postgresql","pothos","prisma","react","starter-kit","template","terraform","typescript","yarn"],"latest_commit_sha":null,"homepage":"https://graphqlstart.com","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kriasoft.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":".github/CONTRIBUTING.md","funding":".github/FUNDING.yml","license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null},"funding":{"github":"kriasoft","patreon":"koistya"}},"created_at":"2016-09-30T13:14:17.000Z","updated_at":"2025-04-19T20:38:54.000Z","dependencies_parsed_at":"2022-07-14T04:30:31.054Z","dependency_job_id":"6f67a9a1-3d8e-40de-ac30-cdd575b5bfc9","html_url":"https://github.com/kriasoft/graphql-starter-kit","commit_stats":{"total_commits":376,"total_committers":25,"mean_commits":15.04,"dds":"0.17553191489361697","last_synced_commit":"c1e278656ff5009ede028ed5715d3fb60961042d"},"previous_names":["kriasoft/graphql-starter-kit","kriasoft/nodejs-api-starter","kriasoft/relay-starter-kit","kriasoft/graphql-starter"],"tags_count":0,"template":true,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kriasoft%2Fgraphql-starter-kit","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kriasoft%2Fgraphql-starter-kit/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kriasoft%2Fgraphql-starter-kit/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kriasoft%2Fgraphql-starter-kit/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kriasoft","download_url":"https://codeload.github.com/kriasoft/graphql-starter-kit/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":250337904,"owners_count":21414103,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api","boilerplate","cloud-run","graphql","graphql-yoga","hackathon","jotai","joy-ui","monorepo","nodejs","postgres","postgresql","pothos","prisma","react","starter-kit","template","terraform","typescript","yarn"],"created_at":"2024-07-31T03:01:23.184Z","updated_at":"2025-04-23T20:53:18.563Z","avatar_url":"https://github.com/kriasoft.png","language":"TypeScript","funding_links":["https://github.com/sponsors/kriasoft","https://patreon.com/koistya","http://patreon.com/koistya","https://img.shields.io/badge/dynamic/json?color=%23ff424d\u0026label=Patreon\u0026style=flat-square\u0026query=data.attributes.patron_count\u0026suffix=%20patrons\u0026url=https%3A%2F%2Fwww.patreon.com%2Fapi%2Fcampaigns%2F233228"],"categories":["TypeScript","React Starter Kit — \"[isomorphic](http://nerds.airbnb.com/isomorphic-javascript-future-web-apps/)\" web app boilerplate \u0026nbsp; \u003ca href=\"https://github.com/kriasoft/react-starter-kit/stargazers\"\u003e\u003cimg src=\"https://img.shields.io/github/stars/kriasoft/react-starter-kit.svg?style=social\u0026label=Star\u0026maxAge=3600\" height=\"20\"\u003e\u003c/a\u003e \u003ca href=\"https://twitter.com/ReactStarter\"\u003e\u003cimg src=\"https://img.shields.io/twitter/follow/ReactStarter.svg?style=social\u0026label=Follow\u0026maxAge=3600\" height=\"20\"\u003e\u003c/a\u003e","boilerplate","\u003ca name=\"TypeScript\"\u003e\u003c/a\u003eTypeScript","📦 Legacy \u0026 Inactive Projects"],"sub_categories":["Related Projects"],"readme":"\u003ch1 align=\"center\"\u003e\n  \u003cimg src=\"https://s.tarkus.me/graphql-logo.png\" width=\"128\" height=\"128\" alt=\"GraphQL\" /\u003e\u003cbr\u003e\n  GraphQL Starter Kit\n  \u003cbr\u003e\n  \u003ca href=\"http://www.typescriptlang.org/\"\u003e\u003cimg src=\"https://img.shields.io/badge/%3C%2F%3E-TypeScript-%230074c1.svg?style=flat-square\" height=\"20\"\u003e\u003c/a\u003e\n  \u003ca href=\"http://patreon.com/koistya\"\u003e\u003cimg src=\"https://img.shields.io/badge/dynamic/json?color=%23ff424d\u0026label=Patreon\u0026style=flat-square\u0026query=data.attributes.patron_count\u0026suffix=%20patrons\u0026url=https%3A%2F%2Fwww.patreon.com%2Fapi%2Fcampaigns%2F233228\" height=\"20\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://discord.gg/gx5pdvZ7Za\"\u003e\u003cimg src=\"https://img.shields.io/discord/643523529131950086?label=Chat\u0026style=flat-square\" height=\"20\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://github.com/kriasoft/graphql-starter-kit/stargazers\"\u003e\u003cimg src=\"https://img.shields.io/github/stars/kriasoft/graphql-starter-kit.svg?style=social\u0026label=Star\u0026maxAge=3600\" height=\"20\"\u003e\u003c/a\u003e\n  \u003ca href=\"https://twitter.com/koistya\"\u003e\u003cimg src=\"https://img.shields.io/twitter/follow/koistya.svg?style=social\u0026label=Follow\u0026maxAge=3600\" height=\"20\"\u003e\u003c/a\u003e\n\u003c/h1\u003e\n\nHigh-performance GraphQL API server, database dev tools, and React front-end.\n\n## Features\n\n- [Monorepo](https://yarnpkg.com/features/workspaces) project structure powered by [Yarn](https://yarnpkg.com/) with [PnP](https://yarnpkg.com/features/pnp).\n- [GraphQL API](https://graphql.org/) powered by [GraphQL Yoga](https://the-guild.dev/graphql/yoga-server), [Pothos GraphQL](https://pothos-graphql.dev/), and [μWebSockets](https://github.com/uNetworking/uWebSockets.js).\n- Authentication and authorization powered by [Google Identity Platform](https://cloud.google.com/identity-platform).\n- Database tooling — seed files, migrations, [Knex.js](https://knexjs.org/) REPL shell, etc.\n- Front-end boilerplate pre-configured with [TypeScript](https://www.typescriptlang.org/), [Vite](https://vitejs.dev/), [React](https://beta.reactjs.org/), and [Joy UI](https://mui.com/joy-ui/getting-started/).\n- Pre-configured dev, test / QA, production, and preview environments.\n- Pre-configured VSCode code snippets and other [VSCode](https://code.visualstudio.com/) settings.\n- The ongoing design and development is supported by these wonderful companies:\n\n\u003ca href=\"https://reactstarter.com/s/1\"\u003e\u003cimg src=\"https://reactstarter.com/s/1.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/s/2\"\u003e\u003cimg src=\"https://reactstarter.com/s/2.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/s/3\"\u003e\u003cimg src=\"https://reactstarter.com/s/3.png\" height=\"60\" /\u003e\u003c/a\u003e\n\n---\n\nThis project was bootstrapped with [GraphQL Starter Kit](https://github.com/kriasoft/graphql-starter-kit).\nBe sure to join our [Discord channel](https://discord.com/invite/bSsv7XM) for assistance.\n\n## Directory Structure\n\n`├──`[`.github`](.github) — GitHub configuration including CI/CD workflows.\u003cbr\u003e\n`├──`[`.vscode`](.vscode) — VSCode settings including code snippets, recommended extensions etc.\u003cbr\u003e\n`├──`[`app`](./app) — front-end application ([Vite](https://vitejs.dev/), [Vitest](https://vitest.dev/), [React](https://reactjs.org/), [Joy UI](https://mui.com/joy-ui/getting-started/templates/)).\u003cbr\u003e\n`├──`[`db`](./db) — database schema, seeds, and migrations ([PostgreSQL](https://www.postgresql.org/)).\u003cbr\u003e\n`├──`[`infra`](./infra) — cloud infrastructure configuration ([Terraform](https://www.terraform.io/)).\u003cbr\u003e\n`├──`[`scripts`](./scripts) — automation scripts shared across the project.\u003cbr\u003e\n`├──`[`server`](./server) — backend server ([GraphQL Yoga](https://the-guild.dev/graphql/yoga-server), [Pothos GraphQL](https://pothos-graphql.dev/)).\u003cbr\u003e\n`└── ...` — add more packages such as `worker`, `admin`, `mobile`, etc.\n\n## Requirements\n\n- [Node.js](https://nodejs.org/) v20 or newer with [Corepack](https://nodejs.org/api/corepack.html) enabled.\n- Local or remote instance of [PostgreSQL](https://www.postgresql.org/).\n- [VS Code](https://code.visualstudio.com/) editor with [recommended extensions](.vscode/extensions.json).\n\n## Getting Started\n\nJust [clone](https://github.com/kriasoft/graphql-starter-kit/generate) the repo\nand, install project dependencies and bootstrap the PostgreSQL database:\n\n```bash\n$ git clone https://github.com/kriasoft/graphql-starter-kit.git example\n$ cd ./example                  # Change current directory to the newly created one\n$ corepack enable               # Ensure Yarn is installed\n$ yarn install                  # Install project dependencies\n$ yarn db create                # Create a new database if doesn't exist\n$ yarn db migrate --seed        # Migrate and seed the database\n```\n\nFrom there on, you can launch the app by running:\n\n```bash\n$ yarn workspace server start   # Or, `yarn server:start`\n$ yarn workspace app start      # Or, `yarn app:start`\n```\n\nThe GraphQL API server should become available at [http://localhost:8080/](http://localhost:8080/).\u003cbr\u003e\nWhile the front-end server should be running at [http://localhost:5173/](http://localhost:5173/).\n\n**IMPORTANT**: Tap `Shift`+`Cmd`+`P` in VSCode, run the **TypeScript: Select TypeScript Version** command and select the workspace version.\n\n## How to Update\n\nIn the case when you kept the original GraphQL Starter Kit git history, you can\nalways pull and merge updates from the \"seed\" repository back into your\nproject by running:\n\n```bash\n$ git fetch seed                # Fetch GraphQL Starter Kit (seed) repository\n$ git checkout main             # Switch to the main branch (or, master branch)\n$ git merge seed/main           # Merge upstream/master into the local branch\n```\n\nIn order to update Yarn and other dependencies to the latest versions, run:\n\n```bash\n$ yarn set version latest       # Upgrade Yarn CLI to the latest version\n$ yarn upgrade-interactive      # Bump Node.js dependencies using an interactive mode\n$ yarn install                  # Install the updated Node.js dependencies\n$ yarn dlx @yarnpkg/sdks vscode # Update VSCode settings\n```\n\n## Backers\n\n\u003ca href=\"https://reactstarter.com/b/1\"\u003e\u003cimg src=\"https://reactstarter.com/b/1.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/2\"\u003e\u003cimg src=\"https://reactstarter.com/b/2.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/3\"\u003e\u003cimg src=\"https://reactstarter.com/b/3.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/4\"\u003e\u003cimg src=\"https://reactstarter.com/b/4.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/5\"\u003e\u003cimg src=\"https://reactstarter.com/b/5.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/6\"\u003e\u003cimg src=\"https://reactstarter.com/b/6.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/7\"\u003e\u003cimg src=\"https://reactstarter.com/b/7.png\" height=\"60\" /\u003e\u003c/a\u003e\u0026nbsp;\u0026nbsp;\u003ca href=\"https://reactstarter.com/b/8\"\u003e\u003cimg src=\"https://reactstarter.com/b/8.png\" height=\"60\" /\u003e\u003c/a\u003e\n\n## How to Contribute\n\nWe welcome contributions through pull requests and issues on our GitHub repository. Feel free to also start a conversation on our [Discord server](https://discord.com/invite/PkRad23) to discuss potential contributions or seek guidance.\n\n## License\n\nCopyright © 2014-present Kriasoft. This source code is licensed under the MIT license found in the\n[LICENSE](https://github.com/kriasoft/graphql-starter-kit/blob/main/LICENSE) file.\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkriasoft%2Fgraphql-starter-kit","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkriasoft%2Fgraphql-starter-kit","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkriasoft%2Fgraphql-starter-kit/lists"}