Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cme-pro/mongoose-audit
Mongoose plugin to store audit information like userAgent, ip, country, etc...
https://github.com/cme-pro/mongoose-audit
mongoose mongoose-plugin nodejs
Last synced: about 1 month ago
JSON representation
Mongoose plugin to store audit information like userAgent, ip, country, etc...
- Host: GitHub
- URL: https://github.com/cme-pro/mongoose-audit
- Owner: cme-pro
- License: mit
- Created: 2019-06-19T03:26:30.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2023-07-18T21:58:04.000Z (over 1 year ago)
- Last Synced: 2024-11-13T12:12:41.209Z (2 months ago)
- Topics: mongoose, mongoose-plugin, nodejs
- Language: TypeScript
- Size: 96.7 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
[![npm][npm]][npm-url]
[![node][node]][node-url]
[![downloads][downloads]][downloads-url]# mongoose-audit
Mongoose plugin to store audit information like userAgent, ip, country, etc...
This plugin simply adds the following fields:
- createdBy
- updatedBy
- deletedBy
- createdFrom
- updatedFrom
- deletedFromWhere:
1. createdBy, updatedBy and deletedBy are a user id,
2. createdFrom, updatedFrom and deletedFrom have the following structure:
- userAgent
- ip
- country
- continent
- region
- city
- zip
- lat
- lng
- tzNote: deletedBy and deletedFrom are only useful if combined with [mongoose-delete plugin](https://www.npmjs.com/package/mongoose-delete).
## Installation
```sh
$ npm install mongoose-audit --save
```## Overview
### Adding plugin to the schema
```js
BlogPost.plugin(mongooseAudit, { userModel: 'Author' });
```### Plugin options
* userModel - optional (default is "User"). The mongoose Model managing users. Used to populate the field).
## Usage
On create:
```js
const post = new BlogPost({});
post.createdBy = currentUserId;
post.createdFrom = {{ ip, userAgent, country };
await post.save();
```On update:
```js
post.set();
post.updatedBy = currentUserId;
post.updatedFrom = {{ ip, userAgent, country };
await post.save();
```On delete (only useful if combined with [mongoose-delete plugin](https://www.npmjs.com/package/mongoose-delete))
```js
post.deletedBy = currentUserId;
post.deletedFrom = {{ ip, userAgent, country };
await post.save();
await post.delete();
```[npm]: https://img.shields.io/npm/v/@cme-pro/mongoose-audit.svg
[npm-url]: https://npmjs.com/package/@cme-pro/mongoose-audit
[node]: https://img.shields.io/node/v/@cme-pro/mongoose-audit.svg
[node-url]: https://nodejs.org
[tests]: http://img.shields.io/travis/webpack-contrib/@cme-pro/mongoose-audit.svg
[tests-url]: https://travis-ci.org/webpack-contrib/@cme-pro/mongoose-audit
[downloads]: https://img.shields.io/npm/dt/@cme-pro/mongoose-audit.svg
[downloads-url]: https://npmjs.com/package/@cme-pro/mongoose-audit