2014-06-03 14:05:25 +01:00
|
|
|
// # API Utils
|
|
|
|
// Shared helpers for working with the API
|
2014-08-17 06:17:23 +00:00
|
|
|
var Promise = require('bluebird'),
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
_ = require('lodash'),
|
2014-12-10 13:28:16 +00:00
|
|
|
path = require('path'),
|
2014-06-20 11:15:01 +02:00
|
|
|
errors = require('../errors'),
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
utils;
|
|
|
|
|
|
|
|
utils = {
|
2015-06-22 21:11:35 +01:00
|
|
|
validate: function validate(docName, attrs) {
|
|
|
|
return function doValidate() {
|
|
|
|
var object, options;
|
|
|
|
if (arguments.length === 2) {
|
|
|
|
object = arguments[0];
|
|
|
|
options = _.clone(arguments[1]) || {};
|
|
|
|
} else if (arguments.length === 1) {
|
|
|
|
options = _.clone(arguments[0]) || {};
|
|
|
|
} else {
|
|
|
|
options = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
if (attrs) {
|
|
|
|
options.data = _.pick(options, attrs);
|
|
|
|
options = _.omit(options, attrs);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (object) {
|
|
|
|
return utils.checkObject(object, docName, options.id).then(function (data) {
|
|
|
|
options.data = data;
|
|
|
|
return Promise.resolve(options);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return Promise.resolve(options);
|
|
|
|
};
|
|
|
|
},
|
|
|
|
|
|
|
|
prepareInclude: function prepareInclude(include, allowedIncludes) {
|
|
|
|
include = include || '';
|
|
|
|
include = _.intersection(include.split(','), allowedIncludes);
|
|
|
|
|
|
|
|
return include;
|
|
|
|
},
|
|
|
|
/**
|
|
|
|
* @param {Array} allowedIncludes
|
|
|
|
* @returns {Function} doConversion
|
|
|
|
*/
|
|
|
|
convertOptions: function convertOptions(allowedIncludes) {
|
|
|
|
/**
|
|
|
|
* Convert our options from API-style to Model-style
|
|
|
|
* @param {Object} options
|
|
|
|
* @returns {Object} options
|
|
|
|
*/
|
|
|
|
return function doConversion(options) {
|
|
|
|
if (options.include) {
|
|
|
|
options.include = utils.prepareInclude(options.include, allowedIncludes);
|
|
|
|
}
|
|
|
|
return options;
|
|
|
|
};
|
|
|
|
},
|
2014-06-03 14:05:25 +01:00
|
|
|
/**
|
|
|
|
* ### Check Object
|
|
|
|
* Check an object passed to the API is in the correct format
|
|
|
|
*
|
|
|
|
* @param {Object} object
|
|
|
|
* @param {String} docName
|
|
|
|
* @returns {Promise(Object)} resolves to the original object if it checks out
|
|
|
|
*/
|
2015-02-26 18:29:53 +00:00
|
|
|
checkObject: function (object, docName, editId) {
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
if (_.isEmpty(object) || _.isEmpty(object[docName]) || _.isEmpty(object[docName][0])) {
|
2014-07-24 23:07:29 +01:00
|
|
|
return errors.logAndRejectError(new errors.BadRequestError('No root key (\'' + docName + '\') provided.'));
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
}
|
2014-07-18 10:48:48 +02:00
|
|
|
|
|
|
|
// convert author property to author_id to match the name in the database
|
|
|
|
if (docName === 'posts') {
|
|
|
|
if (object.posts[0].hasOwnProperty('author')) {
|
|
|
|
object.posts[0].author_id = object.posts[0].author;
|
|
|
|
delete object.posts[0].author;
|
|
|
|
}
|
|
|
|
}
|
2015-02-26 18:29:53 +00:00
|
|
|
|
|
|
|
if (editId && object[docName][0].id && parseInt(editId, 10) !== parseInt(object[docName][0].id, 10)) {
|
|
|
|
return errors.logAndRejectError(new errors.BadRequestError('Invalid id provided.'));
|
|
|
|
}
|
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
return Promise.resolve(object);
|
2014-12-10 13:28:16 +00:00
|
|
|
},
|
2015-01-16 18:03:16 +00:00
|
|
|
checkFileExists: function (options, filename) {
|
2015-06-22 21:11:35 +01:00
|
|
|
return !!(options[filename] && options[filename].type && options[filename].path);
|
2014-12-10 13:28:16 +00:00
|
|
|
},
|
|
|
|
checkFileIsValid: function (file, types, extensions) {
|
|
|
|
var type = file.type,
|
|
|
|
ext = path.extname(file.name).toLowerCase();
|
|
|
|
|
|
|
|
if (_.contains(types, type) && _.contains(extensions, ext)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
Refactor API arguments
closes #2610, refs #2697
- cleanup API index.js, and add docs
- all API methods take consistent arguments: object & options
- browse, read, destroy take options, edit and add take object and options
- the context is passed as part of options, meaning no more .call
everywhere
- destroy expects an object, rather than an id all the way down to the model layer
- route params such as :id, :slug, and :key are passed as an option & used
to perform reads, updates and deletes where possible - settings / themes
may need work here still
- HTTP posts api can find a post by slug
- Add API utils for checkData
2014-05-08 13:41:19 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-08-17 06:17:23 +00:00
|
|
|
module.exports = utils;
|