This module is based on loopback-ds-timestamp-mixin by Bryan Clark. Thanks for heading us in the right direction!
This module is designed for the Strongloop Loopback framework. It adds createdByIp
and updatedByIp
attributes to any Model.
createdByIp
will be set the user's (client's) real IP-Address using ipware.
updatedByIp
will be set for every update of an object through bulk updateAll
or instance model.save
methods.
This module is implemented with the before save
Operation Hook which is relatively new to the loopback framework so your loopback-datasource-juggler module must greater than version 2.23.0.
npm install --save loopback-ds-ips-mixin
With [email protected] mixinSources have been implemented in a way which allows for loading this mixin without changes to the server.js
file previously required.
Add the mixins
property to your server/model-config.json
like the following:
{
"_meta": {
"sources": [
"loopback/common/models",
"loopback/server/models",
"../common/models",
"./models"
],
"mixins": [
"loopback/common/mixins",
"../node_modules/loopback-ds-ips-mixin",
"../common/mixins"
]
}
}
DEPRECATED: See MIXINSOURCES above for configuration. Use this method ONLY if you cannot upgrade to [email protected].
In your server/server.js
file add the following line before the boot(app, __dirname);
line.
...
var app = module.exports = loopback();
...
// Add IPs Mixin to loopback
require('loopback-ds-ips-mixin')(app);
boot(app, __dirname, function(err) {
'use strict';
if (err) throw err;
// start the server if `$ node server.js`
if (require.main === module)
app.start();
});
To use with your Models add the mixins
attribute to the definition object of your model config.
{
"name": "Widget",
"properties": {
"name": {
"type": "string",
}
},
"mixins": {
"IPs" : true
}
}
The attribute names createdByIp
and updatedByIp
are configurable. To use different values for the default attribute names add the following parameters to the mixin options.
You can also configure whether createdByIp
and updatedByIp
are required or not. This can be useful when applying this mixin to existing data where the required
constraint would fail by default.
In this example we change createdByIp
and updatedByIp
to createdIp
and lastUpdatedIp
, respectively. We also change the default required
to false
.
{
"name": "Widget",
"properties": {
"name": {
"type": "string",
}
},
"mixins": {
"IPs" : {
"createdByIp" : "createdIp",
"updatedByIp" : "lastUpdatedIp",
"required" : false
}
}
}
By passing in additional options to an update or save operation you can control when this mixin updates the updatedByIp
field. The passing true to the option skipUpdatedByIp
will skip updating the updatedByIp
field.
In this example we assume a book object with the id of 2 already exists. Normally running this operation would change the updatedByIp
field to a new value.
Book.updateOrCreate({name: 'New name', id: 2}, {skipUpdatedByIp: true}, function(err, book) {
// book.updatedAt will not have changed
});
You'll need jscs
and jshint
globally installed to run the tests which can be installed with this command: npm install -g jshint jscs
. These tools help maintain style and error checking.
Run the tests in test.js
npm test
Run with debugging output on:
DEBUG='loopback-ds-ips-mixin' npm test