@becomes/cms
Version:
Simple CMS for building APIs.
590 lines • 32.9 kB
JavaScript
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
var __generator = (this && this.__generator) || function (thisArg, body) {
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
function verb(n) { return function (v) { return step([n, v]); }; }
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (_) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0: case 1: t = op; break;
case 4: _.label++; return { value: op[1], done: false };
case 5: _.label++; y = op[1]; op = [0]; continue;
case 7: op = _.ops.pop(); _.trys.pop(); continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
if (t[2]) _.ops.pop();
_.trys.pop(); continue;
}
op = body.call(thisArg, _);
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
}
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.GroupController = void 0;
var purple_cheetah_1 = require("purple-cheetah");
var group_service_1 = require("./group.service");
var group_factory_1 = require("./factories/group.factory");
var prop_util_1 = require("../prop/prop-util");
var group_util_1 = require("./group-util");
var template_service_1 = require("../template/template.service");
var prop_interface_1 = require("../prop/interfaces/prop.interface");
var widget_service_1 = require("../widget/widget.service");
var entry_1 = require("../entry");
var GroupController = (function () {
function GroupController() {
}
GroupController_1 = GroupController;
GroupController.prototype.getAll = function (request) {
return __awaiter(this, void 0, void 0, function () {
var error, query, ids, jwt, jwtValid, groups;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
error = purple_cheetah_1.HttpErrorFactory.simple('getAll', this.logger);
query = request.query;
ids = [];
if (query.ids) {
ids = query.ids.split('-');
ids.forEach(function (id, i) {
if (purple_cheetah_1.StringUtility.isIdValid(id) === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Invalid ID '" + id + "' was provided at [" + i + "].");
}
});
}
jwt = purple_cheetah_1.JWTEncoding.decode(request.headers.authorization);
if (jwt instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwt.message);
}
else {
jwtValid = purple_cheetah_1.JWTSecurity.validateAndCheckTokenPermissions(jwt, [purple_cheetah_1.RoleName.ADMIN, purple_cheetah_1.RoleName.USER], purple_cheetah_1.PermissionName.READ, purple_cheetah_1.JWTConfigService.get('user-token-config'));
if (jwtValid instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwtValid.message);
}
}
if (!(ids.length > 0)) return [3, 2];
return [4, this.groupService.findAllById(ids)];
case 1:
groups = _a.sent();
return [3, 4];
case 2: return [4, this.groupService.findAll()];
case 3:
groups = _a.sent();
_a.label = 4;
case 4: return [2, {
groups: groups,
}];
}
});
});
};
GroupController.prototype.getById = function (request) {
return __awaiter(this, void 0, void 0, function () {
var error, jwt, jwtValid, group;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
error = purple_cheetah_1.HttpErrorFactory.simple('getById', this.logger);
if (purple_cheetah_1.StringUtility.isIdValid(request.params.id) === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Invalid ID '" + request.params.id + "' was provided.");
}
jwt = purple_cheetah_1.JWTEncoding.decode(request.headers.authorization);
if (jwt instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwt.message);
}
else {
jwtValid = purple_cheetah_1.JWTSecurity.validateAndCheckTokenPermissions(jwt, [purple_cheetah_1.RoleName.ADMIN, purple_cheetah_1.RoleName.USER], purple_cheetah_1.PermissionName.READ, purple_cheetah_1.JWTConfigService.get('user-token-config'));
if (jwtValid instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwtValid.message);
}
}
return [4, this.groupService.findById(request.params.id)];
case 1:
group = _a.sent();
if (group === null) {
throw error.occurred(purple_cheetah_1.HttpStatus.NOT_FOUNT, "Group with ID '" + request.params.id + "' does not exist.");
}
return [2, {
group: group,
}];
}
});
});
};
GroupController.prototype.add = function (request) {
return __awaiter(this, void 0, void 0, function () {
var error, jwt, jwtValid, group, groupWithSameName, addGroupResult;
return __generator(this, function (_a) {
switch (_a.label) {
case 0:
error = purple_cheetah_1.HttpErrorFactory.simple('add', this.logger);
try {
purple_cheetah_1.ObjectUtility.compareWithSchema(request.body, {
name: {
__type: 'string',
__required: true,
},
desc: {
__type: 'string',
__required: false,
},
}, 'body');
}
catch (e) {
throw error.occurred(purple_cheetah_1.HttpStatus.BAD_REQUEST, e.message);
}
jwt = purple_cheetah_1.JWTEncoding.decode(request.headers.authorization);
if (jwt instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwt.message);
}
else {
jwtValid = purple_cheetah_1.JWTSecurity.validateAndCheckTokenPermissions(jwt, [purple_cheetah_1.RoleName.ADMIN, purple_cheetah_1.RoleName.USER], purple_cheetah_1.PermissionName.WRITE, purple_cheetah_1.JWTConfigService.get('user-token-config'));
if (jwtValid instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwtValid.message);
}
}
group = group_factory_1.GroupFactory.instance;
group.name = group_util_1.GroupUtil.nameEncode(request.body.name);
if (typeof request.body.desc !== 'undefined') {
group.desc = request.body.desc;
}
else {
group.desc = '';
}
return [4, this.groupService.findByName(group.name)];
case 1:
groupWithSameName = _a.sent();
if (groupWithSameName !== null) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Group with name '" + group.name + "' already exist.");
}
return [4, this.groupService.add(group)];
case 2:
addGroupResult = _a.sent();
if (addGroupResult === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.INTERNAL_SERVER_ERROR, 'Failed to add Group to database.');
}
return [2, {
group: group,
}];
}
});
});
};
GroupController.prototype.update = function (request) {
return __awaiter(this, void 0, void 0, function () {
var error, jwt, jwtValid, group, changeDetected, groupWithSameName, _a, e_1, updateGroupResult, groups, _b, _c, _i, i, g, updateGroupPointerResult, updateResult, templates, _d, _e, _f, i, template, updateGroupPointerResult, updateResult, widgets, _g, _h, _j, i, widget, updateGroupPointerResult, updateResult;
return __generator(this, function (_k) {
switch (_k.label) {
case 0:
error = purple_cheetah_1.HttpErrorFactory.simple('update', this.logger);
try {
purple_cheetah_1.ObjectUtility.compareWithSchema(request.body, {
_id: {
__type: 'string',
__required: true,
},
name: {
__type: 'string',
__required: false,
},
desc: {
__type: 'string',
__required: false,
},
changes: {
__type: 'object',
__required: false,
__child: {
props: {
__type: 'array',
__required: true,
__child: {
__type: 'object',
__content: prop_util_1.PropUtil.changesSchema,
},
},
},
},
}, 'body');
}
catch (e) {
throw error.occurred(purple_cheetah_1.HttpStatus.BAD_REQUEST, e.message);
}
if (purple_cheetah_1.StringUtility.isIdValid(request.body._id) === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Invalid ID '" + request.body._id + "' was provided.");
}
jwt = purple_cheetah_1.JWTEncoding.decode(request.headers.authorization);
if (jwt instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwt.message);
}
else {
jwtValid = purple_cheetah_1.JWTSecurity.validateAndCheckTokenPermissions(jwt, [purple_cheetah_1.RoleName.ADMIN, purple_cheetah_1.RoleName.USER], purple_cheetah_1.PermissionName.WRITE, purple_cheetah_1.JWTConfigService.get('user-token-config'));
if (jwtValid instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwtValid.message);
}
}
return [4, this.groupService.findById(request.body._id)];
case 1:
group = _k.sent();
if (group === null) {
throw error.occurred(purple_cheetah_1.HttpStatus.NOT_FOUNT, "Group with ID '" + request.body._id + "' does not exist.");
}
changeDetected = false;
if (!(typeof request.body.name !== 'undefined' &&
request.body.name !== group.name)) return [3, 3];
changeDetected = true;
group.name = group_util_1.GroupUtil.nameEncode(request.body.name);
return [4, this.groupService.findByName(group.name)];
case 2:
groupWithSameName = _k.sent();
if (groupWithSameName !== null) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Group with name '" + group.name + "' already exist.");
}
_k.label = 3;
case 3:
if (typeof request.body.desc !== 'undefined' &&
request.body.desc !== group.desc) {
changeDetected = true;
group.desc = request.body.desc;
}
if (!(typeof request.body.props !== 'undefined')) return [3, 7];
if (typeof request.body.changes === 'undefined') {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, 'When updating Props, changes must be provided.');
}
changeDetected = true;
_k.label = 4;
case 4:
_k.trys.push([4, 6, , 7]);
_a = group;
return [4, prop_util_1.PropUtil.getPropsFromUntrustedObject(request.body.props, this.groupService)];
case 5:
_a.props = _k.sent();
return [3, 7];
case 6:
e_1 = _k.sent();
throw error.occurred(purple_cheetah_1.HttpStatus.BAD_REQUEST, e_1.message);
case 7:
if (changeDetected === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, 'Noting to update.');
}
return [4, this.groupService.update(group)];
case 8:
updateGroupResult = _k.sent();
if (updateGroupResult === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.INTERNAL_SERVER_ERROR, "Failed to update Group in database.");
}
return [4, this.groupService.findAll()];
case 9:
groups = _k.sent();
_b = [];
for (_c in groups)
_b.push(_c);
_i = 0;
_k.label = 10;
case 10:
if (!(_i < _b.length)) return [3, 13];
i = _b[_i];
g = groups[i];
updateGroupPointerResult = group_util_1.GroupUtil.updateGroupPointer(g.props, group);
if (!(updateGroupPointerResult.changes === true)) return [3, 12];
g.props = updateGroupPointerResult.props;
return [4, this.groupService.update(g)];
case 11:
updateResult = _k.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Group " +
("'" + g._id + "' with pointer '" + group._id + "'."));
}
_k.label = 12;
case 12:
_i++;
return [3, 10];
case 13: return [4, this.templateService.findAll()];
case 14:
templates = _k.sent();
_d = [];
for (_e in templates)
_d.push(_e);
_f = 0;
_k.label = 15;
case 15:
if (!(_f < _d.length)) return [3, 18];
i = _d[_f];
template = templates[i];
updateGroupPointerResult = group_util_1.GroupUtil.updateGroupPointer(template.entryTemplate, group);
if (!(updateGroupPointerResult.changes === true)) return [3, 17];
template.entryTemplate = updateGroupPointerResult.props;
return [4, this.templateService.update(template)];
case 16:
updateResult = _k.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Template " +
("'" + template._id + "' with pointer '" + group._id + "'."));
}
_k.label = 17;
case 17:
_f++;
return [3, 15];
case 18: return [4, this.widgetService.findAll()];
case 19:
widgets = _k.sent();
_g = [];
for (_h in widgets)
_g.push(_h);
_j = 0;
_k.label = 20;
case 20:
if (!(_j < _g.length)) return [3, 23];
i = _g[_j];
widget = widgets[i];
updateGroupPointerResult = group_util_1.GroupUtil.updateGroupPointer(widget.props, group);
if (!(updateGroupPointerResult.changes === true)) return [3, 22];
widget.props = updateGroupPointerResult.props;
return [4, this.widgetService.update(widget)];
case 21:
updateResult = _k.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Widget " +
("'" + widget._id + "' with pointer '" + group._id + "'."));
}
_k.label = 22;
case 22:
_j++;
return [3, 20];
case 23:
if (!(typeof request.body.changes !== 'undefined')) return [3, 25];
return [4, group_util_1.GroupUtil.updateEntriesWithNewGroupData(this.entryService, this.logger, request.body.changes.props, group._id.toHexString())];
case 24:
_k.sent();
_k.label = 25;
case 25: return [2, {
group: group,
}];
}
});
});
};
GroupController.prototype.deleteById = function (request) {
return __awaiter(this, void 0, void 0, function () {
var error, jwt, jwtValid, group, deleteGroupResult, groups, _a, _b, _i, i, oldLng, updateResult, templates, _c, _d, _e, i, oldLng, updateResult, widgets, _f, _g, _h, i, oldLng, updateResult;
return __generator(this, function (_j) {
switch (_j.label) {
case 0:
error = purple_cheetah_1.HttpErrorFactory.simple('deleteById', this.logger);
if (purple_cheetah_1.StringUtility.isIdValid(request.params.id) === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.FORBIDDEN, "Invalid ID '" + request.params.id + "' was provided.");
}
jwt = purple_cheetah_1.JWTEncoding.decode(request.headers.authorization);
if (jwt instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwt.message);
}
else {
jwtValid = purple_cheetah_1.JWTSecurity.validateAndCheckTokenPermissions(jwt, [purple_cheetah_1.RoleName.ADMIN, purple_cheetah_1.RoleName.USER], purple_cheetah_1.PermissionName.WRITE, purple_cheetah_1.JWTConfigService.get('user-token-config'));
if (jwtValid instanceof Error) {
throw error.occurred(purple_cheetah_1.HttpStatus.UNAUTHORIZED, jwtValid.message);
}
}
return [4, this.groupService.findById(request.params.id)];
case 1:
group = _j.sent();
if (group === null) {
throw error.occurred(purple_cheetah_1.HttpStatus.NOT_FOUNT, "Group with ID '" + request.params.id + "' does not exist");
}
return [4, this.groupService.deleteById(request.params.id)];
case 2:
deleteGroupResult = _j.sent();
if (deleteGroupResult === false) {
throw error.occurred(purple_cheetah_1.HttpStatus.INTERNAL_SERVER_ERROR, "Failed to remove Group from database.");
}
this.logger.info('delete', 'H1');
return [4, this.groupService.findAll()];
case 3:
groups = _j.sent();
_a = [];
for (_b in groups)
_a.push(_b);
_i = 0;
_j.label = 4;
case 4:
if (!(_i < _a.length)) return [3, 7];
i = _a[_i];
oldLng = groups[i].props.length;
groups[i].props = groups[i].props.filter(function (prop) {
if (prop.type === prop_interface_1.PropType.GROUP_POINTER) {
var value = prop.value;
if (value._id === group._id.toHexString()) {
return false;
}
}
return true;
});
if (!(oldLng !== groups[i].props.length)) return [3, 6];
return [4, this.groupService.update(groups[i])];
case 5:
updateResult = _j.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Group " +
("'" + groups[i]._id + "' with pointer '" + group._id + "'."));
}
_j.label = 6;
case 6:
_i++;
return [3, 4];
case 7:
this.logger.info('delete', 'H2');
return [4, this.templateService.findAll()];
case 8:
templates = _j.sent();
_c = [];
for (_d in templates)
_c.push(_d);
_e = 0;
_j.label = 9;
case 9:
if (!(_e < _c.length)) return [3, 12];
i = _c[_e];
oldLng = templates[i].entryTemplate.length;
templates[i].entryTemplate = templates[i].entryTemplate.filter(function (prop) {
if (prop.type === prop_interface_1.PropType.GROUP_POINTER) {
if (prop.value._id === group._id.toHexString()) {
return false;
}
}
return true;
});
if (!(oldLng !== templates[i].entryTemplate.length)) return [3, 11];
this.logger.info('delete', 'Update template');
return [4, this.templateService.update(templates[i])];
case 10:
updateResult = _j.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Template " +
("'" + templates[i]._id + "' with pointer '" + group._id + "'."));
}
_j.label = 11;
case 11:
_e++;
return [3, 9];
case 12:
this.logger.info('delete', 'H3');
return [4, this.widgetService.findAll()];
case 13:
widgets = _j.sent();
_f = [];
for (_g in widgets)
_f.push(_g);
_h = 0;
_j.label = 14;
case 14:
if (!(_h < _f.length)) return [3, 17];
i = _f[_h];
oldLng = widgets[i].props.length;
widgets[i].props = widgets[i].props.filter(function (prop) {
if (prop.type === prop_interface_1.PropType.GROUP_POINTER) {
if (prop.value._id === group._id.toHexString()) {
return false;
}
}
return true;
});
if (!(oldLng !== widgets[i].props.length)) return [3, 16];
return [4, this.widgetService.update(widgets[i])];
case 15:
updateResult = _j.sent();
if (updateResult === false) {
this.logger.error('update', "Failed to update Group Pointer in Widget " +
("'" + widgets[i]._id + "' with pointer '" + group._id + "'."));
}
_j.label = 16;
case 16:
_h++;
return [3, 14];
case 17: return [2, {
message: 'Success.',
}];
}
});
});
};
var GroupController_1;
__decorate([
purple_cheetah_1.AppLogger(GroupController_1),
__metadata("design:type", purple_cheetah_1.Logger)
], GroupController.prototype, "logger", void 0);
__decorate([
purple_cheetah_1.Service(group_service_1.GroupService),
__metadata("design:type", group_service_1.GroupService)
], GroupController.prototype, "groupService", void 0);
__decorate([
purple_cheetah_1.Service(template_service_1.TemplateService),
__metadata("design:type", template_service_1.TemplateService)
], GroupController.prototype, "templateService", void 0);
__decorate([
purple_cheetah_1.Service(widget_service_1.WidgetService),
__metadata("design:type", widget_service_1.WidgetService)
], GroupController.prototype, "widgetService", void 0);
__decorate([
purple_cheetah_1.Service(entry_1.EntryService),
__metadata("design:type", entry_1.EntryService)
], GroupController.prototype, "entryService", void 0);
__decorate([
purple_cheetah_1.Get('/all'),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], GroupController.prototype, "getAll", null);
__decorate([
purple_cheetah_1.Get('/:id'),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], GroupController.prototype, "getById", null);
__decorate([
purple_cheetah_1.Post(),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], GroupController.prototype, "add", null);
__decorate([
purple_cheetah_1.Put(),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], GroupController.prototype, "update", null);
__decorate([
purple_cheetah_1.Delete('/:id'),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", Promise)
], GroupController.prototype, "deleteById", null);
GroupController = GroupController_1 = __decorate([
purple_cheetah_1.Controller('/group')
], GroupController);
return GroupController;
}());
exports.GroupController = GroupController;
//# sourceMappingURL=group.controller.js.map