]>
Commit | Line | Data |
---|---|---|
4d4e5cd4 | 1 | import * as express from 'express' |
65fcc311 | 2 | import { parallel } from 'async' |
d3cd34be | 3 | |
65fcc311 | 4 | import { |
69818c93 | 5 | BaseRequestScheduler, |
65fcc311 C |
6 | getRequestScheduler, |
7 | getRequestVideoQaduScheduler, | |
8 | getRequestVideoEventScheduler | |
9 | } from '../../lib' | |
10 | import { authenticate, ensureIsAdmin } from '../../middlewares' | |
d3cd34be | 11 | |
65fcc311 | 12 | const requestsRouter = express.Router() |
d3cd34be | 13 | |
65fcc311 C |
14 | requestsRouter.get('/stats', |
15 | authenticate, | |
16 | ensureIsAdmin, | |
d3cd34be C |
17 | getStatsRequests |
18 | ) | |
19 | ||
20 | // --------------------------------------------------------------------------- | |
21 | ||
65fcc311 C |
22 | export { |
23 | requestsRouter | |
24 | } | |
d3cd34be C |
25 | |
26 | // --------------------------------------------------------------------------- | |
27 | ||
69818c93 | 28 | function getStatsRequests (req: express.Request, res: express.Response, next: express.NextFunction) { |
99fdec46 | 29 | parallel({ |
65fcc311 C |
30 | requestScheduler: buildRequestSchedulerFunction(getRequestScheduler()), |
31 | requestVideoQaduScheduler: buildRequestSchedulerFunction(getRequestVideoQaduScheduler()), | |
32 | requestVideoEventScheduler: buildRequestSchedulerFunction(getRequestVideoEventScheduler()) | |
99fdec46 | 33 | }, function (err, result) { |
d3cd34be C |
34 | if (err) return next(err) |
35 | ||
99fdec46 | 36 | return res.json(result) |
d3cd34be C |
37 | }) |
38 | } | |
99fdec46 C |
39 | |
40 | // --------------------------------------------------------------------------- | |
41 | ||
69818c93 | 42 | function buildRequestSchedulerFunction (requestScheduler: BaseRequestScheduler) { |
99fdec46 C |
43 | return function (callback) { |
44 | requestScheduler.remainingRequestsCount(function (err, count) { | |
45 | if (err) return callback(err) | |
46 | ||
47 | const result = { | |
48 | totalRequests: count, | |
49 | requestsLimitPods: requestScheduler.limitPods, | |
50 | requestsLimitPerPod: requestScheduler.limitPerPod, | |
51 | remainingMilliSeconds: requestScheduler.remainingMilliSeconds(), | |
52 | milliSecondsInterval: requestScheduler.requestInterval | |
53 | } | |
54 | ||
55 | return callback(null, result) | |
56 | }) | |
57 | } | |
58 | } |