-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'feat/mongoose-audit' into development
- Loading branch information
Showing
13 changed files
with
1,351 additions
and
28 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
{ | ||
"name": "@sliit-foss/mongoose-audit", | ||
"version": "0.0.0", | ||
"description": "A rework of the mongoose-audit-log package to support newer versions of mongoose and more flexible options", | ||
"main": "dist/index.js", | ||
"types": "types/index.d.ts", | ||
"scripts": { | ||
"build": "node ../../scripts/esbuild.config.js", | ||
"build:watch": "bash ../../scripts/esbuild.watch.sh", | ||
"bump-version": "bash ../../scripts/bump-version.sh --name=@sliit-foss/express-http-context", | ||
"lint": "bash ../../scripts/lint.sh", | ||
"release": "bash ../../scripts/release.sh", | ||
"test": "if [ \"$CI\" = \"true\" ]; then \n bash ../../scripts/test/test.sh; else \n echo \"Skipping as it is not a CI environemnt\"; fi" | ||
}, | ||
"dependencies": { | ||
"deep-diff": "^1.0.2" | ||
}, | ||
"peerDependencies": { | ||
"mongoose": ">=5" | ||
}, | ||
"author": "SLIIT FOSS", | ||
"license": "MIT", | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/sliit-foss/npm-catalogue.git" | ||
}, | ||
"homepage": "https://github.com/sliit-foss/npm-catalogue/blob/main/plugins/mongoose-audit/readme.md", | ||
"keywords": [ | ||
"mongoose", | ||
"mongoose-plugin", | ||
"audit", | ||
"log", | ||
"trail", | ||
"history", | ||
"version" | ||
], | ||
"bugs": { | ||
"url": "https://github.com/sliit-foss/npm-catalogue/issues" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,66 @@ | ||
# @sliit-foss/mongoose-audit | ||
|
||
#### A rework of the [mongoose-audit-log](https://www.npmjs.com/package/mongoose-audit-log) package to support newer versions of mongoose and more flexible options<br> | ||
|
||
It is a mongoose plugin to manage an audit log of changes to a MongoDB database. | ||
|
||
## Features | ||
|
||
- Store changes to entities on persist (save, update, delete) | ||
- Remember the user, that executed the change | ||
- Log when the change has been done | ||
|
||
## Storing the current user | ||
|
||
In order to collect the information about who actually did a change to an entity, the user information is required. | ||
This can be set on a per usage (1) or global (2) level: | ||
|
||
1. Set the current user on an entity right before persisting: | ||
|
||
```javascript | ||
Order.findById(123) | ||
.then((order) => { | ||
order.__user = "[email protected]"; | ||
order.amount = 1000; | ||
}) | ||
.save(); | ||
``` | ||
|
||
2. Set it as an option when registering the plugin: | ||
|
||
```javascript | ||
const { plugin } = require("@sliit-foss/mongoose-audit"); | ||
|
||
SomeSchema.plugin(plugin, { | ||
getUser: () => "user details from wherever you wish to get it" | ||
}); | ||
``` | ||
|
||
## Query history | ||
|
||
Please find below an example express route, to request the history of a given type and id: | ||
|
||
```javascript | ||
const { plugin, Audit } = require("@sliit-foss/mongoose-audit"); | ||
|
||
router.get("/api/users/:id/history", (req, res, next) => { | ||
Audit.find({ entity_id: req.params.id, entity: "User" }) | ||
.then((history) => res.json(history)) | ||
.catch(next); | ||
}); | ||
``` | ||
|
||
## All supported plugin options | ||
|
||
```javascript | ||
const { plugin, AuditType } = require("@sliit-foss/mongoose-audit"); | ||
|
||
SomeSchema.plugin(plugin, { | ||
getUser: () => "user details from wherever you wish to get it", | ||
types: [AuditType.Edit], // default: ['add', 'edit', 'delete'] | ||
exclude: ["field1", "field2"], | ||
onAudit: (audit) => { | ||
// Called before persisting the audit is saved. Use this to use your own audit model instead of the default one. | ||
} | ||
}); | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
export const AuditType = { | ||
Add: "Add", | ||
Edit: "Edit", | ||
Delete: "Delete" | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,11 @@ | ||
import { default as plugin } from "./plugin"; | ||
import { default as Audit } from "./model"; | ||
import { AuditType } from "./constants"; | ||
|
||
export { plugin, Audit, AuditType as auditType }; | ||
|
||
export default { | ||
plugin, | ||
Audit, | ||
auditType: AuditType | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
const mongoose = require("mongoose"); | ||
|
||
const auditSchema = new mongoose.Schema( | ||
{ | ||
entity_id: {}, | ||
entity: String, | ||
collection: String, | ||
changes: {}, | ||
user: { | ||
type: mongoose.Schema.Types.Mixed, | ||
ref: "User", | ||
collection: "users" | ||
} | ||
}, | ||
{ | ||
timestamps: { | ||
createdAt: "created_at", | ||
updatedAt: false | ||
} | ||
} | ||
); | ||
|
||
const model = mongoose.model("Audit", auditSchema); | ||
|
||
export default model; |
Oops, something went wrong.