]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/core/rest/rest-extractor.service.ts
Remove unnecessary function
[github/Chocobozzz/PeerTube.git] / client / src / app / core / rest / rest-extractor.service.ts
CommitLineData
a51bad1a 1import { throwError as observableThrowError } from 'rxjs'
df98563e 2import { Injectable } from '@angular/core'
a51bad1a 3import { Router } from '@angular/router'
67ed6552 4import { dateToHuman } from '@app/helpers'
c0e8b12e 5import { HttpStatusCode, ResultList } from '@shared/models'
de59c48f
C
6
7@Injectable()
8export class RestExtractor {
9
66357162 10 constructor (private router: Router) { }
a51bad1a 11
9df52d66
C
12 applyToResultListData <T, A, U> (
13 result: ResultList<T>,
14 fun: (data: T, ...args: A[]) => U,
15 additionalArgs: A[] = []
16 ): ResultList<U> {
d592e0a9 17 const data: T[] = result.data
de59c48f 18
d592e0a9
C
19 return {
20 total: result.total,
9df52d66 21 data: data.map(d => fun.apply(this, [ d, ...additionalArgs ]))
d592e0a9 22 }
de59c48f
C
23 }
24
d592e0a9
C
25 convertResultListDateToHuman <T> (result: ResultList<T>, fieldsToConvert: string[] = [ 'createdAt' ]): ResultList<T> {
26 return this.applyToResultListData(result, this.convertDateToHuman, [ fieldsToConvert ])
de59c48f
C
27 }
28
9df52d66
C
29 convertDateToHuman (target: any, fieldsToConvert: string[]) {
30 fieldsToConvert.forEach(field => {
31 target[field] = dateToHuman(target[field])
32 })
bf68dd75 33
61bbc727 34 return target
d592e0a9 35 }
de59c48f 36
47f8de28 37 handleError (err: any) {
d592e0a9
C
38 let errorMessage
39
40 if (err.error instanceof Error) {
41 // A client-side or network error occurred. Handle it accordingly.
76148b27 42 errorMessage = err.error.detail || err.error.title
d592e0a9 43 console.error('An error occurred:', errorMessage)
47f8de28
C
44 } else if (typeof err.error === 'string') {
45 errorMessage = err.error
d592e0a9 46 } else if (err.status !== undefined) {
8376734e 47 // A server-side error occurred.
9df52d66 48 if (err.error?.errors) {
490b595a
C
49 const errors = err.error.errors
50 const errorsArray: string[] = []
51
52 Object.keys(errors).forEach(key => {
53 errorsArray.push(errors[key].msg)
54 })
55
56 errorMessage = errorsArray.join('. ')
9df52d66 57 } else if (err.error?.error) {
490b595a 58 errorMessage = err.error.error
f2eb23cd 59 } else if (err.status === HttpStatusCode.PAYLOAD_TOO_LARGE_413) {
9df52d66 60 // eslint-disable-next-line max-len
dc5bb5ce 61 errorMessage = $localize`Media is too large for the server. Please contact you administrator if you want to increase the limit size.`
f2eb23cd 62 } else if (err.status === HttpStatusCode.TOO_MANY_REQUESTS_429) {
490b595a
C
63 const secondsLeft = err.headers.get('retry-after')
64 if (secondsLeft) {
65 const minutesLeft = Math.floor(parseInt(secondsLeft, 10) / 60)
66357162 66 errorMessage = $localize`Too many attempts, please try again after ${minutesLeft} minutes.`
490b595a 67 } else {
66357162 68 errorMessage = $localize`Too many attempts, please try again later.`
490b595a 69 }
f2eb23cd 70 } else if (err.status === HttpStatusCode.INTERNAL_SERVER_ERROR_500) {
66357162 71 errorMessage = $localize`Server error. Please retry later.`
8376734e 72 }
13fb4de9 73
9df52d66 74 errorMessage = errorMessage || 'Unknown error.'
490b595a 75 console.error(`Backend returned code ${err.status}, errorMessage is: ${errorMessage}`)
d592e0a9 76 } else {
2f1548fd 77 console.error(err)
d592e0a9 78 errorMessage = err
df98563e 79 }
de59c48f 80
c199c427 81 const errorObj: { message: string, status: string, body: string } = {
bfb3a98f 82 message: errorMessage,
c9d6d155
C
83 status: undefined,
84 body: undefined
bfb3a98f
C
85 }
86
87 if (err.status) {
88 errorObj.status = err.status
c9d6d155 89 errorObj.body = err.error
bfb3a98f
C
90 }
91
1378c0d3 92 return observableThrowError(() => errorObj)
de59c48f 93 }
a51bad1a 94
ab398a05 95 redirectTo404IfNotFound (obj: { status: number }, type: 'video' | 'other', status = [ HttpStatusCode.NOT_FOUND_404 ]) {
9df52d66 96 if (obj?.status && status.includes(obj.status)) {
a51bad1a 97 // Do not use redirectService to avoid circular dependencies
ab398a05 98 this.router.navigate([ '/404' ], { state: { type, obj }, skipLocationChange: true })
a51bad1a
C
99 }
100
1378c0d3 101 return observableThrowError(() => obj)
a51bad1a 102 }
de59c48f 103}