]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/+admin/system/logs/logs.service.ts
Refactor log level choice
[github/Chocobozzz/PeerTube.git] / client / src / app / +admin / system / logs / logs.service.ts
CommitLineData
67ed6552 1import { Observable } from 'rxjs'
2c22613c
C
2import { catchError, map } from 'rxjs/operators'
3import { HttpClient, HttpParams } from '@angular/common/http'
4import { Injectable } from '@angular/core'
67ed6552
C
5import { RestExtractor } from '@app/core'
6import { LogLevel } from '@shared/models'
2c22613c 7import { environment } from '../../../../environments/environment'
67ed6552 8import { LogRow } from './log-row.model'
2c22613c
C
9
10@Injectable()
11export class LogsService {
5d79474c 12 private static BASE_LOG_URL = environment.apiUrl + '/api/v1/server/logs'
566c125d 13 private static BASE_AUDIT_LOG_URL = environment.apiUrl + '/api/v1/server/audit-logs'
2c22613c
C
14
15 constructor (
16 private authHttp: HttpClient,
2c22613c
C
17 private restExtractor: RestExtractor
18 ) {}
19
566c125d 20 getLogs (options: {
9df52d66
C
21 isAuditLog: boolean
22 startDate: string
23 level?: LogLevel
566c125d
C
24 endDate?: string
25 }): Observable<any[]> {
26 const { isAuditLog, startDate } = options
27
2c22613c
C
28 let params = new HttpParams()
29 params = params.append('startDate', startDate)
2c22613c 30
566c125d
C
31 if (!isAuditLog) params = params.append('level', options.level)
32 if (options.endDate) params.append('endDate', options.endDate)
33
34 const path = isAuditLog
35 ? LogsService.BASE_AUDIT_LOG_URL
36 : LogsService.BASE_LOG_URL
2c22613c 37
566c125d 38 return this.authHttp.get<any[]>(path, { params })
2c22613c
C
39 .pipe(
40 map(rows => rows.map(r => new LogRow(r))),
41 catchError(err => this.restExtractor.handleError(err))
42 )
43 }
44}