]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/+admin/system/logs/logs.service.ts
Merge branch 'release/2.1.0' into develop
[github/Chocobozzz/PeerTube.git] / client / src / app / +admin / system / logs / logs.service.ts
CommitLineData
2c22613c
C
1import { catchError, map } from 'rxjs/operators'
2import { HttpClient, HttpParams } from '@angular/common/http'
3import { Injectable } from '@angular/core'
4import { Observable } from 'rxjs'
5import { environment } from '../../../../environments/environment'
6import { RestExtractor, RestService } from '../../../shared'
7import { LogRow } from '@app/+admin/system/logs/log-row.model'
8import { LogLevel } from '@shared/models/server/log-level.type'
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,
17 private restService: RestService,
18 private restExtractor: RestExtractor
19 ) {}
20
566c125d
C
21 getLogs (options: {
22 isAuditLog: boolean,
23 startDate: string,
24 level?: LogLevel,
25 endDate?: string
26 }): Observable<any[]> {
27 const { isAuditLog, startDate } = options
28
2c22613c
C
29 let params = new HttpParams()
30 params = params.append('startDate', startDate)
2c22613c 31
566c125d
C
32 if (!isAuditLog) params = params.append('level', options.level)
33 if (options.endDate) params.append('endDate', options.endDate)
34
35 const path = isAuditLog
36 ? LogsService.BASE_AUDIT_LOG_URL
37 : LogsService.BASE_LOG_URL
2c22613c 38
566c125d 39 return this.authHttp.get<any[]>(path, { params })
2c22613c
C
40 .pipe(
41 map(rows => rows.map(r => new LogRow(r))),
42 catchError(err => this.restExtractor.handleError(err))
43 )
44 }
45}