]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/+admin/system/logs/logs.service.ts
Add ability for client to create server logs
[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'
64553e88 5import { RestExtractor, RestService } from '@app/core'
42b40636 6import { ServerLogLevel } 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,
64553e88 17 private restService: RestService,
2c22613c
C
18 private restExtractor: RestExtractor
19 ) {}
20
566c125d 21 getLogs (options: {
9df52d66
C
22 isAuditLog: boolean
23 startDate: string
64553e88 24 tagsOneOf?: string[]
42b40636 25 level?: ServerLogLevel
566c125d
C
26 endDate?: string
27 }): Observable<any[]> {
64553e88 28 const { isAuditLog, startDate, endDate, tagsOneOf } = options
566c125d 29
2c22613c
C
30 let params = new HttpParams()
31 params = params.append('startDate', startDate)
2c22613c 32
566c125d 33 if (!isAuditLog) params = params.append('level', options.level)
64553e88
C
34 if (endDate) params = params.append('endDate', options.endDate)
35 if (tagsOneOf) params = this.restService.addArrayParams(params, 'tagsOneOf', tagsOneOf)
566c125d
C
36
37 const path = isAuditLog
38 ? LogsService.BASE_AUDIT_LOG_URL
39 : LogsService.BASE_LOG_URL
2c22613c 40
566c125d 41 return this.authHttp.get<any[]>(path, { params })
2c22613c
C
42 .pipe(
43 map(rows => rows.map(r => new LogRow(r))),
44 catchError(err => this.restExtractor.handleError(err))
45 )
46 }
47}