mongoose-crudl

1.1.2 • Public • Published

mongoose-crudl

CRUDL operations for Mongoose: Create, Read, Update, Delete, & List.

Installation

npm i --save mongoose-crudl

Usage

The following functions are exported in the index.js file:

import { list, createOne, readOne updateOne, patchOne, deleteOne, deleteMany } from 'mongoose-crudl'

These functions are asynchronous by nature, so they return a Javascript promise.

In the following examples, we are going to use async and await, and we assume you will do the same in your code. That is why, whenever the promise returned by the function resolves something, we will refer it to as the function returns that value. Whenever the promise returned by the function rejects something, we will refer it as the function throws an error.

Common parameters

The first two parameters of all of the functions in this lib are the same. The first one is the 'Model' and the second is called 'params'.

Model

All of these functions operate on a Mongoose model, and you have to pass the model as the first argument for all of these functions.

Params

The second parameter for all of the functions in this lib is an object called params. The properties on this objects are intended to be property names in your Mongoose model, and the values are most likely Mongoose ObjectId-s (or the string representation of them).

The properties of the params object are always merged into the filter object, and in case of createOne & updateOne, they are merged into the data object that is sent to the database.

In order to use this lib efficiently, you should add all of the related ids to your Mongoose model. For example, let's say that you have model A, model B, and model C. Model A and B are in a 1-N relationship, model B and C are also in a 1-N relationship. In this case, you will have to put a reference of A into C:

import mongoose from 'mongoose'

const aSchema = new mongoose.Schema({
  name: { type: String, required: true }
})
const aModel = mongoose.model('A', aSchema)

const bSchema = new mongoose.Schema({
  aId: { type: mongoose.Schema.ObjectId, ref: 'A', required: true },

  name: { type: String, required: true }
})
const bModel = mongoose.model('B', bSchema)

const cSchema = new mongoose.Schema({
  aId: { type: mongoose.Schema.ObjectId, ref: 'A', required: true },
  bId: { type: mongoose.Schema.ObjectId, ref: 'B', required: true },

  name: { type: String, required: true }
})
const cModel = mongoose.model('C', cSchema)

Wondering why we call this object params? It comes from express' naming convention. There, you reach the URL params on the req.params object, which you always should add to your filter if the name of the params are equal to the property names in your model. So, if I want to create a route in express for cModel in my example above, then the route will be the following: /v1/a/:aId/b/:bId/c, so req.params will contain aId and bId. (And you definitely want to add those fields to your filter.)

Functions

In the following section, you can read about the CRUDL functions exported by this lib.

list(Model, params, query)

A function for querying your collection.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.
query Object A query object, described below.
query.filter Object A Mongoose filter object, that can be applied to Model.find().
query.select Object A Mongoose select object. Be careful, use the object syntax, not the array / string syntax!
query.sort Object A Mongoose sort object. Be careful, use the object syntax, not the string syntax! The default sort object is { createdAt: -1 }.
query.skip Number The number of records to skip in the result. (See Mongoose skip.) If you pass a string value as query.skip, then it will be parsed as an integer.
query.limit Number The maximum number of items in the result. (See Mongoose limit.) If you pass a string value ask query.limit, then it will be parsed as an integer.

Returns:

{
  status: 200, // If everything goes well, we can set a HTTP 200 status code.
  result: {
    items: [], // The items resulted by the query object (filter, select, sort, skip, & limit)
    count: 0 // The number of items that satisfy query.filter
  }
}

Throws:

Example:

import { list } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await list(ExampleModel, params, query)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result.count) // the number of item satisfies query.filter
  console.log(response.result.items) // an array of objects based on your model
} catch (e) {
  console.error(e) // error thrown by the mongodb or the mongoose package, most likely a connection error
}

createOne(Model, params, body)

Creates an entry in your db.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.
body Object The data which will be inserted to the db.

Note: the params object will be merged into the body before inserting.

Returns:

{
  status: 201, // If everything goes well, we can set a HTTP 201 status code.
  result: { ... } // the new entry inserted into the db.
}

Throws:

Example:

import { createOne } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await createOne(ExampleModel, params, body)
  
  console.log(response.status) // the HTTP status code of the operation: 201
  console.log(response.result) // the newly created MongoDB entry
} catch (e) {
  console.log(e)
}

readOne(Model, params, query)

Reads an entry from your db.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.
query Object A query object that only has a select prop.
query.select Object A Mongoose select object. Be careful, use the object syntax, not the array / string syntax!

Side note: The params object should contain an id field, which will be mapped to the default _id field of MongoDB.

Returns:

{
  status: 200,
  result: { ... } // the entry you were looking for
}

Throws:

Example:

import { readOne } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await readOne(ExampleModel, params, query)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result) // the entry you were looking for
} catch (e) {
  console.log(e)
}

updateOne(Model, params, body)

Updates an entry in your db.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.
body Object The data which will be inserted to the db.

Side note: The params object should contain an id field, which will be mapped to the default _id field of MongoDB.

Side note: the params object will be merged into the body before updating.

Returns:

{
  status: 200,
  result: { ... } // the updated entry
}

Throws:

Example:

import { updateOne } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await updateOne(ExampleModel, params, body)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result) // the updated entry
} catch (e) {
  console.log(e)
}

patchOne(Model, params, body)

Patches an entry in your db.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.
body Object The data which will be inserted to the db.

Side note: The params object should contain an id field, which will be mapped to the default _id field of MongoDB.

Side note: the params object will be merged into the body before updating.

Returns:

{
  status: 200,
  result: { ... } // the updated entry
}

Throws:

Example:

import { patchOne } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await patchOne(ExampleModel, params, body)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result) // the updated entry
} catch (e) {
  console.log(e)
}

deleteOne(Model, params)

Removes an entry from your db.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.

Side note: The params object should contain an id field, which will be mapped to the default _id field of MongoDB.

Returns:

{
  status: 200,
  result: { ... } // the removed entry
}

Throws:

Example:

import { deleteOne } from 'mongoose-crudl'

import ExampleModel from './your/mongoose/model.js'

...

try {
  const response = await deleteOne(ExampleModel, params, query)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result) // the entry you removed
} catch (e) {
  console.log(e)
}

deleteMany(Model, params)

Often times, you will need to remove all of the related elements of an entry. This function is a utility function for exactly that.

Parameters:

Name Type Description
Model Mongoose model A Mongoose model.
params Object A params object.

Side note: In this case, the params object should not contain an id field.

Returns:

{
  status: 200,
  result: {} // a summary about how many elements are actually deleted.
}

Throws:

Example:

import { deleteOne, deleteMany } from 'mongoose-crudl'

import ExampleModel1 from './your/mongoose/model.js'
import ExampleModel2 from './your/mongoose/model.js'

// Let's assume, that ExampleModel2 has a field called 'ref', referring to an ExampleModel1 entry

...

try {
  const response = await deleteOne(ExampleModel1, params, query)
  
  console.log(response.status) // the HTTP status code of the operation: 200
  console.log(response.result) // the entry you removed

  deleteMany(ExampleModel2, { ref: response.result.ref }) // you probably don't want to await for the results, since the main entry is already removed.
} catch (e) {
  console.log(e)
}

Versions

Current Tags

  • Version
    Downloads (Last 7 Days)
    • Tag
  • 1.1.2
    4
    • latest

Version History

Package Sidebar

Install

npm i mongoose-crudl

Weekly Downloads

7

Version

1.1.2

License

MIT

Unpacked Size

45.7 kB

Total Files

21

Last publish

Collaborators

  • gyulanemeth