npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

loopback-ds-ips-mixin

v1.0.1

Published

A mixin to automatically generate createdByIp and updatedByIp attributes for loopback Models

Downloads

4

Readme

NPM license engine npm Build Status Coverage Status

This module is based on loopback-ds-timestamp-mixin by Bryan Clark. Thanks for heading us in the right direction!

IPS

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.

INSTALL

  npm install --save loopback-ds-ips-mixin

MIXINSOURCES

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"
    ]
  }
}

SERVER.JS

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();
});

CONFIG

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
    }
  }

BOOT OPTIONS

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": {
      "TimeStamp" : {
        "createdByIp" : "createdIp",
        "updatedByIp" : "lastUpdatedIp",
        "required" : false
      }
    }
  }

OPERATION OPTIONS

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
});

TESTING

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

VERSIONS

LICENSE

Apache-2.0