Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/theboeffect/boilerplate
This is a boilerplate ESM, TypeScript, mongoose, openapi, etc. microservice template that I use for my work. It can be run as a docker container or a lambda function.
https://github.com/theboeffect/boilerplate
boilerplate docker express lambda microservice mongodb nodejs openapi serverless swagger typescript
Last synced: 3 months ago
JSON representation
This is a boilerplate ESM, TypeScript, mongoose, openapi, etc. microservice template that I use for my work. It can be run as a docker container or a lambda function.
- Host: GitHub
- URL: https://github.com/theboeffect/boilerplate
- Owner: theBoEffect
- Created: 2020-03-15T00:11:25.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-03-17T18:04:43.000Z (10 months ago)
- Last Synced: 2024-03-17T19:24:16.674Z (10 months ago)
- Topics: boilerplate, docker, express, lambda, microservice, mongodb, nodejs, openapi, serverless, swagger, typescript
- Language: TypeScript
- Homepage: https://theboeffect.com
- Size: 5.73 MB
- Stars: 3
- Watchers: 1
- Forks: 3
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Boilerplate Service
A boilerplate typescript micro service that runs as docker or lambda. Click "Use this Template" to use this for your service.
[![CI](https://github.com/theBoEffect/boilerplate/actions/workflows/main.yml/badge.svg?branch=master)](https://github.com/theBoEffect/boilerplate/actions/workflows/main.yml)
#### follow me:
* [twitter](https://twitter.com/theboeffect)
* [linkedIn](https://www.linkedin.com/in/bmotlagh/)
* [instagram](https://www.instagram.com/theboeffect/)## Key Stack Components
* TypeScript
* ESM
* Express
* Mongoose -> MongoDB
* Serverless-http
* openAPI/Swagger
* Express-OpenAPI-Validate
* @hapi/boom
* oData API query
* JSON Patch
* Passport (see libs in package.json)
* Jest## Features
* Authentication and Authorization via [UE Auth](https://ueauth.com)
* Configurable MongoDB connection
* oData support for queries
* JSON Patch implemented for updates with mongodb
* OpenAPI (swagger) and Swagger UI (/swagger)
* Automatic API Documentation Generated via ReDoc (/api)
* Automatic schema validation using the OpenAPI spec built in as middleware
* Automatic Type definitions using OpenAPI spec (yarn swag-spec SWAGGER-OBJEC TYPE-NAME)
* Error handling via @hapi/Boom
* Works with Docker or Lambda
* Jest test harnessHave other ideas? Feel free to PR!
### oData Spec
https://www.odata.org/documentation/
### JSON Patch
http://jsonpatch.com/
### DB
If you'd rather use a different database or ODM, the following modifications are necessary:
* change connection.ts to the appropriate DB
* validate that slsapp and start both correctly implement connection.ts
* in each of your api/resources, change the dal.ts file to access the new DB using the new ODM/ORM## Quickstart Run
* Click "Use this Template" at the top of the repository and setup your project
* clone your project to your machine
* start mongodb on port 27017
* I find the easiest way to do this is via docker in a terminal
* docker run -p 27017:27017 mongo
* Copy ./.env_ci to ./.env and modify env.dev.json to set runtime configuration data
* yarn test (will install dependencies and build first)
* yarn dev
* navigate to localhost:3000### Configure For Your Service
* Update the following in package.json
* name
* author
* person
* description
* homepage (your website or project website)
* logo (your logo or project logo url)
* Do the above quickstart now...
* Add src/api resources using the [logging example](./src/api/logging)