X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Flib%2Fvideo-channel.ts;h=2fd63a8c4cfdac8e40f1435c4d4ec0f55264174f;hb=597f771f3f2bfe4b1e7234a5760e23f0283e2b29;hp=2241799737b8c80d97be7d44e4a0f2df4e9c8b07;hpb=72c7248b6fdcdb2175e726ff51b42e7555f2bd84;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/lib/video-channel.ts b/server/lib/video-channel.ts index 224179973..2fd63a8c4 100644 --- a/server/lib/video-channel.ts +++ b/server/lib/video-channel.ts @@ -1,42 +1,50 @@ import * as Sequelize from 'sequelize' - -import { addVideoChannelToFriends } from './friends' -import { database as db } from '../initializers' -import { AuthorInstance } from '../models' import { VideoChannelCreate } from '../../shared/models' +import { VideoModel } from '../models/video/video' +import { VideoChannelModel } from '../models/video/video-channel' +import { MAccountId, MChannelId } from '../types/models' +import { getLocalVideoChannelActivityPubUrl } from './activitypub/url' +import { federateVideoIfNeeded } from './activitypub/videos' +import { buildActorInstance } from './local-actor' + +async function createLocalVideoChannel (videoChannelInfo: VideoChannelCreate, account: MAccountId, t: Sequelize.Transaction) { + const url = getLocalVideoChannelActivityPubUrl(videoChannelInfo.name) + const actorInstance = buildActorInstance('Group', url, videoChannelInfo.name) -function createVideoChannel (videoChannelInfo: VideoChannelCreate, author: AuthorInstance, t: Sequelize.Transaction) { - let videoChannelUUID = '' + const actorInstanceCreated = await actorInstance.save({ transaction: t }) const videoChannelData = { - name: videoChannelInfo.name, + name: videoChannelInfo.displayName, description: videoChannelInfo.description, - remote: false, - authorId: author.id + support: videoChannelInfo.support, + accountId: account.id, + actorId: actorInstanceCreated.id } - const videoChannel = db.VideoChannel.build(videoChannelData) + const videoChannel = new VideoChannelModel(videoChannelData) + const options = { transaction: t } + const videoChannelCreated = await videoChannel.save(options) - return videoChannel.save(options) - .then(videoChannelCreated => { - // Do not forget to add Author information to the created video channel - videoChannelCreated.Author = author - videoChannelUUID = videoChannelCreated.uuid - - return videoChannelCreated - }) - .then(videoChannel => { - const remoteVideoChannel = videoChannel.toAddRemoteJSON() - - // Now we'll add the video channel's meta data to our friends - return addVideoChannelToFriends(remoteVideoChannel, t) - }) - .then(() => videoChannelUUID) // Return video channel UUID + videoChannelCreated.Actor = actorInstanceCreated + + // No need to send this empty video channel to followers + return videoChannelCreated +} + +async function federateAllVideosOfChannel (videoChannel: MChannelId) { + const videoIds = await VideoModel.getAllIdsFromChannel(videoChannel) + + for (const videoId of videoIds) { + const video = await VideoModel.loadAndPopulateAccountAndServerAndTags(videoId) + + await federateVideoIfNeeded(video, false) + } } // --------------------------------------------------------------------------- export { - createVideoChannel + createLocalVideoChannel, + federateAllVideosOfChannel }