Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/corbaz/next
https://github.com/corbaz/next
Last synced: 8 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/corbaz/next
- Owner: corbaz
- Created: 2023-01-10T08:27:03.000Z (almost 2 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T18:32:28.000Z (about 2 months ago)
- Last Synced: 2024-10-29T20:37:39.809Z (about 2 months ago)
- Language: TypeScript
- Size: 6.86 MB
- Stars: 0
- Watchers: 0
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# NestJS Starter
## Social Login https://javascript.plainenglish.io/oauth2-in-nestjs-for-social-login-google-facebook-twitter-etc-8b405d570fd2
[![CI](https://github.com/thisismydesign/nestjs-starter/actions/workflows/ci.yml/badge.svg)](https://github.com/thisismydesign/nestjs-starter/actions/workflows/ci.yml)#### NestJS MVC boilerplate for rapid development with battle-tested standards.
[Use this template](https://github.com/thisismydesign/nestjs-starter/generate)
[![Deploy](https://www.herokucdn.com/deploy/button.svg)](https://heroku.com/deploy)
## Stack
It has
- Example REST and GraphQL modules, DB using TypeORM as seen on https://docs.nestjs.com/
- [Next.js](https://nextjs.org/) integration for React on the frontend ([howto article](https://csaba-apagyi.medium.com/nestjs-react-next-js-in-one-mvc-repo-for-rapid-prototyping-faed42a194ca))
- Typed queries & results with GraphQL out of the box ([howto article](https://csaba-apagyi.medium.com/automagically-typed-graphql-queries-and-results-with-apollo-3731bad989aa))
- Authentication via [Passport.js](http://www.passportjs.org/) including Social providers ([howto article](https://medium.com/csaba.apagyi/oauth2-in-nestjs-for-social-login-google-facebook-twitter-etc-8b405d570fd2)), [AWS Cognito](https://aws.amazon.com/cognito/) ([howto article](https://medium.com/csaba.apagyi/cognito-via-oauth2-in-nestjs-outsourcing-authentication-without-vendor-lock-in-ce908518f547)), and JWT strategy for REST and GraphQL
- Docker setup
- Typescript, ESLint
- CI via GitHub Actions
- Running tasks (e.g. DB seeding) via [nestjs-console](https://github.com/Pop-Code/nestjs-console)
- Unit and integration testing via Jest
- Heroku deployment setup
- Google Analytics 4## Usage
### Production
https://nestjs-starter-production.herokuapp.com/
### Staging
https://nestjs-starter-staging.herokuapp.com/
### Dev
```sh
cp .env.example .env
docker-compose up
docker-compose exec web yarn lint
docker-compose exec web yarn test
docker-compose exec web yarn test:request
docker-compose exec web yarn build
docker run -it -v $PWD:/e2e -w /e2e --entrypoint=cypress cypress/included:10.0.3 run --config-file cypress.docker.config.ts
```## Functionality
REST endpoint via Nest
- http://localhost:3000/JWT-protected REST endpoint via Nest
- http://localhost:3000/privateGraphQL playground (`query WhoAmI` is JWT-protected)
- http://localhost:3000/graphql
```qgl
query Public {
things {
id
name
}users {
id
provider
}
}# Add Header: { "Authorization": "Bearer " }
query Private {
whoAmI {
id,
provider,
providerId,
username,
name
}orders {
idalias
thing {
name
}
}
}mutation createOrder {
createOrder(alias: "myname", thingName: "this is a thing you can order") {
id
alias
}
}
```Cognito auth (redirects to hosted Cognito UI)
- http://localhost:3000/auth/cognitoGoogle auth
- http://localhost:3000/auth/googleNext.js page
- http://localhost:3000/homeJWT-protected Next.js page
- http://localhost:3000/profile### Useful commands
Nest CLI:
```
docker-compose exec web yarn nest -- --help
```TypeORM CLI:
```
docker-compose exec web yarn typeorm -- --help
```## Resources
- https://github.com/jmcdo29/testing-nestjs