2021-06-17 16:02:38 +02:00
|
|
|
import { VideoPlaylistModel } from '@server/models/video/video-playlist'
|
|
|
|
import { MVideoPlaylistFullSummary } from '@server/types/models'
|
|
|
|
import { APObject } from '@shared/models'
|
2022-03-23 14:24:50 +01:00
|
|
|
import { getAPId } from '../activity'
|
2021-06-17 16:02:38 +02:00
|
|
|
import { createOrUpdateVideoPlaylist } from './create-update'
|
|
|
|
import { scheduleRefreshIfNeeded } from './refresh'
|
|
|
|
import { fetchRemoteVideoPlaylist } from './shared'
|
|
|
|
|
|
|
|
async function getOrCreateAPVideoPlaylist (playlistObjectArg: APObject): Promise<MVideoPlaylistFullSummary> {
|
|
|
|
const playlistUrl = getAPId(playlistObjectArg)
|
|
|
|
|
|
|
|
const playlistFromDatabase = await VideoPlaylistModel.loadByUrlWithAccountAndChannelSummary(playlistUrl)
|
|
|
|
|
|
|
|
if (playlistFromDatabase) {
|
|
|
|
scheduleRefreshIfNeeded(playlistFromDatabase)
|
|
|
|
|
|
|
|
return playlistFromDatabase
|
|
|
|
}
|
|
|
|
|
|
|
|
const { playlistObject } = await fetchRemoteVideoPlaylist(playlistUrl)
|
|
|
|
if (!playlistObject) throw new Error('Cannot fetch remote playlist with url: ' + playlistUrl)
|
|
|
|
|
2021-10-20 15:01:17 +02:00
|
|
|
// playlistUrl is just an alias/redirection, so process object id instead
|
2021-06-17 16:02:38 +02:00
|
|
|
if (playlistObject.id !== playlistUrl) return getOrCreateAPVideoPlaylist(playlistObject)
|
|
|
|
|
|
|
|
const playlistCreated = await createOrUpdateVideoPlaylist(playlistObject)
|
|
|
|
|
|
|
|
return playlistCreated
|
|
|
|
}
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
|
|
|
|
export {
|
|
|
|
getOrCreateAPVideoPlaylist
|
|
|
|
}
|