1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/backend/routes/UserRouter.ts

97 lines
2.4 KiB
TypeScript
Raw Normal View History

2018-03-30 15:30:30 -04:00
import {UserMWs} from '../middlewares/user/UserMWs';
2018-11-28 23:49:33 +01:00
import {Express} from 'express';
2018-03-30 15:30:30 -04:00
import {UserRoles} from '../../common/entities/UserDTO';
import {AuthenticationMWs} from '../middlewares/user/AuthenticationMWs';
import {UserRequestConstrainsMWs} from '../middlewares/user/UserRequestConstrainsMWs';
import {RenderingMWs} from '../middlewares/RenderingMWs';
2016-05-09 17:04:56 +02:00
export class UserRouter {
2018-11-28 23:49:33 +01:00
public static route(app: Express) {
this.addLogin(app);
this.addLogout(app);
this.addGetSessionUser(app);
this.addChangePassword(app);
this.addCreateUser(app);
this.addDeleteUser(app);
this.addListUsers(app);
this.addChangeRole(app);
}
2018-11-28 23:49:33 +01:00
private static addLogin(app: Express) {
2018-03-30 15:30:30 -04:00
app.post('/api/user/login',
AuthenticationMWs.inverseAuthenticate,
AuthenticationMWs.login,
RenderingMWs.renderSessionUser
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addLogout(app: Express) {
2018-03-30 15:30:30 -04:00
app.post('/api/user/logout',
AuthenticationMWs.logout,
RenderingMWs.renderOK
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addGetSessionUser(app: Express) {
2018-03-30 15:30:30 -04:00
app.get('/api/user/login',
AuthenticationMWs.authenticate,
RenderingMWs.renderSessionUser
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addChangePassword(app: Express) {
2018-03-30 15:30:30 -04:00
app.post('/api/user/:id/password',
AuthenticationMWs.authenticate,
UserRequestConstrainsMWs.forceSelfRequest,
UserMWs.changePassword,
RenderingMWs.renderOK
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addCreateUser(app: Express) {
2018-03-30 15:30:30 -04:00
app.put('/api/user',
AuthenticationMWs.authenticate,
AuthenticationMWs.authorise(UserRoles.Admin),
UserMWs.createUser,
RenderingMWs.renderOK
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addDeleteUser(app: Express) {
2018-03-30 15:30:30 -04:00
app.delete('/api/user/:id',
AuthenticationMWs.authenticate,
AuthenticationMWs.authorise(UserRoles.Admin),
UserRequestConstrainsMWs.notSelfRequest,
UserMWs.deleteUser,
RenderingMWs.renderOK
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addListUsers(app: Express) {
2018-03-30 15:30:30 -04:00
app.get('/api/user/list',
AuthenticationMWs.authenticate,
AuthenticationMWs.authorise(UserRoles.Admin),
UserMWs.listUsers,
RenderingMWs.renderResult
);
2018-03-30 15:30:30 -04:00
}
2018-11-28 23:49:33 +01:00
private static addChangeRole(app: Express) {
2018-03-30 15:30:30 -04:00
app.post('/api/user/:id/role',
AuthenticationMWs.authenticate,
AuthenticationMWs.authorise(UserRoles.Admin),
UserRequestConstrainsMWs.notSelfRequestOr2Admins,
UserMWs.changeRole,
RenderingMWs.renderOK
);
2018-03-30 15:30:30 -04:00
}
}