]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/shared/rest/rest-extractor.service.ts
autofocus first field on login
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / rest / rest-extractor.service.ts
CommitLineData
a51bad1a 1import { throwError as observableThrowError } from 'rxjs'
df98563e 2import { Injectable } from '@angular/core'
61bbc727 3import { dateToHuman } from '@app/shared/misc/utils'
d592e0a9 4import { ResultList } from '../../../../../shared'
a51bad1a 5import { Router } from '@angular/router'
b1d40cff 6import { I18n } from '@ngx-translate/i18n-polyfill'
de59c48f
C
7
8@Injectable()
9export class RestExtractor {
10
b1d40cff
C
11 constructor (
12 private router: Router,
13 private i18n: I18n
14 ) {
a51bad1a
C
15 // empty
16 }
17
d592e0a9 18 extractDataBool () {
df98563e 19 return true
de59c48f
C
20 }
21
d592e0a9
C
22 applyToResultListData <T> (result: ResultList<T>, fun: Function, additionalArgs?: any[]): ResultList<T> {
23 const data: T[] = result.data
24 const newData: T[] = []
de59c48f 25
61bbc727 26 data.forEach(d => newData.push(fun.apply(this, [ d ].concat(additionalArgs))))
de59c48f 27
d592e0a9
C
28 return {
29 total: result.total,
30 data: newData
31 }
de59c48f
C
32 }
33
d592e0a9
C
34 convertResultListDateToHuman <T> (result: ResultList<T>, fieldsToConvert: string[] = [ 'createdAt' ]): ResultList<T> {
35 return this.applyToResultListData(result, this.convertDateToHuman, [ fieldsToConvert ])
de59c48f
C
36 }
37
d592e0a9 38 convertDateToHuman (target: object, fieldsToConvert: string[]) {
61bbc727 39 fieldsToConvert.forEach(field => target[field] = dateToHuman(target[field]))
bf68dd75 40
61bbc727 41 return target
d592e0a9 42 }
de59c48f 43
47f8de28 44 handleError (err: any) {
d592e0a9
C
45 let errorMessage
46
47 if (err.error instanceof Error) {
48 // A client-side or network error occurred. Handle it accordingly.
49 errorMessage = err.error.message
50 console.error('An error occurred:', errorMessage)
47f8de28
C
51 } else if (typeof err.error === 'string') {
52 errorMessage = err.error
d592e0a9 53 } else if (err.status !== undefined) {
8376734e 54 // A server-side error occurred.
490b595a
C
55 if (err.error && err.error.errors) {
56 const errors = err.error.errors
57 const errorsArray: string[] = []
58
59 Object.keys(errors).forEach(key => {
60 errorsArray.push(errors[key].msg)
61 })
62
63 errorMessage = errorsArray.join('. ')
64 } else if (err.error && err.error.error) {
65 errorMessage = err.error.error
13fb4de9 66 } else if (err.status === 413) {
b1d40cff
C
67 errorMessage = this.i18n(
68 'Request is too large for the server. Please contact you administrator if you want to increase the limit size.'
69 )
490b595a
C
70 } else if (err.status === 429) {
71 const secondsLeft = err.headers.get('retry-after')
72 if (secondsLeft) {
73 const minutesLeft = Math.floor(parseInt(secondsLeft, 10) / 60)
25acef90 74 errorMessage = this.i18n('Too many attempts, please try again after {{minutesLeft}} minutes.', { minutesLeft })
490b595a 75 } else {
b1d40cff 76 errorMessage = this.i18n('Too many attempts, please try again later.')
490b595a
C
77 }
78 } else if (err.status === 500) {
b1d40cff 79 errorMessage = this.i18n('Server error. Please retry later.')
8376734e 80 }
13fb4de9 81
8376734e 82 errorMessage = errorMessage ? errorMessage : 'Unknown error.'
490b595a 83 console.error(`Backend returned code ${err.status}, errorMessage is: ${errorMessage}`)
d592e0a9
C
84 } else {
85 errorMessage = err
df98563e 86 }
de59c48f 87
bfb3a98f
C
88 const errorObj = {
89 message: errorMessage,
c9d6d155
C
90 status: undefined,
91 body: undefined
bfb3a98f
C
92 }
93
94 if (err.status) {
95 errorObj.status = err.status
c9d6d155 96 errorObj.body = err.error
bfb3a98f
C
97 }
98
13359203 99 return observableThrowError(errorObj)
de59c48f 100 }
a51bad1a
C
101
102 redirectTo404IfNotFound (obj: { status: number }, status = [ 404 ]) {
103 if (obj && obj.status && status.indexOf(obj.status) !== -1) {
104 // Do not use redirectService to avoid circular dependencies
105 this.router.navigate([ '/404' ], { skipLocationChange: true })
106 }
107
108 return observableThrowError(obj)
109 }
de59c48f 110}