From 9b925712cbdedacdf8af947e929ca3975b56e3fa Mon Sep 17 00:00:00 2001 From: Danijel Andjelkovic Date: Sat, 5 Mar 2022 19:46:16 +0100 Subject: Added auth and auth guard services, included ngx-cookie-service and angular-jwt. Made a configuration file. --- frontend/src/app/auth.service.ts | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) (limited to 'frontend/src/app/auth.service.ts') diff --git a/frontend/src/app/auth.service.ts b/frontend/src/app/auth.service.ts index af27fdec..29dca31d 100644 --- a/frontend/src/app/auth.service.ts +++ b/frontend/src/app/auth.service.ts @@ -1,9 +1,31 @@ import { Injectable } from '@angular/core'; +import { HttpClient, HttpHeaders } from '@angular/common/http'; +import { JwtHelperService } from '@auth0/angular-jwt'; +import { CookieService } from 'ngx-cookie-service'; +import { API_SETTINGS } from 'src/config'; + +const jwtHelper = new JwtHelperService(); @Injectable({ providedIn: 'root' }) export class AuthService { - constructor() { } + constructor(private http: HttpClient, private cookie: CookieService) { } + + login(username: string, password: string) { + return this.http.post(`${API_SETTINGS.apiURL}/login`, { username, password }); + } + + register(username: string, password: string) { + return this.http.post(`${API_SETTINGS.apiURL}/register`, { username, password }); + } + + isAuthenticated(): boolean { + if (this.cookie.check('token')) { + var token = this.cookie.get('token'); + return !jwtHelper.isTokenExpired(token); + } + return false; + } } -- cgit v1.2.3