This module is designed for the Strongloop Loopback framework. It adds createdAt
and updatedAt
attributes to any Model.
createdAt
will be set to the current Date the by using the default property of the attribute.
updatedAt
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 loopback-ds-timestamp-mixin --save
With version 2.33.2 of this module the upsert validation was turned off. This may create issues for your project if upsert validation is required. If you need upsert validation, you can turn off the requirement for the updatedAt
and createdAt
fields which will allow upsert validation to continue.
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-timestamp-mixin",
"../common/mixins"
]
}
}
To use with your Models add the mixins
attribute to the definition object of your model config.
{
"name": "Widget",
"properties": {
"name": {
"type": "string",
}
},
"mixins": {
"TimeStamp" : true
}
}
The attribute names createdAt
and updatedAt
are configurable. To use different values for the default attribute names add the following parameters to the mixin options.
You can also configure whether createdAt
and updatedAt
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 createdAt
and updatedAt
to createdOn
and updatedOn
, respectively. We also change the default required
to false
.
{
"name": "Widget",
"properties": {
"name": {
"type": "string",
}
},
"mixins": {
"TimeStamp" : {
"createdAt" : "createdOn",
"updatedAt" : "updatedOn",
"required" : false,
"disableAllValidateUpsert" : true
}
}
}
By passing in additional options to an update or save operation you can control when this mixin updates the updatedAt
field. The passing true to the option skipUpdatedAt
will skip updating the updatedAt
field.
In this example we assume a book object with the id of 2 already exists. Normally running this operation would change the updatedAt
field to a new value.
Book.updateOrCreate({name: 'New name', id: 2}, {skipUpdatedAt: true}, function(err, book) {
// book.updatedAt will not have changed
});
This package is written in ES6 JavaScript, check out @getify/You-Dont-Know-JS if you want to learn more about ES6.
Source files are located in the es6
directory. Edit the source files to make changes while running gulp
in the background. Gulp is using babel to transform the es6 JavaScript into node compatible JavaScript.
gulp
This package uses jscs
and jshint
as pretests to help maintain style and for error checking. All test are run against the transformed versions of files, not the es6 versions.
Run the tests in the test
directory.
npm test
Run with debugging output on:
DEBUG='loopback:mixins:time-stamp' npm test