This is just for simple project.
However, you can learn the file structure and strategies for aws lambda to develop in local.
benefit of these file structure is to deploy easily as functions or the whole project.
can be used for :
- File Structure
- Before installation the npm dependences
- After installation the npm dependences
- npm Dependences
- How to Setup
- How to Run
- How to Test
- Swagger
- Acknowledgement
Structure is base on lambda functions.
So we can easily deploy to lambda or ECS or EC2 as the monolith or microservice.
We can separate authorizer and functions too.
All the services on our code would be functions in Lambda and middleware will be lambda Authorizer as well as all the others are the layers.
.
├── http # dir for sqlite3 database
| ├── routes # sqlite3 db file
│ │ ├── routegenerator.js
│ │ └── routelist.js
| ├── package.json # sqlite3 db file
| └── server.js # sqlite3 db file
├── lambda # nodejs source code
│ ├── functions # administrator and customer middlewares
│ │ └── ...
│ └── layers # Controllers , we can deploy them to AWS Lambda functions
│ ├── v1 # For all admin functions
│ │ ├── package.json
│ │ └── ...
│ └── v2 # For all user functions
│ ├── package.json
│ └── ...
├── resources # for documentations
│ └── ...
├── .eslintrc.cjs # for standar code check
├── package.json
├── README.md
└── ...
.
├── http # dir for sqlite3 database
| ├── routes # sqlite3 db file
│ │ ├── routegenerator.js
│ │ └── routelist.js
| ├── package.json # sqlite3 db file
│ ├── node_modules
│ │ └── ...
| └── server.js # sqlite3 db file
├── lambda # nodejs source code
│ ├── functions # administrator and customer middlewares
│ │ └── ...
│ └── layers # Controllers , we can deploy them to AWS Lambda functions
│ ├── v1 # For all admin functions
│ │ ├── package.json
│ │ ├── node_modules
│ │ │ └── ...
│ │ └── ...
│ └── v2 # For all user functions
│ ├── package.json
│ ├── node_modules
│ │ └── ...
│ └── ...
├── resources # for documentations
│ └── ...
├── .eslintrc.cjs # for standar code check
├── package.json
├── node_modules
│ └── ...
├── README.md
└── ...
- Root
- supervisor ^0.12.0 - to restart app on source code changes or crash app
- jest ^28.0.3 - for unit testing
- supertest ^6.2.3 - for api testing
- http
- express ^4.18.1 - to handle rest api
- cors ^2.8.5 - for api cors allown and deny
- swagger-jsdoc ^6.2.1 - for api doc
- swagger-ui-express ^4.3.0 - express api doc
- lambda
- functions
- nothing to install
- layers
- layerauthorizer
- jsonwebtoken ^8.5.1 - JWT
- v1
- dotenv ^16.0.0 - to load environment variable from .env file or sys environment variable
- md5 ^2.3.0 - for one way password hex
- jsonwebtoken ^8.5.1 - JWT
- mysql ^2.18.1 - for db crud
- layerauthorizer
- functions
We have to install npm dependence to run our program smoothly. pls follow as the singlie line of the following command.
npm run setup
Configuration is just for dev(local) only. we can easily execute our program in local as the following command.
npm run dev
I use jest and supertest npm package for testing. main program is base on commajs and jest is base on model type. however we can run and test our program because i have configured in package.json. You can check the testing source code in ./test directory too. Here is the command to run the testing.
npm test
we can reach to our swagger from this link...
Link API Doc swagger -> http://localhost:9999/swagger/
We can test the api ourselves.
Thank you all for visiting to my repo. please feel free to contact me.