admiraljs
Version:
Lightweight plug and play admin interface
92 lines (72 loc) • 2.89 kB
Markdown
To Use with Sails
use recordID:"id" in config.json
create blueprinthooks
overriding find.js in blueprints/find.js
for adding count and paging infos in response header.
/**
* Module dependencies
*/
var util = require('util'),
actionUtil = require('./actionUtil'),
_ = require('lodash');
/**
* Find Records
*
* get /:modelIdentity
* * /:modelIdentity/find
*
* An API call to find and return model instances from the data adapter
* using the specified criteria. If an id was specified, just the instance
* with that unique id will be returned.
*
* Optional:
* @param {Object} where - the find criteria (passed directly to the ORM)
* @param {Integer} limit - the maximum number of records to send back (useful for pagination)
* @param {Integer} skip - the number of records to skip (useful for pagination)
* @param {String} sort - the order of returned records, e.g. `name ASC` or `age DESC`
* @param {String} callback - default jsonp callback param (i.e. the name of the js function returned)
*/
module.exports = function findRecords (req, res) {
// Look up the model
var Model = actionUtil.parseModel(req);
// If an `id` param was specified, use the findOne blueprint action
// to grab the particular instance with its primary key === the value
// of the `id` param. (mainly here for compatibility for 0.9, where
// there was no separate `findOne` action)
if ( actionUtil.parsePk(req) ) {
return require('./findOne')(req,res);
}
// Lookup for records that match the specified criteria
var query = Model.find()
.where( actionUtil.parseCriteria(req) )
.limit( actionUtil.parseLimit(req) )
.skip( actionUtil.parseSkip(req) )
.sort( actionUtil.parseSort(req) );
// TODO: .populateEach(req.options);
query = actionUtil.populateEach(query, req);
query.exec(function found(err, matchingRecords) {
if (err) return res.serverError(err);
// Only `.watch()` for new instances of the model if
// `autoWatch` is enabled.
if (req._sails.hooks.pubsub && req.isSocket) {
Model.subscribe(req, matchingRecords);
if (req.options.autoWatch) { Model.watch(req); }
// Also subscribe to instances of all associated models
_.each(matchingRecords, function (record) {
actionUtil.subscribeDeep(req, record);
});
}
actionUtil.parseModel(req).count(actionUtil.parseCriteria(req))
.exec(function(err, total){
var limit=actionUtil.parseLimit(req);
var skip=actionUtil.parseSkip(req);
var start = actionUtil.parseSkip(req)*actionUtil.parseLimit(req);
var end = start + actionUtil.parseLimit(req);
res.set('Content-Range','items ' + start + '-' + end + '/' + total);
res.set('total',total);
res.set('page',Math.round(skip/limit)+1);
res.set('perPage',limit);
res.ok(matchingRecords);
});
});
};