j2s
Version:
JSON to SQL, build RESTful API server on the fly, which accespts JSON describing SQL query statements, support (almost) full SQL functionality, with configurable access control & pluggable middlewares
83 lines (80 loc) • 18.6 kB
JavaScript
'use strict';
function J2SError(code, message, status) {
this.success = false;
this.code = code;
this.message = message;
if (status) {
this.status = status;
}
}
J2SError.prototype = Object.create(Error.prototype);
J2SError.prototype.name = "J2SError";
J2SError.prototype.success = false;
J2SError.prototype.code = -1;
J2SError.prototype.message = "";
J2SError.prototype.status = 500;
J2SError.prototype.constructor = J2SError;
module.exports = {
J2SError: J2SError,
ErrBetweenSuffixValueShouldBeList: new J2SError(100101, "value for query clause with 'between' suffix must be list"),
ErrBetweenSuffixValueShouldBeLengthTwo: new J2SError(100102, "value for query clause with 'between' suffix must be list of length 2"),
ErrNotBetweenSuffixShouldBeList: new J2SError(100103, "value for query clause with 'not_between' suffix must be list"),
ErrNotBetweenSuffixShouldBeLengthTwo: new J2SError(100104, "value for query clause with 'not_between' suffix must be list of length 2"),
ErrInSuffixShouldBeList: new J2SError(100105, "value for query clause with 'in' suffix must be list"),
ErrNotInSuffixShouldBeList: new J2SError(100106, "value for query clause with 'not_in' suffix must be list"),
ErrNullSuffixShouldBeBoolean: new J2SError(100107, "value for query clause with 'null' suffix must be boolean"),
FnErrSuffixNotImplemented: function FnErrSuffixNotImplemented(suffix) {
return new J2SError(100108, "suffix '".concat(suffix, "' is not implemented"));
},
ErrJoinShouldBeJSONObject: new J2SError(100108, "value of 'join' should be JSON object"),
ErrOrderByShouldBeList: new J2SError(100109, "value of 'order_by' should be list"),
ErrOrderByLengthShouldBeTwo: new J2SError(100110, "value of 'order_by' could only be of length 1 or 2"),
FnErrKeywordNotImplemented: function FnErrKeywordNotImplemented(keyword) {
return new J2SError(100111, "keyword '".concat(keyword, "' is not implemented"));
},
FnErrUnknowRuleType: function FnErrUnknowRuleType(rule) {
return new J2SError(100112, "unknown rule type: ".concat(rule));
},
ErrOperationNotAuthorized: new J2SError(100113, "operation not authorized"),
ErrQueryShouldBeJsonObject: new J2SError(100115, "value of 'query' must be JSON object"),
ErrDataShouldBeJsonObject: new J2SError(100117, "value of 'data' must be JSON object"),
ErrPopulateShouldBeList: new J2SError(100118, "value of 'populate' must be JSON array"),
ErrPopulateObjectShouldHaveExactlyOneKey: new J2SError(100119, "value of element in 'populate' with object type should have exactly one key"),
ErrPopulateElementShouldBeStringOrObject: new J2SError(100120, "value of element in 'populate' should be either JSON object or string"),
ErrExistsObjectShouldHaveExactlyOneKey: new J2SError(100121, "value of 'exists' or 'not_exists' should be JSON object that contains exactly one key"),
ErrAddClauseShouldBeList: new J2SError(100122, "value of 'add_clause' should be JSON Array"),
FnErrKeyForbidden: function FnErrKeyForbidden(keyword) {
return new J2SError(100123, "keyword '".concat(keyword, "' is forbidden"));
},
ErrAddClauseElementShouldBeStringOrObject: new J2SError(100124, "value of element in 'add_clause' should be either JSON object or string"),
ErrLikeShouldBeStringOrList: new J2SError(100125, "value of 'like' should be either JSON array or string"),
ErrDeletionNotAllowed: new J2SError(100126, "deletion for more than one instance is not allowed"),
ErrResourceNotFound: new J2SError(100127, "resource not found"),
FnErrDatabaseOperationError: function FnErrDatabaseOperationError(msg) {
return new J2SError(100128, "DB operation error: ".concat(msg));
},
FnErrClauseNotExists: function FnErrClauseNotExists(clause) {
return new J2SError(100129, "clause '".concat(clause, "' is not defined on the model"));
},
FnErrClauseObjectShouldHaveExactlyOneKey: function FnErrClauseObjectShouldHaveExactlyOneKey(keys) {
return new J2SError(100130, "clause should have exactly one key, but got [".concat(keys, "]"));
},
ErrWhereKeywordWhenGetWithIdForbidden: new J2SError(100131, "the 'where' keyword is not allowed when get objects with id"),
FnErrValueShouldBeObject: function FnErrValueShouldBeObject(key) {
return new J2SError(100132, "the value of key '".concat(key, "' should be object"));
},
FnErrValueShouldBeArray: function FnErrValueShouldBeArray(key) {
return new J2SError(100133, "the value of key '".concat(key, "' should be array"));
},
ErrRelationKeyConflicts: new J2SError(100134, "'replace' conflicts with 'add', 'remove' or 'create'"),
FnErrUnknownRelationType: function FnErrUnknownRelationType(type) {
return new J2SError(100135, "relation type '".concat(type, "' is not implemented"));
},
ErrNoQueryOrWhereSupplied: new J2SError(100136, "no 'query' or 'where' supplied in body when updating data"),
ErrWhereKeywordWhenPutWithIdForbidden: new J2SError(100137, "the 'where' keyword is not allowed when put objects with id"),
ErrWhereKeywordWhenDeleteWithIdForbidden: new J2SError(100138, "the 'where' keyword is not allowed when delete objects with id"),
FnErrValueShouldBeNumberOrObject: function FnErrValueShouldBeNumberOrObject(key) {
return new J2SError(100139, "the value of key '".concat(key, "' should be number or object"));
}
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/errors.js"],"names":["J2SError","code","message","status","success","prototype","Object","create","Error","name","constructor","module","exports","ErrBetweenSuffixValueShouldBeList","ErrBetweenSuffixValueShouldBeLengthTwo","ErrNotBetweenSuffixShouldBeList","ErrNotBetweenSuffixShouldBeLengthTwo","ErrInSuffixShouldBeList","ErrNotInSuffixShouldBeList","ErrNullSuffixShouldBeBoolean","FnErrSuffixNotImplemented","suffix","ErrJoinShouldBeJSONObject","ErrOrderByShouldBeList","ErrOrderByLengthShouldBeTwo","FnErrKeywordNotImplemented","keyword","FnErrUnknowRuleType","rule","ErrOperationNotAuthorized","ErrQueryShouldBeJsonObject","ErrDataShouldBeJsonObject","ErrPopulateShouldBeList","ErrPopulateObjectShouldHaveExactlyOneKey","ErrPopulateElementShouldBeStringOrObject","ErrExistsObjectShouldHaveExactlyOneKey","ErrAddClauseShouldBeList","FnErrKeyForbidden","ErrAddClauseElementShouldBeStringOrObject","ErrLikeShouldBeStringOrList","ErrDeletionNotAllowed","ErrResourceNotFound","FnErrDatabaseOperationError","msg","FnErrClauseNotExists","clause","FnErrClauseObjectShouldHaveExactlyOneKey","keys","ErrWhereKeywordWhenGetWithIdForbidden","FnErrValueShouldBeObject","key","FnErrValueShouldBeArray","ErrRelationKeyConflicts","FnErrUnknownRelationType","type","ErrNoQueryOrWhereSupplied","ErrWhereKeywordWhenPutWithIdForbidden","ErrWhereKeywordWhenDeleteWithIdForbidden","FnErrValueShouldBeNumberOrObject"],"mappings":"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","sourcesContent":["'use strict';\n\nfunction J2SError(code, message, status) {\n    this.success = false;\n    this.code = code;\n    this.message = message;\n    if (status) {\n        this.status = status;\n    }\n }\n\nJ2SError.prototype = Object.create(Error.prototype);\nJ2SError.prototype.name = \"J2SError\";\nJ2SError.prototype.success = false;\nJ2SError.prototype.code = -1;\nJ2SError.prototype.message = \"\";\nJ2SError.prototype.status = 500;\nJ2SError.prototype.constructor = J2SError;\n\nmodule.exports = {\n    J2SError: J2SError,\n    ErrBetweenSuffixValueShouldBeList: new J2SError(100101, `value for query clause with 'between' suffix must be list`),\n    ErrBetweenSuffixValueShouldBeLengthTwo: new J2SError(100102, `value for query clause with 'between' suffix must be list of length 2`),\n    ErrNotBetweenSuffixShouldBeList: new J2SError(100103, `value for query clause with 'not_between' suffix must be list`),\n    ErrNotBetweenSuffixShouldBeLengthTwo: new J2SError(100104, `value for query clause with 'not_between' suffix must be list of length 2`),\n    ErrInSuffixShouldBeList: new J2SError(100105, `value for query clause with 'in' suffix must be list`),\n    ErrNotInSuffixShouldBeList: new J2SError(100106, `value for query clause with 'not_in' suffix must be list`),\n    ErrNullSuffixShouldBeBoolean: new J2SError(100107, `value for query clause with 'null' suffix must be boolean`),\n    FnErrSuffixNotImplemented: function(suffix) {\n        return new J2SError(100108, `suffix '${suffix}' is not implemented`);\n    },\n    ErrJoinShouldBeJSONObject: new J2SError(100108, `value of 'join' should be JSON object`),\n    ErrOrderByShouldBeList: new J2SError(100109, `value of 'order_by' should be list`),\n    ErrOrderByLengthShouldBeTwo: new J2SError(100110, `value of 'order_by' could only be of length 1 or 2`),\n    FnErrKeywordNotImplemented: function(keyword) {\n        return new J2SError(100111, `keyword '${keyword}' is not implemented`);\n    },\n    FnErrUnknowRuleType: function(rule) {\n        return new J2SError(100112, `unknown rule type: ${rule}`);\n    },\n    ErrOperationNotAuthorized: new J2SError(100113, `operation not authorized`),\n    ErrQueryShouldBeJsonObject: new J2SError(100115, `value of 'query' must be JSON object`),\n    ErrDataShouldBeJsonObject: new J2SError(100117, `value of 'data' must be JSON object`),\n    ErrPopulateShouldBeList: new J2SError(100118, `value of 'populate' must be JSON array`),\n    ErrPopulateObjectShouldHaveExactlyOneKey: new J2SError(100119, `value of element in 'populate' with object type should have exactly one key`),\n    ErrPopulateElementShouldBeStringOrObject: new J2SError(100120, `value of element in 'populate' should be either JSON object or string`),\n    ErrExistsObjectShouldHaveExactlyOneKey: new J2SError(100121, `value of 'exists' or 'not_exists' should be JSON object that contains exactly one key`),\n    ErrAddClauseShouldBeList: new J2SError(100122, `value of 'add_clause' should be JSON Array`),\n    FnErrKeyForbidden: function(keyword) {\n        return new J2SError(100123, `keyword '${keyword}' is forbidden`);\n    },\n    ErrAddClauseElementShouldBeStringOrObject: new J2SError(100124, `value of element in 'add_clause' should be either JSON object or string`),\n    ErrLikeShouldBeStringOrList: new J2SError(100125, `value of 'like' should be either JSON array or string`),\n    ErrDeletionNotAllowed: new J2SError(100126, `deletion for more than one instance is not allowed`),\n    ErrResourceNotFound: new J2SError(100127, `resource not found`),\n    FnErrDatabaseOperationError: function(msg) {\n        return new J2SError(100128, `DB operation error: ${msg}`);\n    },\n    FnErrClauseNotExists: function(clause) {\n        return new J2SError(100129, `clause '${clause}' is not defined on the model`);\n    },\n    FnErrClauseObjectShouldHaveExactlyOneKey: function(keys) {\n        return new J2SError(100130, `clause should have exactly one key, but got [${keys}]`);\n    },\n    ErrWhereKeywordWhenGetWithIdForbidden: new J2SError(100131, `the 'where' keyword is not allowed when get objects with id`),\n    FnErrValueShouldBeObject: function(key) {\n        return new J2SError(100132, `the value of key '${key}' should be object`);\n    },\n    FnErrValueShouldBeArray: function(key) {\n        return new J2SError(100133, `the value of key '${key}' should be array`);\n    },\n    ErrRelationKeyConflicts: new J2SError(100134, `'replace' conflicts with 'add', 'remove' or 'create'`),\n    FnErrUnknownRelationType: function(type) {\n        return new J2SError(100135, `relation type '${type}' is not implemented`);\n    },\n    ErrNoQueryOrWhereSupplied: new J2SError(100136, `no 'query' or 'where' supplied in body when updating data`),\n    ErrWhereKeywordWhenPutWithIdForbidden: new J2SError(100137, `the 'where' keyword is not allowed when put objects with id`),\n    ErrWhereKeywordWhenDeleteWithIdForbidden: new J2SError(100138, `the 'where' keyword is not allowed when delete objects with id`),\n    FnErrValueShouldBeNumberOrObject: function(key) {\n        return new J2SError(100139, `the value of key '${key}' should be number or object`);\n    },\n}\n"]}