diff options
Diffstat (limited to 'client/src/app')
-rw-r--r-- | client/src/app/+videos/+video-edit/video-add-components/video-upload.component.ts | 67 |
1 files changed, 43 insertions, 24 deletions
diff --git a/client/src/app/+videos/+video-edit/video-add-components/video-upload.component.ts b/client/src/app/+videos/+video-edit/video-add-components/video-upload.component.ts index c4438d777..ec858c8a8 100644 --- a/client/src/app/+videos/+video-edit/video-add-components/video-upload.component.ts +++ b/client/src/app/+videos/+video-edit/video-add-components/video-upload.component.ts | |||
@@ -50,10 +50,11 @@ export class VideoUploadComponent extends VideoSend implements OnInit, OnDestroy | |||
50 | // So that it can be accessed in the template | 50 | // So that it can be accessed in the template |
51 | protected readonly BASE_VIDEO_UPLOAD_URL = VideoService.BASE_VIDEO_URL + '/upload-resumable' | 51 | protected readonly BASE_VIDEO_UPLOAD_URL = VideoService.BASE_VIDEO_URL + '/upload-resumable' |
52 | 52 | ||
53 | private uploadxOptions: UploadxOptions | ||
54 | private isUpdatingVideo = false | 53 | private isUpdatingVideo = false |
55 | private fileToUpload: File | 54 | private fileToUpload: File |
56 | 55 | ||
56 | private alreadyRefreshedToken = false | ||
57 | |||
57 | constructor ( | 58 | constructor ( |
58 | protected formValidatorService: FormValidatorService, | 59 | protected formValidatorService: FormValidatorService, |
59 | protected loadingBar: LoadingBarService, | 60 | protected loadingBar: LoadingBarService, |
@@ -68,26 +69,6 @@ export class VideoUploadComponent extends VideoSend implements OnInit, OnDestroy | |||
68 | private resumableUploadService: UploadxService | 69 | private resumableUploadService: UploadxService |
69 | ) { | 70 | ) { |
70 | super() | 71 | super() |
71 | |||
72 | // FIXME: https://github.com/Chocobozzz/PeerTube/issues/4382#issuecomment-915854167 | ||
73 | const chunkSize = isIOS() | ||
74 | ? 0 | ||
75 | : undefined // Auto chunk size | ||
76 | |||
77 | this.uploadxOptions = { | ||
78 | endpoint: this.BASE_VIDEO_UPLOAD_URL, | ||
79 | multiple: false, | ||
80 | token: this.authService.getAccessToken(), | ||
81 | uploaderClass: UploaderXFormData, | ||
82 | chunkSize, | ||
83 | retryConfig: { | ||
84 | maxAttempts: 30, // maximum attempts for 503 codes, otherwise set to 6, see below | ||
85 | maxDelay: 120_000, // 2 min | ||
86 | shouldRetry: (code: number, attempts: number) => { | ||
87 | return code === HttpStatusCode.SERVICE_UNAVAILABLE_503 || ((code < 400 || code > 500) && attempts < 6) | ||
88 | } | ||
89 | } | ||
90 | } | ||
91 | } | 72 | } |
92 | 73 | ||
93 | get videoExtensions () { | 74 | get videoExtensions () { |
@@ -135,6 +116,12 @@ export class VideoUploadComponent extends VideoSend implements OnInit, OnDestroy | |||
135 | onUploadVideoOngoing (state: UploadState) { | 116 | onUploadVideoOngoing (state: UploadState) { |
136 | switch (state.status) { | 117 | switch (state.status) { |
137 | case 'error': { | 118 | case 'error': { |
119 | if (!this.alreadyRefreshedToken && state.response.status === HttpStatusCode.UNAUTHORIZED_401) { | ||
120 | this.alreadyRefreshedToken = true | ||
121 | |||
122 | return this.refereshTokenAndRetryUpload() | ||
123 | } | ||
124 | |||
138 | const error = state.response?.error || 'Unknow error' | 125 | const error = state.response?.error || 'Unknow error' |
139 | 126 | ||
140 | this.handleUploadError({ | 127 | this.handleUploadError({ |
@@ -281,9 +268,9 @@ export class VideoUploadComponent extends VideoSend implements OnInit, OnDestroy | |||
281 | } | 268 | } |
282 | 269 | ||
283 | this.resumableUploadService.handleFiles(file, { | 270 | this.resumableUploadService.handleFiles(file, { |
284 | ...this.uploadxOptions, | 271 | ...this.getUploadxOptions(), |
285 | metadata, | 272 | |
286 | maxChunkSize: this.serverConfig.client.videos.resumableUpload.maxChunkSize | 273 | metadata |
287 | }) | 274 | }) |
288 | 275 | ||
289 | this.isUploadingVideo = true | 276 | this.isUploadingVideo = true |
@@ -378,4 +365,36 @@ export class VideoUploadComponent extends VideoSend implements OnInit, OnDestroy | |||
378 | 365 | ||
379 | return name | 366 | return name |
380 | } | 367 | } |
368 | |||
369 | private refereshTokenAndRetryUpload () { | ||
370 | this.authService.refreshAccessToken() | ||
371 | .subscribe(() => this.retryUpload()) | ||
372 | } | ||
373 | |||
374 | private getUploadxOptions (): UploadxOptions { | ||
375 | // FIXME: https://github.com/Chocobozzz/PeerTube/issues/4382#issuecomment-915854167 | ||
376 | const chunkSize = isIOS() | ||
377 | ? 0 | ||
378 | : undefined // Auto chunk size | ||
379 | |||
380 | return { | ||
381 | endpoint: this.BASE_VIDEO_UPLOAD_URL, | ||
382 | multiple: false, | ||
383 | |||
384 | maxChunkSize: this.serverConfig.client.videos.resumableUpload.maxChunkSize, | ||
385 | chunkSize, | ||
386 | |||
387 | token: this.authService.getAccessToken(), | ||
388 | |||
389 | uploaderClass: UploaderXFormData, | ||
390 | |||
391 | retryConfig: { | ||
392 | maxAttempts: 30, // maximum attempts for 503 codes, otherwise set to 6, see below | ||
393 | maxDelay: 120_000, // 2 min | ||
394 | shouldRetry: (code: number, attempts: number) => { | ||
395 | return code === HttpStatusCode.SERVICE_UNAVAILABLE_503 || ((code < 400 || code > 500) && attempts < 6) | ||
396 | } | ||
397 | } | ||
398 | } | ||
399 | } | ||
381 | } | 400 | } |