mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-25 11:55:03 +03:00
7498b520e4
Refactored the generateSlug method to return a promise and check for existing posts with matching slugs. Should close #221
56 lines
1.2 KiB
JavaScript
56 lines
1.2 KiB
JavaScript
var _ = require('underscore'),
|
|
errors;
|
|
|
|
/**
|
|
* Basic error handling helpers
|
|
*/
|
|
errors = {
|
|
throwError: function (err) {
|
|
if (!err) {
|
|
err = new Error("An error occurred");
|
|
}
|
|
|
|
if (_.isString(err)) {
|
|
throw new Error(err);
|
|
}
|
|
|
|
throw err;
|
|
},
|
|
|
|
logError: function (err) {
|
|
err = err || "Unknown";
|
|
// TODO: Logging framework hookup
|
|
console.log("Error occurred: ", err.message || err, err.stack || "");
|
|
},
|
|
|
|
logAndThrowError: function (err) {
|
|
this.logError(err);
|
|
|
|
this.throwError(err);
|
|
},
|
|
|
|
logErrorWithMessage: function (msg) {
|
|
var self = this;
|
|
|
|
return function () {
|
|
self.logError(msg);
|
|
};
|
|
},
|
|
|
|
logErrorWithRedirect: function (msg, redirectTo, req, res) {
|
|
var self = this;
|
|
|
|
return function () {
|
|
self.logError(msg);
|
|
|
|
if (_.isFunction(res.redirect)) {
|
|
res.redirect(redirectTo);
|
|
}
|
|
};
|
|
}
|
|
};
|
|
|
|
// Ensure our 'this' context in the functions
|
|
_.bindAll(errors, "throwError", "logError", "logAndThrowError", "logErrorWithMessage", "logErrorWithRedirect");
|
|
|
|
module.exports = errors; |