Skip to content

MarkKhramko/nodester

Repository files navigation

nodester logo

nodester NPM version License

nodester is a Node.js framework designed to solve the problem of a complex data querying over HTTP.

The main reason of nodester's existence is the nodester Query Language (NQL) →, an extension of standard REST API syntax, it lets you craft complex queries with hierarchical associations.

Building an application which allows users to build their own REST queries raises huge security concerns. That's why nodester was not developed as a middleware. It's a framework equipped with a set of technologies enabling you to fully customize the request-response flow down to the specific user and a database column.

Quick Example

With NQL, a single endpoint can handle complex queries:

GET /api/v1/countries?includes=cities(limit=5&order_by=population&order=desc).areas&name=like(Bel)&fn=count(cities)

This query:

  • Filters countries by name containing "Bel"
  • Includes cities (limited to 5, ordered by population)
  • Includes areas for each city
  • Counts total cities per country

All with proper security through Filters → that control what users can query.

Check out core concepts documentation → for more info.

Installation

Install with NPM

npm install -S nodester

Or kickstart your project with the boilerplate

npx degit https://github.com/MarkKhramko/nodester/examples/boilerplate my-app

cd my-app

npm i

npm run bootstrap

Features

  • 🔍 Powerful Query Language (NQL): Extend REST with SQL-like querying capabilities
  • 🔒 Security First: Fine-grained control over what users can query through Filters
  • 🌳 Hierarchical Associations: Query nested relationships with ease
  • ⚡ Built on Sequelize: Leverage the power of Sequelize ORM
  • 🎯 Flexible Architecture: Controller → Facade → Model pattern for clean separation
  • 🛡️ Request Validation: Automatic validation and bounds checking
  • 📊 Aggregate Functions: Built-in support for count, avg, and more
  • 🔧 Extensible: Easy to extend and customize for your needs

Table of Contents

Usage

const nodester = require('nodester');
const db = require('#db');

const app = new nodester();
app.set.database(db);

// Do any synchronous initializations
// before app.listen here
// ...

// Optional beforeStart hook:
app.beforeStart(async () => {
  // Do any asynchronous initializations
  // before app.listen here
  // ...
});

// Start the http server:
app.listen(8080, function() {
  console.log('listening on port', app.port);
});

// Gracefully shut down:
process.once('SIGTERM', () => {
  app.stop(() => {
    const pid = process.pid;
    console.info('Process', pid, 'terminated\n');
    process.exit(0);
  });
});

Documentation

Core concepts

Core concepts documentation →

Queries & querying - nodester Query Language (NQL)

The true strength of nodester lies in its query language. Serving as an extension of standard REST API syntax, it brings many aspects of SQL into REST requests, providing developers with a simple yet powerful tool for expressive and efficient data querying.

NQL Documentation:

Database

Nodester is built upon a powerful Sequelize.
Supported drivers:

  • MySQL
  • PostgreSQL

How to setup a database →

Application

Application documentation →

Comments

We (contributors) use JSDoc to describe the actual code.

Philosophy

The Philosophy of nodester is to provide a developer with a tool that can build an app (or feature) in hours and scale it with ease for years.

Goal

The goal of nodester is to be a robust and flexible framework that makes development in iterations easy, while laying the foundation for seamless scalability in the future.

License

MIT

Copyright

Copyright 2021-present Mark Khramko

About

Versatile Node.js framework for a modern REST API.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published