Ajout d'une date d'expiration sur l'objet du
localStorage
This commit is contained in:
@@ -6,6 +6,7 @@ import { map } from 'rxjs/operators';
|
|||||||
|
|
||||||
import { User } from '../models/user';
|
import { User } from '../models/user';
|
||||||
import { BaseService } from './base.service';
|
import { BaseService } from './base.service';
|
||||||
|
import { DateService } from './date.service';
|
||||||
|
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
@@ -15,7 +16,7 @@ export class AuthenticationService extends BaseService {
|
|||||||
private currentUserSubject: BehaviorSubject<User>;
|
private currentUserSubject: BehaviorSubject<User>;
|
||||||
public currentUser: Observable<User>;
|
public currentUser: Observable<User>;
|
||||||
|
|
||||||
constructor(private http: HttpClient) {
|
constructor(private http: HttpClient, private dateService: DateService) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
this.currentUserSubject = new BehaviorSubject<User>(JSON.parse(localStorage.getItem('currentUser')));
|
this.currentUserSubject = new BehaviorSubject<User>(JSON.parse(localStorage.getItem('currentUser')));
|
||||||
@@ -23,6 +24,14 @@ export class AuthenticationService extends BaseService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public get currentUserValue(): User {
|
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;
|
return this.currentUserSubject.value;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -38,6 +47,8 @@ export class AuthenticationService extends BaseService {
|
|||||||
.pipe(map(user => {
|
.pipe(map(user => {
|
||||||
// store user details and basic auth credentials in local storage to keep user logged in between page refreshes
|
// 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.authdata = window.btoa(username + ':' + password);
|
||||||
|
user.expired = this.dateService.AddDays(new Date(), 1).getTime();
|
||||||
|
|
||||||
localStorage.setItem('currentUser', JSON.stringify(user));
|
localStorage.setItem('currentUser', JSON.stringify(user));
|
||||||
this.currentUserSubject.next(user);
|
this.currentUserSubject.next(user);
|
||||||
return user;
|
return user;
|
||||||
|
|||||||
Reference in New Issue
Block a user