This repository has been archived on 2025-06-18. You can view files and clone it, but you cannot make any changes to its state, such as pushing and creating new issues, pull requests or comments.
casino/frontend/src/app/service/auth.service.ts
Constantin Simonis db6bf4f199
Some checks failed
CI / Get Changed Files (pull_request) Successful in 10s
CI / Checkstyle Main (pull_request) Has been skipped
CI / Docker backend validation (pull_request) Successful in 14s
CI / oxlint (pull_request) Successful in 26s
CI / eslint (pull_request) Successful in 34s
CI / Docker frontend validation (pull_request) Successful in 47s
CI / prettier (pull_request) Failing after 23s
CI / test-build (pull_request) Successful in 32s
refactor(auth.service): remove unused imports and variables
2025-05-07 17:24:32 +02:00

94 lines
2.4 KiB
TypeScript

import { Injectable } from '@angular/core';
import { HttpClient } from '@angular/common/http';
import { BehaviorSubject, Observable, tap } from 'rxjs';
import { Router } from '@angular/router';
import { LoginRequest } from '../model/auth/LoginRequest';
import { RegisterRequest } from '../model/auth/RegisterRequest';
import { AuthResponse } from '../model/auth/AuthResponse';
import { User } from '../model/User';
import { environment } from '@environments/environment';
const TOKEN_KEY = 'token';
const USER_KEY = 'user';
@Injectable({
providedIn: 'root',
})
export class AuthService {
private authUrl = `${environment.apiUrl}/auth`;
private userUrl = `${environment.apiUrl}/users`;
userSubject: BehaviorSubject<User | null>;
constructor(
private http: HttpClient,
private router: Router
) {
this.userSubject = new BehaviorSubject<User | null>(this.getUserFromStorage());
if (this.getToken()) {
this.loadCurrentUser();
}
}
public get currentUserValue(): User | null {
return this.userSubject.value;
}
login(loginRequest: LoginRequest): Observable<AuthResponse> {
return this.http.post<AuthResponse>(`${this.authUrl}/login`, loginRequest).pipe(
tap((response) => {
this.setToken(response.token);
this.loadCurrentUser();
})
);
}
register(registerRequest: RegisterRequest): Observable<User> {
return this.http.post<User>(`${this.authUrl}/register`, registerRequest);
}
logout(): void {
localStorage.removeItem(TOKEN_KEY);
localStorage.removeItem(USER_KEY);
this.userSubject.next(null);
this.router.navigate(['/']);
}
isLoggedIn(): boolean {
return !!this.getToken();
}
getToken(): string | null {
return localStorage.getItem(TOKEN_KEY);
}
public loadCurrentUser(): void {
this.http.get<User>(`${this.userUrl}/me`).subscribe({
next: (user) => {
this.setUser(user);
},
error: () => {
this.logout();
},
});
}
private setToken(token: string): void {
localStorage.setItem(TOKEN_KEY, token);
}
private setUser(user: User): void {
localStorage.setItem(USER_KEY, JSON.stringify(user));
this.userSubject.next(user);
}
private getUserFromStorage(): User | null {
const user = localStorage.getItem(USER_KEY);
return user ? JSON.parse(user) : null;
}
getUser(): User | null {
return this.currentUserValue;
}
}