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
|
|
|
var when = require('when'),
|
|
|
|
_ = require('lodash'),
|
|
|
|
dataProvider = require('../models'),
|
|
|
|
settings = require('./settings'),
|
|
|
|
canThis = require('../permissions').canThis,
|
|
|
|
errors = require('../errors'),
|
|
|
|
utils = require('./utils'),
|
|
|
|
|
|
|
|
docName = 'users',
|
|
|
|
ONE_DAY = 86400000,
|
2013-12-06 09:51:35 +01:00
|
|
|
users;
|
|
|
|
|
|
|
|
users = {
|
|
|
|
|
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
|
|
|
/**
|
|
|
|
* ## Browse
|
|
|
|
* Fetch all users
|
|
|
|
* @param {object} options (optional)
|
|
|
|
* @returns {Promise(Users)} Users Collection
|
|
|
|
*/
|
2013-12-06 09:51:35 +01:00
|
|
|
browse: function browse(options) {
|
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
|
|
|
options = options || {};
|
|
|
|
return canThis(options.context).browse.user().then(function () {
|
Consistency in model method naming
- The API has the BREAD naming for methods
- The model now has findAll, findOne, findPage (where needed), edit, add and destroy, meaning it is similar but with a bit more flexibility
- browse, read, update, create, and delete, which were effectively just aliases, have all been removed.
- added jsDoc for the model methods
2014-05-05 16:18:38 +01:00
|
|
|
return dataProvider.User.findAll(options).then(function (result) {
|
2014-05-06 12:14:58 +02:00
|
|
|
return { users: result.toJSON() };
|
2014-04-08 15:40:33 +02:00
|
|
|
});
|
|
|
|
}, function () {
|
2014-05-09 12:11:29 +02:00
|
|
|
return when.reject(new errors.NoPermissionError('You do not have permission to browse users.'));
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
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
|
|
|
read: function read(options) {
|
|
|
|
var attrs = ['id'],
|
|
|
|
data = _.pick(options, attrs);
|
|
|
|
|
|
|
|
options = _.omit(options, attrs);
|
|
|
|
|
|
|
|
if (data.id === 'me' && options.context && options.context.user) {
|
|
|
|
data.id = options.context.user;
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
|
|
|
|
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
|
|
|
return dataProvider.User.findOne(data, options).then(function (result) {
|
2013-12-06 09:51:35 +01:00
|
|
|
if (result) {
|
2014-05-06 12:14:58 +02:00
|
|
|
return { users: [result.toJSON()] };
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
|
|
|
|
2014-05-09 12:11:29 +02:00
|
|
|
return when.reject(new errors.NotFoundError('User not found.'));
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
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
|
|
|
edit: function edit(object, options) {
|
|
|
|
if (options.id === 'me' && options.context && options.context.user) {
|
|
|
|
options.id = options.context.user;
|
|
|
|
}
|
|
|
|
|
|
|
|
return canThis(options.context).edit.user(options.id).then(function () {
|
|
|
|
return utils.checkObject(object, docName).then(function (checkedUserData) {
|
|
|
|
|
|
|
|
return dataProvider.User.edit(checkedUserData.users[0], options);
|
2014-04-28 21:42:38 +01:00
|
|
|
}).then(function (result) {
|
2014-04-08 15:40:33 +02:00
|
|
|
if (result) {
|
2014-05-06 12:14:58 +02:00
|
|
|
return { users: [result.toJSON()]};
|
2014-04-08 15:40:33 +02:00
|
|
|
}
|
2014-05-09 12:11:29 +02:00
|
|
|
return when.reject(new errors.NotFoundError('User not found.'));
|
2014-04-08 15:40:33 +02:00
|
|
|
});
|
|
|
|
}, function () {
|
2014-05-09 12:11:29 +02:00
|
|
|
return when.reject(new errors.NoPermissionError('You do not have permission to edit this users.'));
|
2013-12-06 09:51:35 +01:00
|
|
|
});
|
|
|
|
},
|
|
|
|
|
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
|
|
|
add: function add(object, options) {
|
|
|
|
options = options || {};
|
|
|
|
|
|
|
|
return canThis(options.context).add.user().then(function () {
|
|
|
|
return utils.checkObject(object, docName).then(function (checkedUserData) {
|
|
|
|
// if the user is created by users.register(), use id: 1 as the creator for now
|
|
|
|
if (options.context.internal) {
|
|
|
|
options.context.user = 1;
|
2014-04-28 21:42:38 +01:00
|
|
|
}
|
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
|
|
|
|
|
|
|
return dataProvider.User.add(checkedUserData.users[0], options);
|
2014-04-28 21:42:38 +01:00
|
|
|
}).then(function (result) {
|
|
|
|
if (result) {
|
2014-05-06 12:14:58 +02:00
|
|
|
return { users: [result.toJSON()]};
|
2014-04-28 21:42:38 +01:00
|
|
|
}
|
|
|
|
});
|
2014-04-08 15:40:33 +02:00
|
|
|
}, function () {
|
2014-05-09 12:11:29 +02:00
|
|
|
return when.reject(new errors.NoPermissionError('You do not have permission to add a users.'));
|
2014-04-08 15:40:33 +02:00
|
|
|
});
|
2014-04-03 15:03:09 +02:00
|
|
|
},
|
|
|
|
|
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
|
|
|
register: function register(object) {
|
|
|
|
// TODO: if we want to prevent users from being created with the signup form this is the right place to do it
|
|
|
|
return users.add(object, {context: {internal: true}});
|
2013-12-06 09:51:35 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
|
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
|
|
|
check: function check(object) {
|
|
|
|
return dataProvider.User.check(object);
|
2013-12-06 09:51:35 +01:00
|
|
|
},
|
|
|
|
|
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
|
|
|
changePassword: function changePassword(object) {
|
|
|
|
return dataProvider.User.changePassword(object);
|
2013-12-06 09:51:35 +01:00
|
|
|
},
|
|
|
|
|
|
|
|
generateResetToken: function generateResetToken(email) {
|
|
|
|
var expires = Date.now() + ONE_DAY;
|
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
|
|
|
return settings.read({context: {internal: true}, key: 'dbHash'}).then(function (response) {
|
2014-04-27 18:28:50 -05:00
|
|
|
var dbHash = response.settings[0].value;
|
2013-12-06 09:51:35 +01:00
|
|
|
return dataProvider.User.generateResetToken(email, expires, dbHash);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
validateToken: function validateToken(token) {
|
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
|
|
|
return settings.read({context: {internal: true}, key: 'dbHash'}).then(function (response) {
|
2014-04-27 18:28:50 -05:00
|
|
|
var dbHash = response.settings[0].value;
|
2013-12-06 09:51:35 +01:00
|
|
|
return dataProvider.User.validateToken(token, dbHash);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
|
|
|
|
resetPassword: function resetPassword(token, newPassword, ne2Password) {
|
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
|
|
|
return settings.read({context: {internal: true}, key: 'dbHash'}).then(function (response) {
|
2014-04-27 18:28:50 -05:00
|
|
|
var dbHash = response.settings[0].value;
|
2013-12-06 09:51:35 +01:00
|
|
|
return dataProvider.User.resetPassword(token, newPassword, ne2Password, dbHash);
|
|
|
|
});
|
2014-04-08 15:40:33 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
doesUserExist: function doesUserExist() {
|
Consistency in model method naming
- The API has the BREAD naming for methods
- The model now has findAll, findOne, findPage (where needed), edit, add and destroy, meaning it is similar but with a bit more flexibility
- browse, read, update, create, and delete, which were effectively just aliases, have all been removed.
- added jsDoc for the model methods
2014-05-05 16:18:38 +01:00
|
|
|
return dataProvider.User.findAll().then(function (users) {
|
2014-04-08 15:40:33 +02:00
|
|
|
if (users.length === 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
});
|
2013-12-06 09:51:35 +01:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = users;
|