]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - shared/extra-utils/server/jobs.ts
Fix webtorrent player
[github/Chocobozzz/PeerTube.git] / shared / extra-utils / server / jobs.ts
CommitLineData
5cd80545 1import * as request from 'supertest'
d4681c00 2import { Job, JobState } from '../../models'
d175a6f7 3import { wait } from '../miscs/miscs'
bc22d608 4import { ServerInfo } from './servers'
2284f202 5import { inspect } from 'util'
5cd80545 6
94a5ff8a
C
7function getJobsList (url: string, accessToken: string, state: JobState) {
8 const path = '/api/v1/jobs/' + state
5cd80545
C
9
10 return request(url)
11 .get(path)
12 .set('Accept', 'application/json')
13 .set('Authorization', 'Bearer ' + accessToken)
14 .expect(200)
15 .expect('Content-Type', /json/)
16}
17
94a5ff8a
C
18function getJobsListPaginationAndSort (url: string, accessToken: string, state: JobState, start: number, count: number, sort: string) {
19 const path = '/api/v1/jobs/' + state
5cd80545
C
20
21 return request(url)
22 .get(path)
23 .query({ start })
24 .query({ count })
25 .query({ sort })
26 .set('Accept', 'application/json')
27 .set('Authorization', 'Bearer ' + accessToken)
28 .expect(200)
29 .expect('Content-Type', /json/)
30}
31
3cd0734f 32async function waitJobs (serversArg: ServerInfo[] | ServerInfo) {
2f1548fd 33 const pendingJobWait = process.env.NODE_PENDING_JOB_WAIT ? parseInt(process.env.NODE_PENDING_JOB_WAIT, 10) : 2000
3cd0734f
C
34 let servers: ServerInfo[]
35
36 if (Array.isArray(serversArg) === false) servers = [ serversArg as ServerInfo ]
37 else servers = serversArg as ServerInfo[]
38
94831479 39 const states: JobState[] = [ 'waiting', 'active', 'delayed' ]
cef534ed 40 let pendingRequests = false
3cd0734f 41
cef534ed
C
42 function tasksBuilder () {
43 const tasks: Promise<any>[] = []
3cd0734f
C
44 pendingRequests = false
45
46 // Check if each server has pending request
47 for (const server of servers) {
48 for (const state of states) {
49 const p = getJobsListPaginationAndSort(server.url, server.accessToken, state, 0, 10, '-createdAt')
6b616860
C
50 .then(res => res.body.data)
51 .then((jobs: Job[]) => jobs.filter(j => j.type !== 'videos-views'))
52 .then(jobs => {
2284f202
C
53 if (jobs.length !== 0) {
54 pendingRequests = true
55 }
3cd0734f
C
56 })
57 tasks.push(p)
58 }
59 }
60
cef534ed
C
61 return tasks
62 }
63
64 do {
65 await Promise.all(tasksBuilder())
3cd0734f
C
66
67 // Retry, in case of new jobs were created
68 if (pendingRequests === false) {
2f1548fd 69 await wait(pendingJobWait)
cef534ed 70 await Promise.all(tasksBuilder())
3cd0734f
C
71 }
72
73 if (pendingRequests) {
74 await wait(1000)
75 }
76 } while (pendingRequests)
77}
78
5cd80545
C
79// ---------------------------------------------------------------------------
80
81export {
82 getJobsList,
3cd0734f 83 waitJobs,
5cd80545
C
84 getJobsListPaginationAndSort
85}