Ajout d'une date d'expiration sur l'objet du

localStorage
This commit is contained in:
Sébastien André
2020-03-13 17:48:15 +01:00
parent 11d4127c20
commit e7a3d2c23f

View File

@@ -6,6 +6,7 @@ import { map } from 'rxjs/operators';
import { User } from '../models/user';
import { BaseService } from './base.service';
import { DateService } from './date.service';
@Injectable({
@@ -15,7 +16,7 @@ export class AuthenticationService extends BaseService {
private currentUserSubject: BehaviorSubject<User>;
public currentUser: Observable<User>;
constructor(private http: HttpClient) {
constructor(private http: HttpClient, private dateService: DateService) {
super();
this.currentUserSubject = new BehaviorSubject<User>(JSON.parse(localStorage.getItem('currentUser')));
@@ -23,6 +24,14 @@ export class AuthenticationService extends BaseService {
}
public get currentUserValue(): User {
const tmp = localStorage.getItem('currentUser');
if (tmp) {
const storedUser = JSON.parse(tmp);
if (new Date().getTime() > storedUser.expired) {
localStorage.removeItem('currentUser');
}
}
return this.currentUserSubject.value;
}
@@ -38,6 +47,8 @@ export class AuthenticationService extends BaseService {
.pipe(map(user => {
// store user details and basic auth credentials in local storage to keep user logged in between page refreshes
user.authdata = window.btoa(username + ':' + password);
user.expired = this.dateService.AddDays(new Date(), 1).getTime();
localStorage.setItem('currentUser', JSON.stringify(user));
this.currentUserSubject.next(user);
return user;