c02ebb0dcf
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
39 lines
1.2 KiB
JavaScript
39 lines
1.2 KiB
JavaScript
var migrations = require('../data/migration'),
|
|
_ = require('lodash'),
|
|
when = require('when');
|
|
|
|
module.exports = {
|
|
Post: require('./post').Post,
|
|
User: require('./user').User,
|
|
Role: require('./role').Role,
|
|
Permission: require('./permission').Permission,
|
|
Settings: require('./settings').Settings,
|
|
Tag: require('./tag').Tag,
|
|
Base: require('./base'),
|
|
Session: require('./session').Session,
|
|
App: require('./app').App,
|
|
AppField: require('./appField').AppField,
|
|
AppSetting: require('./appSetting').AppSetting,
|
|
|
|
init: function () {
|
|
return migrations.init();
|
|
},
|
|
// ### deleteAllContent
|
|
// Delete all content from the database (posts, tags, tags_posts)
|
|
deleteAllContent: function () {
|
|
var self = this;
|
|
|
|
return self.Post.findAll().then(function (posts) {
|
|
return when.all(_.map(posts.toJSON(), function (post) {
|
|
return self.Post.destroy({id: post.id});
|
|
}));
|
|
}).then(function () {
|
|
return self.Tag.findAll().then(function (tags) {
|
|
return when.all(_.map(tags.toJSON(), function (tag) {
|
|
return self.Tag.destroy({id: tag.id});
|
|
}));
|
|
});
|
|
});
|
|
}
|
|
};
|