PeerTube/shared/utils/videos/video-playlists.ts

188 lines
4.6 KiB
TypeScript
Raw Normal View History

2019-02-26 09:55:40 +00:00
import { makeDeleteRequest, makeGetRequest, makePostBodyRequest, makePutBodyRequest, makeUploadRequest } from '../requests/requests'
import { VideoPlaylistCreate } from '../../models/videos/playlist/video-playlist-create.model'
import { omit } from 'lodash'
import { VideoPlaylistUpdate } from '../../models/videos/playlist/video-playlist-update.model'
import { VideoPlaylistElementCreate } from '../../models/videos/playlist/video-playlist-element-create.model'
import { VideoPlaylistElementUpdate } from '../../models/videos/playlist/video-playlist-element-update.model'
2019-01-29 07:37:25 +00:00
2019-02-26 09:55:40 +00:00
function getVideoPlaylistsList (url: string, start: number, count: number, sort?: string) {
const path = '/api/v1/video-playlists'
const query = {
start,
count,
sort
}
return makeGetRequest({
url,
path,
query
})
2019-01-29 07:37:25 +00:00
}
2019-02-26 09:55:40 +00:00
function getVideoPlaylist (url: string, playlistId: number | string, statusCodeExpected = 200) {
const path = '/api/v1/video-playlists/' + playlistId
return makeGetRequest({
url,
path,
statusCodeExpected
})
2019-01-29 07:37:25 +00:00
}
2019-02-28 10:14:26 +00:00
function deleteVideoPlaylist (url: string, token: string, playlistId: number | string, statusCodeExpected = 204) {
2019-02-26 09:55:40 +00:00
const path = '/api/v1/video-playlists/' + playlistId
return makeDeleteRequest({
url,
path,
token,
statusCodeExpected
})
2019-01-29 07:37:25 +00:00
}
2019-02-26 09:55:40 +00:00
function createVideoPlaylist (options: {
url: string,
token: string,
playlistAttrs: VideoPlaylistCreate,
2019-02-28 10:14:26 +00:00
expectedStatus?: number
2019-02-26 09:55:40 +00:00
}) {
const path = '/api/v1/video-playlists/'
const fields = omit(options.playlistAttrs, 'thumbnailfile')
2019-02-26 09:55:40 +00:00
const attaches = options.playlistAttrs.thumbnailfile
? { thumbnailfile: options.playlistAttrs.thumbnailfile }
: {}
2019-02-26 09:55:40 +00:00
return makeUploadRequest({
method: 'POST',
url: options.url,
path,
token: options.token,
fields,
attaches,
2019-02-28 10:14:26 +00:00
statusCodeExpected: options.expectedStatus || 200
2019-02-26 09:55:40 +00:00
})
}
2019-02-26 09:55:40 +00:00
function updateVideoPlaylist (options: {
url: string,
token: string,
playlistAttrs: VideoPlaylistUpdate,
2019-02-28 10:14:26 +00:00
playlistId: number | string,
expectedStatus?: number
2019-02-26 09:55:40 +00:00
}) {
2019-02-28 10:14:26 +00:00
const path = '/api/v1/video-playlists/' + options.playlistId
2019-02-26 09:55:40 +00:00
const fields = omit(options.playlistAttrs, 'thumbnailfile')
2019-02-26 09:55:40 +00:00
const attaches = options.playlistAttrs.thumbnailfile
? { thumbnailfile: options.playlistAttrs.thumbnailfile }
: {}
2019-02-26 09:55:40 +00:00
return makeUploadRequest({
method: 'PUT',
url: options.url,
path,
token: options.token,
fields,
attaches,
2019-02-28 10:14:26 +00:00
statusCodeExpected: options.expectedStatus || 204
2019-02-26 09:55:40 +00:00
})
}
function addVideoInPlaylist (options: {
url: string,
token: string,
playlistId: number | string,
elementAttrs: VideoPlaylistElementCreate
2019-02-28 10:14:26 +00:00
expectedStatus?: number
2019-02-26 09:55:40 +00:00
}) {
const path = '/api/v1/video-playlists/' + options.playlistId + '/videos'
return makePostBodyRequest({
url: options.url,
path,
token: options.token,
fields: options.elementAttrs,
2019-02-28 10:14:26 +00:00
statusCodeExpected: options.expectedStatus || 200
2019-02-26 09:55:40 +00:00
})
}
function updateVideoPlaylistElement (options: {
url: string,
token: string,
playlistId: number | string,
videoId: number | string,
elementAttrs: VideoPlaylistElementUpdate,
2019-02-28 10:14:26 +00:00
expectedStatus?: number
2019-02-26 09:55:40 +00:00
}) {
const path = '/api/v1/video-playlists/' + options.playlistId + '/videos/' + options.videoId
return makePutBodyRequest({
url: options.url,
path,
token: options.token,
fields: options.elementAttrs,
2019-02-28 10:14:26 +00:00
statusCodeExpected: options.expectedStatus || 204
2019-02-26 09:55:40 +00:00
})
}
function removeVideoFromPlaylist (options: {
url: string,
token: string,
playlistId: number | string,
videoId: number | string,
expectedStatus: number
}) {
const path = '/api/v1/video-playlists/' + options.playlistId + '/videos/' + options.videoId
return makeDeleteRequest({
url: options.url,
path,
token: options.token,
2019-02-28 10:14:26 +00:00
statusCodeExpected: options.expectedStatus || 204
2019-02-26 09:55:40 +00:00
})
}
function reorderVideosPlaylist (options: {
url: string,
token: string,
playlistId: number | string,
elementAttrs: {
startPosition: number,
2019-02-28 10:14:26 +00:00
insertAfterPosition: number,
2019-02-26 09:55:40 +00:00
reorderLength?: number
},
expectedStatus: number
}) {
2019-02-28 10:14:26 +00:00
const path = '/api/v1/video-playlists/' + options.playlistId + '/videos/reorder'
2019-02-26 09:55:40 +00:00
2019-02-28 10:14:26 +00:00
return makePostBodyRequest({
2019-02-26 09:55:40 +00:00
url: options.url,
path,
token: options.token,
fields: options.elementAttrs,
statusCodeExpected: options.expectedStatus
})
}
2019-01-29 07:37:25 +00:00
// ---------------------------------------------------------------------------
export {
2019-02-26 09:55:40 +00:00
getVideoPlaylistsList,
getVideoPlaylist,
createVideoPlaylist,
updateVideoPlaylist,
deleteVideoPlaylist,
addVideoInPlaylist,
2019-02-28 10:14:26 +00:00
updateVideoPlaylistElement,
2019-02-26 09:55:40 +00:00
removeVideoFromPlaylist,
reorderVideosPlaylist
2019-01-29 07:37:25 +00:00
}