1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/model/network/authentication.service.ts

85 lines
2.5 KiB
TypeScript
Raw Normal View History

2016-05-09 23:04:56 +08:00
import {Injectable} from "@angular/core";
2016-12-27 23:09:47 +08:00
import {UserDTO, UserRoles} from "../../../../common/entities/UserDTO";
import {Event} from "../../../../common/event/Event";
2016-12-27 06:36:38 +08:00
import {UserService} from "./user.service";
import {LoginCredential} from "../../../../common/entities/LoginCredential";
import {Message} from "../../../../common/entities/Message";
2016-12-27 06:36:38 +08:00
import {Cookie} from "ng2-cookies";
2016-05-05 00:34:54 +08:00
import {ErrorCodes} from "../../../../common/entities/Error";
import {Config} from "../../config/Config";
2016-03-13 18:28:29 +08:00
2016-05-09 23:04:56 +08:00
declare module ServerInject {
2016-12-27 23:09:47 +08:00
export let user: UserDTO;
}
2016-03-13 18:28:29 +08:00
@Injectable()
2016-05-09 23:04:56 +08:00
export class AuthenticationService {
2016-03-13 18:28:29 +08:00
2016-12-27 23:09:47 +08:00
private _user: UserDTO = null;
public OnUserChanged: Event<UserDTO>;
2016-03-13 18:28:29 +08:00
2016-12-27 06:36:38 +08:00
constructor(private _userService: UserService) {
2016-05-17 05:15:03 +08:00
this.OnUserChanged = new Event();
//picking up session..
2016-05-26 15:44:13 +08:00
if (this.isAuthenticated() == false && Cookie.get('pigallery2-session') != null) {
2016-05-09 23:04:56 +08:00
if (typeof ServerInject !== "undefined" && typeof ServerInject.user !== "undefined") {
this.setUser(ServerInject.user);
}
2016-05-09 23:04:56 +08:00
this.getSessionUser();
2016-12-27 06:36:38 +08:00
} else {
this.OnUserChanged.trigger(this._user);
}
2016-05-09 23:04:56 +08:00
}
2016-05-09 23:04:56 +08:00
private getSessionUser() {
2016-12-27 23:09:47 +08:00
this._userService.getSessionUser().then((message: Message<UserDTO>) => {
2016-05-09 23:04:56 +08:00
if (message.error) {
console.log(message.error);
2016-05-09 23:04:56 +08:00
} else {
this._user = message.result;
2016-05-17 05:15:03 +08:00
this.OnUserChanged.trigger(this._user);
}
});
2016-03-13 18:28:29 +08:00
}
2016-12-27 23:09:47 +08:00
private setUser(user: UserDTO) {
2016-05-05 04:20:54 +08:00
this._user = user;
2016-05-17 05:15:03 +08:00
this.OnUserChanged.trigger(this._user);
2016-05-05 04:20:54 +08:00
}
2016-12-27 06:36:38 +08:00
public login(credential: LoginCredential) {
2016-12-27 23:09:47 +08:00
return this._userService.login(credential).then((message: Message<UserDTO>) => {
2016-05-09 23:04:56 +08:00
if (message.error) {
2016-12-27 06:36:38 +08:00
console.log(ErrorCodes[message.error.code] + ", message: ", message.error.message);
2016-05-09 23:04:56 +08:00
} else {
this.setUser(message.result);
}
return message;
});
}
2016-05-05 04:20:54 +08:00
2016-03-13 18:28:29 +08:00
2016-12-27 06:36:38 +08:00
public isAuthenticated(): boolean {
if (Config.Client.authenticationRequired === false) {
return true;
}
2016-12-27 06:36:38 +08:00
return !!(this._user && this._user != null);
2016-03-13 18:28:29 +08:00
}
2016-05-09 23:04:56 +08:00
public getUser() {
if (Config.Client.authenticationRequired === false) {
2016-12-27 23:09:47 +08:00
return <UserDTO>{name: "", password: "", role: UserRoles.Admin};
}
return this._user;
}
2016-03-13 18:28:29 +08:00
2016-05-17 05:15:03 +08:00
public logout() {
this._userService.logout();
this.setUser(null);
}
2016-03-13 18:28:29 +08:00
}