-import { makePutBodyRequest } from '../requests/requests'
+import { makeDeleteRequest, makeGetRequest, makePostBodyRequest, makePutBodyRequest } from '../requests/requests'
+import { VideoRedundanciesTarget } from '@shared/models'
+import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
-async function updateRedundancy (url: string, accessToken: string, host: string, redundancyAllowed: boolean, expectedStatus = 204) {
+function updateRedundancy (
+ url: string,
+ accessToken: string,
+ host: string,
+ redundancyAllowed: boolean,
+ expectedStatus = HttpStatusCode.NO_CONTENT_204
+) {
const path = '/api/v1/server/redundancy/' + host
return makePutBodyRequest({
})
}
+function listVideoRedundancies (options: {
+ url: string
+ accessToken: string
+ target: VideoRedundanciesTarget
+ start?: number
+ count?: number
+ sort?: string
+ statusCodeExpected?: HttpStatusCode
+}) {
+ const path = '/api/v1/server/redundancy/videos'
+
+ const { url, accessToken, target, statusCodeExpected, start, count, sort } = options
+
+ return makeGetRequest({
+ url,
+ token: accessToken,
+ path,
+ query: {
+ start: start ?? 0,
+ count: count ?? 5,
+ sort: sort ?? 'name',
+ target
+ },
+ statusCodeExpected: statusCodeExpected || HttpStatusCode.OK_200
+ })
+}
+
+function addVideoRedundancy (options: {
+ url: string
+ accessToken: string
+ videoId: number
+}) {
+ const path = '/api/v1/server/redundancy/videos'
+ const { url, accessToken, videoId } = options
+
+ return makePostBodyRequest({
+ url,
+ token: accessToken,
+ path,
+ fields: { videoId },
+ statusCodeExpected: HttpStatusCode.NO_CONTENT_204
+ })
+}
+
+function removeVideoRedundancy (options: {
+ url: string
+ accessToken: string
+ redundancyId: number
+}) {
+ const { url, accessToken, redundancyId } = options
+ const path = '/api/v1/server/redundancy/videos/' + redundancyId
+
+ return makeDeleteRequest({
+ url,
+ token: accessToken,
+ path,
+ statusCodeExpected: HttpStatusCode.NO_CONTENT_204
+ })
+}
+
export {
- updateRedundancy
+ updateRedundancy,
+ listVideoRedundancies,
+ addVideoRedundancy,
+ removeVideoRedundancy
}