A One Paragraph Overview

April 7, 2024 ยท View on GitHub

Best practices starter


Generate a Node.js app that is packed with best practices AND simplicity in mind. Based off our repo Node.js best practices (96,100 stars)


Twitter Twitter | Site Documentation site


A One Paragraph Overview

Although Node.js has great frameworks ๐Ÿ’š, they were never meant to be dev & production ready immediately (e.g., no architecture layers, DB schemas, docker file, etc etc). Practica.js aims to bridge the gap. Based on your preferred framework, we generate example code that demonstrates a full Microservice flow, from API to DB, that is packed with good practices. For example, we include a battle-tested error handler, sanitized API response, hardened dockerfile, thoughtful 3-tier folder structure, great testing templates with DB, and more. This saves a great deal of time and can prevent painful mistakes. All decisions made are neatly and thoughtfully documented. We strive to keep things as simple and standard as possible and base our work on the popular guide: Node.js Best Practices

1 min video ๐Ÿ‘‡, ensure audio is activated

https://user-images.githubusercontent.com/8571500/170464232-43355e43-98cf-4069-b9fc-6bc303a39efc.mp4


Table of Contents


Super-Quick Setup


Run Practica.js from the Command Line

Run practica CLI and generate our default app (you can customize it using different flags):

npx @practica/create-node-app immediate --install-dependencies

โœจ And you're done! That's it, the code's all been generated. Our default setup includes Fastify for the web layer, Sequelize for the data access and PostgreSQL

Prefer express and Prisma? Just pass the right flags to the CLI:

npx @practica/create-node-app immediate --install-dependencies --web-framework=express --orm=prisma

Prefer other DB? We use standard ORMs, read its docs and switch DB. This is your code, do whatever you like


Start the Project

cd {your chosen folder name}
npm install

Then choose whether to start the app:

npm run

or run the tests:

npm test

Pretty straightforward, right?

You just got a Node.js Monorepo solution with one example component/Microservice and multiple libraries. Based on this hardened solution you can build a robust application. The example component/Microservice is located under: {your chosen folder name}/services/order-service. This is where you'll find the API and a good spot to start your journey from


Next Steps

  • โœ… Start coding. The code we generate is minimal by design and based on known libraries. This should help you get up to speed quickly.
  • โœ… Read our 'coding with practica' guide
  • โœ… Master it by reading our docs at https://practica.dev.

Our Philosophies and Unique Values

1. Best Practices on top of known Node.js frameworks

We don't re-invent the wheel. Rather, we use your favorite framework and empower it with structure and real examples. With a single command you can get an Express/Fastify-based codebase with many thoughtful best practices inside

Built on top of known frameworks

2. Simplicity, how Node.js was intended

Keeping it simple, flat, and based on native Node/JS capabilities is part of this project's DNA. We believe that too many abstractions, high-complexity or fancy language features can quickly become a stumbling block for the team

To name a few examples, our code flow is flat with almost no level of indirection, no DI - it's just simple functions calling other functions. Although using TypeScript, almost no features are being used besides types, for modularization we simply use... Node.js modules

Simplicity!

3. Supports many technologies and frameworks

Good Practices and Simplicity is the name of the game with Practica. There is no need to narrow our code to a specific framework or database. We aim to support the popular Node.js frameworks and data access approaches

Built on top of known frameworks


Practices and Features

We apply dozens of practices and optimizations. You can opt in or out for most of these features using option flags on our CLI. The following table lists just a few examples out of the full list of features we provide.

FeatureExplanationFlagDocs
Monorepo setupGenerates two components (e.g., Microservices) in a single repository with interactions between the two--mr, --monorepoDocs here
Output escaping and sanitizingClean-out outgoing responses from potential HTML security risks like XSS--oe, --output-escapeDocs here
Integration (component) testingGenerates full-blown component/integration tests setup including DB--t, --testsDocs here
Unique request ID (Correlation ID)Generates module that creates a unique correlation/request ID for every incoming request. This is available for any other object during the request life-span. Internally it uses Node's built-in AsyncLocalStorage--coi, --correlation-idDocs here
DockerfileGenerates dockerfile that embodies >20 best practices--df, --docker-fileDocs here
Strong-schema configurationA configuration module that dynamically load run-time configuration keys and includes a strong schema so it can fail fastBuilt-in with basic appDocs here

๐Ÿ“— See our full list of features here


The People Behind Practica.js

Steering Committee

Practica is a community-driven open-source project. It's being led voluntarily by engineers from many different companies. These companies are just a few who encourage their engineers to contribute and keep this project moving. ๐Ÿ’š

Autodesk

A Nasdaq 100 company, a world leader in design software

Cox2m

Leader IoT provider, part of 'Cox Communication', the 3rd largest cable company in the US

Core Team


Yoni Goldberg


Independent Node.js consultant

Michael Solomon


Node.js lead

Raz Luvaton


Node.js developer

Daniel Gluskin


Node.js lead

Ariel Steiner


Node.js developer

Tomer Kohane


Frontend geek

Dan Goldberg


Node.js lead

Ron Dahan


Node.js expert

Partners

These companies are keen for continuous improvement and their engineers to have been known to contribute during work hours.

Minta

Our Amazing Contributors ๐Ÿ’š

A million thanks to these great people who have contributed code to our project:

Brian Clark
Brian Clark

๐Ÿ’ป
Raz Luvaton
Raz Luvaton

๐Ÿ–‹ ๐Ÿ’ป
Michael Solomon
Michael Solomon

๐Ÿ’ป
itainoam
itainoam

๐Ÿ’ป ๐Ÿ“†
shanizlo
shanizlo

๐Ÿ’ป
Ron Dahan
Ron Dahan

๐Ÿ’ป
AlonK
AlonK

๐Ÿ’ป
Jose Luis Alvarez Herrera
Jose Luis Alvarez Herrera

๐Ÿ–‹ ๐Ÿ’ป
reinaldo-calderon-team
reinaldo-calderon-team

๐Ÿ’ป
KarelVerschraegen
KarelVerschraegen

๐Ÿ“–
Daniel Morrison
Daniel Morrison

๐Ÿ–‹
Sean Lowe
Sean Lowe

๐Ÿ’ก ๐Ÿ–‹
idobetesh
idobetesh

๐Ÿ’ป
Alejandra Acosta
Alejandra Acosta

๐Ÿ’ป
adandanielteamint
adandanielteamint

๐Ÿ–‹
Rashad Majali
Rashad Majali

๐Ÿ’ป
yohai zvuloon
yohai zvuloon

๐Ÿ–‹
Yonatan Kra
Yonatan Kra

๐Ÿ–‹
Yoni Rapoport
Yoni Rapoport

๐Ÿ–‹
perilevy
perilevy

๐Ÿ’ป
ToMer-K
ToMer-K

๐Ÿ’ป
hen arbel
hen arbel

๐Ÿ’ป
Mojca Ostir
Mojca Ostir

๐Ÿ’ป
evbambly
evbambly

๐Ÿ–‹
Amir Adar
Amir Adar

๐Ÿ–‹
Sebastien Vaucouleur
Sebastien Vaucouleur

๐Ÿ–‹
Harry Dobrev
Harry Dobrev

๐Ÿ’ป
Bassam Ismail
Bassam Ismail

๐Ÿ“–
Marcos Molina
Marcos Molina

๐Ÿ’ป
Isen Kasa
Isen Kasa

๐Ÿ’ป
Vishal Sharma
Vishal Sharma

๐Ÿ’ป