Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork25
🚀 The Ultimate Monorepo Starter for Node.js Serverless Applications
License
ngneat/nx-serverless
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
The Ultimate Monorepo Starter for Node.js Serverless Applications
✅ First-Class Typescript Support
✅ DynamoDB Single Table Design
✅ Shared API Gateway
✅ Environments Configuration
✅ CORS
✅ JWT Auth Middleware
✅ Http Params Validation
✅ Typed Proxy Handlers
✅ Auto Generators
✅ Localstack
✅ ESLint
✅ Jest
✅ Github Actions
- Docker
- Node.js
- Run git clonehttps://github.com/ngneat/nx-serverless.git your-app-name
- Run
npm install
- Run
npm run localstack
( Check that it works by going tohttp://localhost:4566/health) - Run
npx nx deploy core --stage local
to create the table - Update the
environment
files based on your configuration - Run
npm run serve
The application contains three services:
The auth service is responsible for authentication. It exposes one route for signing up:
curl --request POST'http://localhost:3001/dev/auth/sign-up' \--data-raw'{ "email": "netanel@gmail.com", "name": "Netanel Basal"}'
The request returns a JWT, which is used for accessing protected routes.
The users service is responsible for managing users. It exposes one route:
curl'http://localhost:3003/dev/user' --header'Authorization: token TOKEN'
The request returns the logged-in user.
The todos service is responsible for managing todos. A user has many todos. It exposes CRUD routes:
// Get user todoscurl'http://localhost:3005/dev/todos' --header'Authorization: token TOKEN'// Get a single todocurl'http://localhost:3005/dev/todos/:id' --header'Authorization: token TOKEN'// Create a todocurl --request POST'http://localhost:3005/dev/todos' \--header'Authorization: token TOKEN'--data-raw'{ "title": "Learn Serverless"}'// Update a todocurl --request PUT'http://localhost:3005/dev/todos/:id' \--header'Authorization: token TOKEN' \--data-raw'{ "completed": true}'
Download NoSQL Workbench for DynamoDB and connect tohttp://localhost:4566
.
nx serve<service-name>nx deploy<service-name>nx remove<service-name>nx build<service-name>nx lint<service-name>nxtest<service-name>// Use different enviromentNODE_ENV=prod nx deploy<service-name> NODE_ENV=stg nx deploy<service-name> // Run only affectednx affected:testnx affected:deploy
// Generate a serviceyarn g:service tags// Generate handleryarn g:handler handler-name// Generate http handleryarn g:http-handler create-tag// Generate a modelyarn g:model tag
The pipeline has been configured to run everytime a push/pull_request is made to themain
branch. You should uncomment theci.yml
workflow.
Checkout: The
checkout
action is used to checkout the source code.Node setup: The
setup-node
action is used to optionally download and cache distribution of the requested Node.js version.lint and test: The
lint
andtest
runs only on affected projects.Configure AWS credentials: The credentials needed are
AWS_ACCESS_KEY_ID
andAWS_SECRET_ACCESS_KEY
and should be set as Githubsecrets.Each branch should be prefixed with the
environment
name. For example, if we have astg-feature-name
branch and open a pull request to themain
branch, it will setNODE_ENV
tostg
and deploy to this environment.
By merging the pull request to themain
branch,NODE_ENV
is set toprod
, and the deployment is done to production.
The workflow file can have as many environments as you need.
- VisitServerless Documentation to learn more about Serverless framework
- VisitNx Documentation to learn more about Nx dev toolkit
- VisitLocalStack to learn more about it
Found an issue? feel free to raise an issue with information to reproduce.
Pull requests are welcome to improve.
MIT
This project is a fork ofnx-serverless
About
🚀 The Ultimate Monorepo Starter for Node.js Serverless Applications
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Releases
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.
Packages0
Uh oh!
There was an error while loading.Please reload this page.