Skip to content

Starter kit for building RESTful APIs using Fastify and Prisma in a TypeScript environment for Node.js.

License

Notifications You must be signed in to change notification settings

thekeogh/fastify-prisma-typescript-boilerplate

Repository files navigation

Fastify Prisma TypeScript Boilerplate

Fastify Prisma TypeScript Boilerplate is a starter kit for building RESTful APIs using Fastify and Prisma in a TypeScript environment for Node.js.

Included

Setup

Clone the repository:

git clone [email protected]:thekeogh/fastify-prisma-typescript-boilerplate.git

Install the dependencies:

npm install

Migrate the database:

npm run migrate

Please make sure that you have created the appropriate roles and database based on the DATABASE_URL specified in your .env.local file before running this command. See the Enviromental Variables section for more.

Generate artifacts

This command will generate all necessary artifacts, including TypeScript definitions, JSON Schemas and helpers for the service. See the Artifacts section for more.

npm run generate

Setup SSL

To enable SSL for the API in local development, you can use a self-signed certificate. To accomplish this, you will need to generate a self-signed SSL certificate locally by following our guide, which is available for both Microsoft Windows and Apple macOS. Once this process is complete, the server.key and server.crt files will be generated. Copy these SSL files to the /ssl directory using the following steps:

cp /path/to/server.key /path/to/server.crt ./ssl

To avoid utilising SSL locally, just leave the SSL_CERT and SSL_KEY fields blank in your .env.development.local configuration file. See the Enviromental Variables section for more.

Start the service:

npm run dev

Environmental Variables

If the default configuration in the .env.development file is not sufficient, you can create a .env.development.local file to customise the values according to your requirements.

touch .env.development.local

To modify specific values, selectively copy them from the .env.development file and paste them here. Only copy the values that you intend to change, and avoid copying any values that do not need to be modified. If no changes are required, completely skip this step.

Migration

Please take note that dotenv-flow is used to establish environment variables for all of the subsequent commands. Therefore, it's imperative to only execute these commands in a development environment. In production, the commands must be manually run and not via the package.json. You are welcome to change this of course.

To migrate any modifications made to the schema.prisma file and apply them to the database, use the following command:

npm run migrate:create

# ✔ Enter a name for the new migration: [name migration]

By executing this command, a .sql script will be created and applied to the database without any manual intervention. Upon committing the generated .sql to version control, it can be readily deployed in production.

To initiate a complete database reset and apply all migrations (note that this will result in the loss of all data), run the following command:

npm run migrate:reset

Please be cautious! Executing this command will delete all the data stored in the database. Use this command only when necessary.

If you wish to execute any pending migrations that have not yet been applied in your current environment, use the following command:

npm run migrate

This command is considered safe to execute since it will only apply changes to the database that have not already been made. If there are no pending migrations, this command will not have any effect.

For more information on Prisma, please read their documentation.

Artifacts

In an effort to eliminate the need for repetitive code, the service can generate much of it for you by analyzing your JSON Schemas. This includes inferring TypeScript types from all of your JSON Schemas and creating the final schema definition for your Fastify routes. To generate these automatically, simply execute the following command:

npm run generate

The above command will generate all the service artifacts aswell as the Prisma artifacts. To generate only the service artifacts you can run:

npm run generate:schema

You will find comments in all files that are generated by the command mentioned above, except for the schemas/schema.json file. This file is also generated by the command, but without any comments.

Conversely, to generate only the Prisma artifacts, run:

npm run generate:prisma

API Documentation

The API fully leverages the fact that it is compliant with OAS3 standards by using the Swagger UI to generate all documentation. You can view the Swagger UI for the API at the following endpoint:

/explorer

In JSON

/explorer/json

In YAML

/explorer/yaml

Build

Since the service is built in TypeScript, it must be compiled to plain JavaScript before it can be deployed in a production environment. To achieve this, you can run the following command

npm run build

The resulting JavaScript code should now be compiled and stored in the /build directory, which is now ready for deployment in a production environment.

To execute the compiled JavaScript, simply enter the following command:

npm start

Deploy

It's worth highlighting that the majority of npm scripts are intended for use in the development environment and necessitate dotenv-flow. In contrast, production, specifically the Docker container, will manually execute all commands exclusive of the package.json.

As an example, the Docker script will boot the server like:

CMD [ "node", "build/index.js" ]

Opposed to:

CMD [ "npm", "start" ]

Healthcheck

The API exposes the /healthcheck endpoint, which enables a health check of the service and its dependencies (such as the database), for instance, by ELB.

{
  "status": "ok"
}

Lint

To execute ESLint on the service, enter the following command:

npm run lint

To fix any linting errors automatically, run the following command:

npm run lint:fix

Tests

Vitest is utilized to execute all tests.

Run the entire test suite:

npm run test

Run specific tests:

npm run test /path/fuzzy/glob/file

Watch for changes:

npm run test:watch

About

Starter kit for building RESTful APIs using Fastify and Prisma in a TypeScript environment for Node.js.

Topics

Resources

License

Stars

Watchers

Forks