argos/dmp-frontend/src/app/core/services/auth/auth.service.ts

149 lines
4.9 KiB
TypeScript
Raw Normal View History

2019-09-23 10:17:03 +02:00
import {of as observableOf, throwError as observableThrowError, Observable } from 'rxjs';
import {map, catchError, takeUntil } from 'rxjs/operators';
2018-11-27 15:13:56 +01:00
import { HttpClient, HttpHeaders } from '@angular/common/http';
2017-12-14 11:41:26 +01:00
import { Injectable } from '@angular/core';
2019-09-23 10:17:03 +02:00
import { MatSnackBar } from '@angular/material/snack-bar';
2017-12-14 11:41:26 +01:00
import { Router } from '@angular/router';
2018-11-27 15:13:56 +01:00
import { TranslateService } from '@ngx-translate/core';
2019-01-18 18:03:45 +01:00
import { environment } from '../../../../environments/environment';
import { SnackBarNotificationComponent } from '../../../library/notification/snack-bar/snack-bar-notification.component';
import { BaseService } from '../../common/base/base.service';
import { Credential } from '../../model/auth/credential';
import { LoginInfo } from '../../model/auth/login-info';
import { Principal } from '../../model/auth/Principal';
2019-02-15 10:18:14 +01:00
import { UiNotificationService, SnackBarNotificationLevel } from '../notification/ui-notification-service';
2019-01-18 18:03:45 +01:00
2017-12-14 11:41:26 +01:00
@Injectable()
2018-11-27 18:33:17 +01:00
export class AuthService extends BaseService {
2018-10-05 17:00:54 +02:00
private actionUrl: string;
private headers: HttpHeaders;
constructor(
private http: HttpClient,
2019-02-15 10:18:14 +01:00
private snackBar: MatSnackBar,
private language: TranslateService,
private router: Router,
private uiNotificationService: UiNotificationService
2018-10-05 17:00:54 +02:00
) {
2018-11-27 18:33:17 +01:00
super();
2018-11-27 15:13:56 +01:00
this.actionUrl = environment.Server + 'auth/';
2018-10-05 17:00:54 +02:00
this.headers = new HttpHeaders();
this.headers = this.headers.set('Content-Type', 'application/json');
this.headers = this.headers.set('Accept', 'application/json');
}
private clear(): void {
localStorage.removeItem('principal');
}
public current(principal?: Principal): Principal {
if (principal) {
localStorage.setItem('principal', JSON.stringify(principal));
return principal;
}
const principalJson = localStorage.getItem('principal');
if (!principalJson) { return null; }
const principalObj = JSON.parse(principalJson) as Principal;
return principalObj;
}
//public login(credential: Credential): Observable<Principal> {
// const url = this.actionUrl + 'login';
// return this.http.post(url, credential, { headers: this.headers })
// .map((res: Response) => {
// let principal = this.current(new JsonSerializer<Principal>().fromJSONObject(res, Principal));
// //this.loginContextSubject.next(true);
// return principal;
// })
// .catch((error: any) => {
// //this.loginContextSubject.next(false);
// return Observable.throw(error);
// });
//}
public login(loginInfo: LoginInfo): Observable<Principal> {
const url = this.actionUrl + 'externallogin';
2019-09-23 10:17:03 +02:00
return this.http.post(url, loginInfo, { headers: this.headers }).pipe(
map((res: any) => {
2019-01-18 18:03:45 +01:00
const principal = this.current(res.payload);
2018-10-05 17:00:54 +02:00
//this.loginContextSubject.next(true);
return principal;
2019-09-23 10:17:03 +02:00
}),
catchError((error: any) => {
2018-10-05 17:00:54 +02:00
//this.loginContextSubject.next(false);
2019-09-23 10:17:03 +02:00
return observableThrowError(error);
}),);
2018-10-05 17:00:54 +02:00
}
public nativeLogin(credentials: Credential): Observable<Principal> {
const url = this.actionUrl + 'nativelogin';
2019-09-23 10:17:03 +02:00
return this.http.post(url, credentials, { headers: this.headers }).pipe(
map((res: any) => {
2019-01-18 18:03:45 +01:00
const principal = this.current(res.payload);
2018-10-05 17:00:54 +02:00
//this.loginContextSubject.next(true);
return principal;
2019-09-23 10:17:03 +02:00
}),
catchError((error: any) => {
2018-10-05 17:00:54 +02:00
//this.loginContextSubject.next(false);
2019-09-23 10:17:03 +02:00
return observableThrowError(error);
}),);
2018-10-05 17:00:54 +02:00
}
public logout(): void {
const url = this.actionUrl + 'logout';
const principal = this.current();
this.clear();
if (!principal) { return; }
let headers = this.headers;
headers = headers.set('AuthToken', principal.token);
2018-11-27 18:33:17 +01:00
this.http.post(url, null, { headers: headers })
.pipe(takeUntil(this._destroyed))
.subscribe(
res => this.onLogOutSuccess(res),
error => this.onLogOutError(error)
);
2018-10-05 17:00:54 +02:00
}
public me(): Observable<Principal> {
const url = this.actionUrl + '/me';
const principal = this.current();
if (!principal) {
this.clear();
2019-09-23 10:17:03 +02:00
return observableOf<Principal>();
2018-10-05 17:00:54 +02:00
}
let headers = this.headers;
headers = headers.set('AuthToken', principal.token);
2019-09-23 10:17:03 +02:00
return this.http.post(url, null, { headers: headers }).pipe(
map((res: any) => {
2019-01-18 18:03:45 +01:00
const princ = this.current(res.payload);
2018-10-05 17:00:54 +02:00
return princ;
2019-09-23 10:17:03 +02:00
}),
catchError((error: any) => {
//console.warn('could not retrieve me info:\n', error);
2018-10-05 17:00:54 +02:00
this.clear();
const princ = this.current();
this.router.navigate(['/login']);
2019-09-23 10:17:03 +02:00
return observableOf<Principal>(princ);
}),);
2018-10-05 17:00:54 +02:00
}
public onLogOutSuccess(logoutMessage: any) {
2019-02-15 10:18:14 +01:00
this.uiNotificationService.snackBarNotification(this.language.instant('GENERAL.SNACK-BAR.SUCCESSFUL-LOGOUT'), SnackBarNotificationLevel.Success);
2018-10-05 17:00:54 +02:00
this.router.navigate(['/login']);
}
public onLogOutError(errorMessage: string) {
2019-02-15 10:18:14 +01:00
this.uiNotificationService.snackBarNotification(this.language.instant('GENERAL.SNACK-BAR.UNSUCCESSFUL-LOGOUT'), SnackBarNotificationLevel.Error);
2018-10-05 17:00:54 +02:00
this.router.navigate(['/login']);
}
2017-12-14 11:41:26 +01:00
}