1
0
Fork 0
peertube/shared/extra-utils/videos/video-channels.ts

169 lines
4.5 KiB
TypeScript
Raw Normal View History

2020-01-31 10:56:52 -05:00
/* eslint-disable @typescript-eslint/no-floating-promises */
2017-10-24 13:41:30 -04:00
import * as request from 'supertest'
import { VideoChannelUpdate } from '../../models/videos/channel/video-channel-update.model'
import { VideoChannelCreate } from '../../models/videos/channel/video-channel-create.model'
import { makeGetRequest, updateAvatarRequest } from '../requests/requests'
import { ServerInfo } from '../server/servers'
import { User } from '../../models/users/user.model'
import { getMyUserInformation } from '../users/users'
import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes'
2017-10-24 13:41:30 -04:00
2020-03-27 17:26:39 -04:00
function getVideoChannelsList (url: string, start: number, count: number, sort?: string, withStats?: boolean) {
2018-04-24 11:05:32 -04:00
const path = '/api/v1/video-channels'
2017-10-24 13:41:30 -04:00
const req = request(url)
.get(path)
.query({ start: start })
.query({ count: count })
if (sort) req.query({ sort })
2020-03-27 17:26:39 -04:00
if (withStats) req.query({ withStats })
2017-10-24 13:41:30 -04:00
return req.set('Accept', 'application/json')
.expect(HttpStatusCode.OK_200)
2017-10-24 13:41:30 -04:00
.expect('Content-Type', /json/)
}
function getAccountVideoChannelsList (parameters: {
2020-01-31 10:56:52 -05:00
url: string
accountName: string
start?: number
count?: number
sort?: string
specialStatus?: HttpStatusCode
2020-03-27 17:26:39 -04:00
withStats?: boolean
search?: string
}) {
const {
url,
accountName,
start,
count,
sort = 'createdAt',
specialStatus = HttpStatusCode.OK_200,
withStats = false,
search
} = parameters
2018-05-25 03:57:16 -04:00
const path = '/api/v1/accounts/' + accountName + '/video-channels'
2017-10-24 13:41:30 -04:00
return makeGetRequest({
url,
path,
query: {
start,
count,
2020-03-27 17:26:39 -04:00
sort,
withStats,
search
},
statusCodeExpected: specialStatus
})
2017-10-24 13:41:30 -04:00
}
2018-04-24 11:05:32 -04:00
function addVideoChannel (
url: string,
token: string,
2018-04-26 10:11:38 -04:00
videoChannelAttributesArg: VideoChannelCreate,
expectedStatus = HttpStatusCode.OK_200
2018-04-24 11:05:32 -04:00
) {
const path = '/api/v1/video-channels/'
2017-10-24 13:41:30 -04:00
// Default attributes
let attributes = {
2018-04-26 10:11:38 -04:00
displayName: 'my super video channel',
description: 'my super channel description',
support: 'my super channel support'
2017-10-24 13:41:30 -04:00
}
attributes = Object.assign(attributes, videoChannelAttributesArg)
return request(url)
.post(path)
.send(attributes)
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + token)
.expect(expectedStatus)
}
2018-04-24 11:05:32 -04:00
function updateVideoChannel (
url: string,
token: string,
2018-08-24 05:04:02 -04:00
channelName: string,
2018-04-26 10:11:38 -04:00
attributes: VideoChannelUpdate,
expectedStatus = HttpStatusCode.NO_CONTENT_204
2018-04-24 11:05:32 -04:00
) {
const body: any = {}
2018-08-24 05:04:02 -04:00
const path = '/api/v1/video-channels/' + channelName
2017-10-24 13:41:30 -04:00
if (attributes.displayName) body.displayName = attributes.displayName
if (attributes.description) body.description = attributes.description
if (attributes.support) body.support = attributes.support
if (attributes.bulkVideosSupportUpdate) body.bulkVideosSupportUpdate = attributes.bulkVideosSupportUpdate
2017-10-24 13:41:30 -04:00
return request(url)
.put(path)
.send(body)
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + token)
.expect(expectedStatus)
}
function deleteVideoChannel (url: string, token: string, channelName: string, expectedStatus = HttpStatusCode.NO_CONTENT_204) {
2018-08-24 05:04:02 -04:00
const path = '/api/v1/video-channels/' + channelName
2017-10-24 13:41:30 -04:00
return request(url)
2018-04-24 11:05:32 -04:00
.delete(path)
2017-10-24 13:41:30 -04:00
.set('Accept', 'application/json')
.set('Authorization', 'Bearer ' + token)
.expect(expectedStatus)
}
2018-08-24 05:04:02 -04:00
function getVideoChannel (url: string, channelName: string) {
const path = '/api/v1/video-channels/' + channelName
2017-10-24 13:41:30 -04:00
return request(url)
.get(path)
.set('Accept', 'application/json')
.expect(HttpStatusCode.OK_200)
2017-10-24 13:41:30 -04:00
.expect('Content-Type', /json/)
}
function updateVideoChannelAvatar (options: {
2020-01-31 10:56:52 -05:00
url: string
accessToken: string
fixture: string
2018-08-17 09:45:42 -04:00
videoChannelName: string | number
}) {
2018-08-17 09:45:42 -04:00
const path = '/api/v1/video-channels/' + options.videoChannelName + '/avatar/pick'
return updateAvatarRequest(Object.assign(options, { path }))
}
2019-03-05 04:58:44 -05:00
function setDefaultVideoChannel (servers: ServerInfo[]) {
const tasks: Promise<any>[] = []
for (const server of servers) {
const p = getMyUserInformation(server.url, server.accessToken)
2020-01-31 10:56:52 -05:00
.then(res => { server.videoChannel = (res.body as User).videoChannels[0] })
2019-03-05 04:58:44 -05:00
tasks.push(p)
}
return Promise.all(tasks)
}
2017-10-24 13:41:30 -04:00
// ---------------------------------------------------------------------------
export {
updateVideoChannelAvatar,
2017-10-24 13:41:30 -04:00
getVideoChannelsList,
2017-11-17 06:05:59 -05:00
getAccountVideoChannelsList,
2017-10-24 13:41:30 -04:00
addVideoChannel,
updateVideoChannel,
deleteVideoChannel,
2019-03-05 04:58:44 -05:00
getVideoChannel,
setDefaultVideoChannel
2017-10-24 13:41:30 -04:00
}