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 {
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