You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Hydro/hydro/handler/manage.js

129 lines
3.6 KiB
JavaScript

const user = require('../model/user');
const { Route, Handler } = require('../service/server');
const { PERM_MANAGE } = require('../permission');
5 years ago
const { RoleAlreadyExistError, ValidationError } = require('../error');
class ManageHandler extends Handler {
async prepare() {
this.checkPerm(PERM_MANAGE);
5 years ago
this.system = await user.getById(0);
}
}
class ManageMainHandler extends ManageHandler {
async get() {
this.response.redirect = '/manage/dashboard';
}
}
class ManageDashboardHandler extends ManageHandler {
async get() {
this.response.template = 'domain_manage_dashboard.html';
5 years ago
this.response.body = { system: this.system };
}
}
class ManageEditHandler extends ManageHandler {
async get() {
this.response.template = 'domain_manage_edit.html';
5 years ago
this.response.body = { system: this.system };
}
5 years ago
async post({ uname, gravatar, bio }) {
const unameLower = uname.trim().toLowerCase();
await user.setById(0, {
uname, unameLower, gravatar, bio,
});
this.back();
}
}
class ManageUserHandler extends ManageHandler {
async get() {
const uids = [];
const rudocs = {};
const [udocs, roles, system] = await Promise.all([
user.getMulti({ role: { $ne: 'default' } }).toArray(),
user.getRoles(),
user.getById(0),
]);
for (const role of roles) rudocs[role._id] = [];
for (const udoc of udocs) {
uids.push(udoc._id);
rudocs[udoc.role].push(udoc);
}
const rolesSelect = roles.map((role) => [role._id, role._id]);
const udict = await user.getList(uids);
this.response.template = 'domain_manage_user.html';
this.response.body = {
roles, rolesSelect, rudocs, udict, system,
};
}
async postSetUser({ uid, role }) {
await user.setById(uid, { role });
this.back();
}
}
class ManagePermissionHandler extends ManageHandler {
async get() {
const [roles, system] = await Promise.all([
user.getRoles(),
user.getById(0),
]);
this.response.template = 'domain_manage_permission.html';
this.response.body = { roles, system };
}
async post({ roles }) {
for (const role of roles) {
let perms = '';
for (const perm of roles) {
perms += perm;
}
roles[role] = perms;
}
await user.setRoles(roles);
this.back();
}
}
class ManageRoleHandler extends ManageHandler {
async get() {
const [roles, system] = await Promise.all([
user.getRoles(),
user.getById(0),
]);
this.response.template = 'domain_manage_role.html';
this.response.body = { roles, system };
}
async postAdd({ role }) {
const [r, u] = await Promise.all([
user.getRole(role),
user.getRole('default'),
]);
5 years ago
if (r) throw new RoleAlreadyExistError(role);
await user.addRole(role, u.perm);
this.back();
}
5 years ago
async postDelete({ roles }) {
for (const role of roles) {
if (['root', 'default', 'guest'].includes(role)) {
5 years ago
throw new ValidationError('role');
}
}
await user.deleteRoles(roles);
this.back();
}
}
Route('/manage', ManageMainHandler);
Route('/manage/dashboard', ManageDashboardHandler);
Route('/manage/edit', ManageEditHandler);
Route('/manage/user', ManageUserHandler);
Route('/manage/permission', ManagePermissionHandler);
Route('/manage/role', ManageRoleHandler);