Skip to content

Commit

Permalink
Bug fix for #77
Browse files Browse the repository at this point in the history
- Users will now be warned if their tokens are about to expire
- Users will be logged out upon token expiration
  • Loading branch information
limcaaarl committed Nov 12, 2024
1 parent c49d008 commit 78399a6
Show file tree
Hide file tree
Showing 3 changed files with 48 additions and 4 deletions.
35 changes: 35 additions & 0 deletions frontend/src/_services/authentication.service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import { map, switchMap } from 'rxjs/operators';
import { UServRes } from '../_models/user.service.model';
import { User } from '../_models/user.model';
import { ApiService } from './api.service';
import { ToastService } from './toast.service';

@Injectable({ providedIn: 'root' })
export class AuthenticationService extends ApiService {
Expand All @@ -18,6 +19,7 @@ export class AuthenticationService extends ApiService {
constructor(
private router: Router,
private http: HttpClient,
private toastService: ToastService,
) {
super();
const userData = localStorage.getItem('user');
Expand Down Expand Up @@ -53,6 +55,8 @@ export class AuthenticationService extends ApiService {
}
localStorage.setItem('user', JSON.stringify(user));
this.userSubject.next(user);
this.startTokenExpiryCheck();

return user;
}),
);
Expand Down Expand Up @@ -99,4 +103,35 @@ export class AuthenticationService extends ApiService {
}),
);
}
public startTokenExpiryCheck(): void {
const tokenExpirationTime = this.getTokenExpiration();

if (!tokenExpirationTime) {
this.logout();
return;
}

const oneMinute = 60 * 1000;
const checkInterval = oneMinute;

setInterval(() => {
const now = Date.now();
const timeLeft = tokenExpirationTime - now;

if (timeLeft <= 0) {
this.toastService.showToast('Your session has expired. Please log in again.');
this.logout();
} else if (timeLeft < 5 * oneMinute) {
this.toastService.showToast('Your session will expire in less than 5 minutes. Please log in again');
}
}, checkInterval);
}

private getTokenExpiration() {
const user = this.userValue;
if (!user || !user.accessToken) return null;

const tokenPayload = JSON.parse(atob(user.accessToken.split('.')[1]));
return tokenPayload.exp ? tokenPayload.exp * 1000 : null;
}
}
1 change: 1 addition & 0 deletions frontend/src/app/app.component.html
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
<main>
<app-navigation-bar />
<p-toast></p-toast>
<router-outlet />
</main>
16 changes: 12 additions & 4 deletions frontend/src/app/app.component.ts
Original file line number Diff line number Diff line change
@@ -1,16 +1,24 @@
import { Component } from '@angular/core';
import { Component, OnInit } from '@angular/core';
import { RouterOutlet } from '@angular/router';
import { ButtonModule } from 'primeng/button';
import { PasswordModule } from 'primeng/password';
import { ToastModule } from 'primeng/toast';
import { NavigationBarComponent } from './navigation-bar/navigation-bar.component';

import { AuthenticationService } from '../_services/authentication.service';
import { MessageService } from 'primeng/api';
@Component({
selector: 'app-root',
standalone: true,
imports: [NavigationBarComponent, RouterOutlet, ButtonModule, PasswordModule],
imports: [NavigationBarComponent, RouterOutlet, ButtonModule, PasswordModule, ToastModule],
providers: [MessageService],
templateUrl: './app.component.html',
styleUrl: './app.component.css',
})
export class AppComponent {
export class AppComponent implements OnInit {
title = 'frontend';

constructor(private authService: AuthenticationService) {}
ngOnInit() {
this.authService.startTokenExpiryCheck();
}
}

0 comments on commit 78399a6

Please sign in to comment.