Integrates the awesome TSOA framework with Serverless for building sweet APIs in Lambda with no cold starts and lots of strongly typed goodness!
https://rosacksoftwaresolutions.com/2017/03/20/serverless-monolithic-apis-and-tsoa/
Make sure you have Serverless installed globally (npm install -g serverless
) and install the dependencies (yarn is preferred), then you can:
npm run start
- This runs the TSOA pipeline, then builds the typescript using Serverless Webpack and serves it using Serverless Offline!
npm run debug
- Same as start, but launches with the debugger available for connection on port 5858. There's a launch.json for VSCode available that should allow you to just connect.
npm run deploy-dev
- Deploys everything out to AWS to play around with. Obviously, this may cost you money. You'll need to run this twice if you want to play with the
swagger - npm run fix-swagger
will tweak the swagger.json appropriately, but only after it's been deployed once and we can get the ServiceEndpoint from the CloudFormation outputs. (I'd love a better way to do this if anyone has any ideas.)
I don't have Swagger UI set up in the project, mostly because I really don't want to handle serving real HTML/JS assets (at least for now). If you want to play around with your API once you've got it up and running locally, just go to http://petstore.swagger.io?url=http://localhost:3000/v1/swagger.json.