2013-12-06 09:51:35 +01:00
|
|
|
var when = require('when'),
|
2014-02-05 00:40:30 -08:00
|
|
|
_ = require('lodash'),
|
2013-12-06 09:51:35 +01:00
|
|
|
dataProvider = require('../models'),
|
2014-02-26 18:51:01 +01:00
|
|
|
canThis = require('../permissions').canThis,
|
2013-12-06 09:51:35 +01:00
|
|
|
filteredUserAttributes = require('./users').filteredAttributes,
|
|
|
|
posts;
|
|
|
|
|
2014-04-16 12:09:03 +02:00
|
|
|
function checkPostData(postData) {
|
|
|
|
if (_.isEmpty(postData) || _.isEmpty(postData.posts) || _.isEmpty(postData.posts[0])) {
|
|
|
|
return when.reject({code: 400, message: 'No root key (\'posts\') provided.'});
|
|
|
|
}
|
|
|
|
return when.resolve(postData);
|
|
|
|
}
|
|
|
|
|
2013-12-06 09:51:35 +01:00
|
|
|
// ## Posts
|
|
|
|
posts = {
|
|
|
|
|
2014-04-16 12:09:03 +02:00
|
|
|
// #### Browse
|
2013-12-06 09:51:35 +01:00
|
|
|
// **takes:** filter / pagination parameters
|
|
|
|
browse: function browse(options) {
|
2014-01-03 15:50:03 +00:00
|
|
|
options = options || {};
|
2014-04-19 17:03:20 +02:00
|
|
|
|
|
|
|
// only published posts if no user is present
|
2014-04-08 15:40:33 +02:00
|
|
|
if (!this.user) {
|
|
|
|
options.status = 'published';
|
|
|
|
}
|
2013-12-06 09:51:35 +01:00
|
|
|
// **returns:** a promise for a page of posts in a json object
|
|
|
|
return dataProvider.Post.findPage(options).then(function (result) {
|
|
|
|
var i = 0,
|
|
|
|
omitted = result;
|
|
|
|
|
|
|
|
for (i = 0; i < omitted.posts.length; i = i + 1) {
|
|
|
|
omitted.posts[i].author = _.omit(omitted.posts[i].author, filteredUserAttributes);
|
|
|
|
}
|
|
|
|
return omitted;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// #### Read
|
|
|
|
// **takes:** an identifier (id or slug?)
|
2014-04-08 15:40:33 +02:00
|
|
|
read: function read(options) {
|
|
|
|
options = options || {};
|
2014-04-19 17:03:20 +02:00
|
|
|
|
|
|
|
// only published posts if no user is present
|
2014-04-08 15:40:33 +02:00
|
|
|
if (!this.user) {
|
|
|
|
options.status = 'published';
|
|
|
|
}
|
|
|
|
|
2013-12-06 09:51:35 +01:00
|
|
|
// **returns:** a promise for a single post in a json object
|
2014-04-08 15:40:33 +02:00
|
|
|
return dataProvider.Post.findOne(options).then(function (result) {
|
2013-12-06 09:51:35 +01:00
|
|
|
var omitted;
|
|
|
|
|
|
|
|
if (result) {
|
|
|
|
omitted = result.toJSON();
|
|
|
|
omitted.author = _.omit(omitted.author, filteredUserAttributes);
|
2014-04-16 12:09:03 +02:00
|
|
|
return { posts: [ omitted ]};
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
2014-02-26 18:51:01 +01:00
|
|
|
return when.reject({code: 404, message: 'Post not found'});
|
2013-12-06 09:51:35 +01:00
|
|
|
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// #### Edit
|
|
|
|
// **takes:** a json object with all the properties which should be updated
|
|
|
|
edit: function edit(postData) {
|
|
|
|
// **returns:** a promise for the resulting post in a json object
|
2014-04-03 15:03:09 +02:00
|
|
|
var self = this;
|
|
|
|
|
|
|
|
return canThis(self.user).edit.post(postData.id).then(function () {
|
2014-04-16 12:09:03 +02:00
|
|
|
return checkPostData(postData).then(function (checkedPostData) {
|
2014-04-16 18:49:07 +02:00
|
|
|
return dataProvider.Post.edit(checkedPostData.posts[0], {user: self.user});
|
2014-04-16 12:09:03 +02:00
|
|
|
}).then(function (result) {
|
2013-12-06 09:51:35 +01:00
|
|
|
if (result) {
|
|
|
|
var omitted = result.toJSON();
|
|
|
|
omitted.author = _.omit(omitted.author, filteredUserAttributes);
|
2014-04-16 12:09:03 +02:00
|
|
|
return { posts: [ omitted ]};
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
2014-02-26 18:51:01 +01:00
|
|
|
return when.reject({code: 404, message: 'Post not found'});
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
}, function () {
|
2014-02-26 18:51:01 +01:00
|
|
|
return when.reject({code: 403, message: 'You do not have permission to edit this post.'});
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// #### Add
|
|
|
|
// **takes:** a json object representing a post,
|
|
|
|
add: function add(postData) {
|
2014-04-03 15:03:09 +02:00
|
|
|
var self = this;
|
2013-12-06 09:51:35 +01:00
|
|
|
// **returns:** a promise for the resulting post in a json object
|
|
|
|
return canThis(this.user).create.post().then(function () {
|
2014-04-16 12:09:03 +02:00
|
|
|
return checkPostData(postData).then(function (checkedPostData) {
|
2014-04-03 15:03:09 +02:00
|
|
|
return dataProvider.Post.add(checkedPostData.posts[0], {user: self.user});
|
2014-04-16 12:09:03 +02:00
|
|
|
}).then(function (result) {
|
|
|
|
var omitted = result.toJSON();
|
|
|
|
omitted.author = _.omit(omitted.author, filteredUserAttributes);
|
|
|
|
return { posts: [ omitted ]};
|
|
|
|
});
|
2013-12-06 09:51:35 +01:00
|
|
|
}, function () {
|
2014-02-26 18:51:01 +01:00
|
|
|
return when.reject({code: 403, message: 'You do not have permission to add posts.'});
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
// #### Destroy
|
|
|
|
// **takes:** an identifier (id or slug?)
|
|
|
|
destroy: function destroy(args) {
|
2014-04-08 15:40:33 +02:00
|
|
|
var self = this;
|
2013-12-06 09:51:35 +01:00
|
|
|
// **returns:** a promise for a json response with the id of the deleted post
|
|
|
|
return canThis(this.user).remove.post(args.id).then(function () {
|
2014-04-08 15:40:33 +02:00
|
|
|
// TODO: Would it be good to get rid of .call()?
|
|
|
|
return posts.read.call({user: self.user}, {id : args.id, status: 'all'}).then(function (result) {
|
2013-12-06 09:51:35 +01:00
|
|
|
return dataProvider.Post.destroy(args.id).then(function () {
|
2014-01-03 00:37:21 +00:00
|
|
|
var deletedObj = result;
|
2013-12-06 09:51:35 +01:00
|
|
|
return deletedObj;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}, function () {
|
2014-02-26 18:51:01 +01:00
|
|
|
return when.reject({code: 403, message: 'You do not have permission to remove posts.'});
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
2014-04-08 15:40:33 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
// #### Generate slug
|
|
|
|
|
|
|
|
// **takes:** a string to generate the slug from
|
|
|
|
generateSlug: function generateSlug(args) {
|
|
|
|
|
|
|
|
return canThis(this.user).slug.post().then(function () {
|
|
|
|
return dataProvider.Base.Model.generateSlug(dataProvider.Post, args.title, {status: 'all'}).then(function (slug) {
|
|
|
|
if (slug) {
|
|
|
|
return slug;
|
|
|
|
}
|
|
|
|
return when.reject({code: 500, message: 'Could not generate slug'});
|
|
|
|
});
|
|
|
|
}, function () {
|
|
|
|
return when.reject({code: 403, message: 'You do not have permission.'});
|
|
|
|
});
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
2014-04-08 15:40:33 +02:00
|
|
|
|
2013-12-06 09:51:35 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = posts;
|