2018-03-30 15:30:30 -04:00
|
|
|
import {UserDTO, UserRoles} from '../../../common/entities/UserDTO';
|
|
|
|
import {IUserManager} from '../interfaces/IUserManager';
|
|
|
|
import {ProjectPath} from '../../ProjectPath';
|
|
|
|
import {Utils} from '../../../common/Utils';
|
|
|
|
import * as path from 'path';
|
|
|
|
import * as fs from 'fs';
|
|
|
|
import {PasswordHelper} from '../PasswordHelper';
|
2016-07-07 12:19:08 +02:00
|
|
|
|
|
|
|
|
2016-05-09 17:04:56 +02:00
|
|
|
export class UserManager implements IUserManager {
|
2017-07-25 23:39:50 +02:00
|
|
|
private db: { users?: UserDTO[], idCounter?: number } = {};
|
2018-11-28 23:49:33 +01:00
|
|
|
private readonly dbPath: string;
|
2016-07-07 12:19:08 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
generateId(): string {
|
|
|
|
function s4() {
|
|
|
|
return Math.floor((1 + Math.random()) * 0x10000)
|
|
|
|
.toString(16)
|
|
|
|
.substring(1);
|
2016-07-07 12:19:08 +02:00
|
|
|
}
|
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
return s4() + s4() + s4() + s4();
|
|
|
|
}
|
2016-07-07 12:19:08 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
constructor() {
|
2017-07-25 23:39:50 +02:00
|
|
|
this.dbPath = path.join(ProjectPath.Root, 'users.db');
|
|
|
|
if (fs.existsSync(this.dbPath)) {
|
|
|
|
this.loadDB();
|
|
|
|
}
|
2016-07-07 12:19:08 +02:00
|
|
|
|
2017-07-25 23:39:50 +02:00
|
|
|
if (!this.db.idCounter) {
|
|
|
|
this.db.idCounter = 1;
|
2016-07-07 12:19:08 +02:00
|
|
|
}
|
2016-04-22 13:23:44 +02:00
|
|
|
|
2017-07-25 23:39:50 +02:00
|
|
|
if (!this.db.users) {
|
|
|
|
this.db.users = [];
|
2018-05-12 12:19:51 -04:00
|
|
|
// TODO: remove defaults
|
2018-03-30 15:30:30 -04:00
|
|
|
this.createUser(<UserDTO>{name: 'admin', password: 'admin', role: UserRoles.Admin});
|
2016-04-22 13:23:44 +02:00
|
|
|
}
|
2017-07-25 23:39:50 +02:00
|
|
|
this.saveDB();
|
2016-07-07 12:19:08 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|
2016-07-07 12:19:08 +02:00
|
|
|
|
2016-04-22 13:23:44 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
public async findOne(filter: any) {
|
|
|
|
const result = await this.find(filter);
|
2016-04-22 13:23:44 +02:00
|
|
|
|
2018-05-12 12:19:51 -04:00
|
|
|
if (result.length === 0) {
|
|
|
|
throw new Error('UserDTO not found');
|
2016-04-22 13:23:44 +02:00
|
|
|
}
|
2017-07-03 19:17:49 +02:00
|
|
|
return result[0];
|
|
|
|
}
|
|
|
|
|
|
|
|
public async find(filter: any) {
|
2018-05-12 12:19:51 -04:00
|
|
|
const pass = filter.password;
|
2017-07-09 22:36:25 +02:00
|
|
|
delete filter.password;
|
2017-07-25 23:39:50 +02:00
|
|
|
const users = this.db.users.slice();
|
2017-07-10 18:08:39 +02:00
|
|
|
let i = users.length;
|
|
|
|
while (i--) {
|
2017-07-11 09:01:59 +02:00
|
|
|
if (pass && !(PasswordHelper.comparePassword(pass, users[i].password))) {
|
2017-07-10 18:08:39 +02:00
|
|
|
users.splice(i, 1);
|
|
|
|
continue;
|
2017-07-09 22:36:25 +02:00
|
|
|
}
|
2018-05-12 12:19:51 -04:00
|
|
|
if (Utils.equalsFilter(users[i], filter) === false) {
|
2017-07-10 18:08:39 +02:00
|
|
|
users.splice(i, 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return users;
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public async createUser(user: UserDTO) {
|
2017-07-25 23:39:50 +02:00
|
|
|
user.id = this.db.idCounter++;
|
2017-07-11 09:01:59 +02:00
|
|
|
user.password = PasswordHelper.cryptPassword(user.password);
|
2017-07-25 23:39:50 +02:00
|
|
|
this.db.users.push(user);
|
|
|
|
this.saveDB();
|
2017-07-03 19:17:49 +02:00
|
|
|
return user;
|
|
|
|
}
|
|
|
|
|
2017-07-25 23:39:50 +02:00
|
|
|
public async deleteUser(id: number) {
|
2018-05-12 12:19:51 -04:00
|
|
|
const deleted = this.db.users.filter((u: UserDTO) => u.id === id);
|
|
|
|
this.db.users = this.db.users.filter((u: UserDTO) => u.id !== id);
|
2017-07-25 23:39:50 +02:00
|
|
|
this.saveDB();
|
2017-07-03 19:17:49 +02:00
|
|
|
if (deleted.length > 0) {
|
|
|
|
return deleted[0];
|
2016-04-22 13:23:44 +02:00
|
|
|
}
|
2017-07-03 19:17:49 +02:00
|
|
|
return null;
|
|
|
|
}
|
2016-05-09 17:04:56 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
public async changeRole(id: number, newRole: UserRoles): Promise<UserDTO> {
|
2017-07-25 23:39:50 +02:00
|
|
|
for (let i = 0; i < this.db.users.length; i++) {
|
2018-05-12 12:19:51 -04:00
|
|
|
if (this.db.users[i].id === id) {
|
2017-07-25 23:39:50 +02:00
|
|
|
this.db.users[i].role = newRole;
|
|
|
|
this.saveDB();
|
|
|
|
return this.db.users[i];
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|
2016-04-22 13:23:44 +02:00
|
|
|
}
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|
2016-05-09 17:04:56 +02:00
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
public async changePassword(request: any) {
|
2018-05-12 12:19:51 -04:00
|
|
|
throw new Error('not implemented'); // TODO: implement
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|
2016-04-22 13:23:44 +02:00
|
|
|
|
2017-07-25 23:39:50 +02:00
|
|
|
private loadDB() {
|
|
|
|
const data = fs.readFileSync(this.dbPath, 'utf8');
|
|
|
|
this.db = JSON.parse(data);
|
|
|
|
}
|
|
|
|
|
|
|
|
private saveDB() {
|
|
|
|
fs.writeFileSync(this.dbPath, JSON.stringify(this.db));
|
|
|
|
}
|
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
}
|