1.0.4 • Published 2 days ago

@warlock.js/cascade v1.0.4

Weekly downloads
-
License
MIT
Repository
github
Last release
2 days ago

cascade

A powerful and easy to use MongoDB driver for Nodejs

Features

cascade is a MongoDB driver for Nodejs, it's built on top of the official MongoDB driver, and it provides a simple and easy to use API for working with MongoDB, it is fast, efficient, reliable and will make your life easier with real world apps.

Some but not all of the features:

  • Easy to use: Cascade is very easy to use, it's just a wrapper around MongoDB driver.
  • Supports multiple connections: You can perform multiple connections to different MongoDB connections and use each one of them separately.
  • Supports multiple databases: Cascade supports multiple databases, you can connect to multiple databases at the same time.
  • Powerful Aggregate framework: Cascade has a powerful aggregate framework that helps you to perform complex queries.
  • Basic CRUD operations: Cascade supports basic CRUD operations, you can perform create, read, update and delete operations.
  • Events Driven: Cascade is events driven, you can listen to events and perform actions, for example before creating, updating or deleting a document.
  • Powerful Models: Cascade has a powerful models system, a Model is a collection manager document based, it manages a collection's document easily with many utilities.
  • Learning curve: Cascade has a very small learning curve, you can learn it in few minutes.
  • Pagination support: Cascade supports pagination, you can paginate your results easily.
  • Output formatting: Cascade supports output formatting, you can format your output easily when model is sent as a response.
  • Auto incremented id: Cascade supports auto incremented id, you can use it as a primary key for your documents.
  • Random or sequential id: Cascade supports random or sequential id.
  • Recycle Bin: Reduce collection documents by removing the document entirely from the collection, but move it to a separate collection trash.
  • Migration system: Cascade has a migration system, you can create migrations and run them easily.
  • Data casting: You can cast your data to a specific type or using custom casting.
  • Embedded documents: Cascade supports single and multiple embedded documents, you can embed documents inside other documents.
  • Syncing Models: Auto update documents when model's data is updated or deleted.

Installation

npm i @warlock.js/cascade

Using yarn:

yarn add @warlock.js/cascade

Using pnpm:

pnpm add @warlock.js/cascade

Peek inside cascade

Here is a simple example of defining a User model:

import { Model } from "@warlock.js/cascade";

export class User extends Model {
  /**
   * The collection name
   * Must be defined explicitly.
   */
  public static collection = "users";
}

A quick example of creating a user:

import { User } from "src/models/user";

export async function createUser() {
  const user = await User.create({
    name: "Hasan Zohdy",
    email: "hassanzohdy@gmail.com",
  });

  console.log(user.data);
}

Outputs something similar to:

{
  "id": 1231412,
  "_id": "fagtrw43qwedasjoijwq",
  "name": "Hasan Zohdy",
  "email": "hassanzohdy@gmail.com",
  "createdAt": "2023-06-01 00:00:00",
  "updatedAt": "2023-06-01 00:00:00"
}

Documentation

To see the full documentation, please visit Cascade Documentation