X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=server%2Flib%2Fvideo-channel.ts;h=9f7ed929738c56d7f915cb59d70279b5afd6debd;hb=e3bb78a2134a5e5755b6dbd8987894572ca31269;hp=5bb1814ea902bd19fe067be97dcc27284fd97413;hpb=79d5caf994edd87ad721994490f10677be277497;p=oweals%2Fpeertube.git diff --git a/server/lib/video-channel.ts b/server/lib/video-channel.ts index 5bb1814ea..9f7ed9297 100644 --- a/server/lib/video-channel.ts +++ b/server/lib/video-channel.ts @@ -1,47 +1,41 @@ import * as Sequelize from 'sequelize' +import * as uuidv4 from 'uuid/v4' import { VideoChannelCreate } from '../../shared/models' -import { logger } from '../helpers' -import { getActivityPubUrl } from '../helpers/activitypub' -import { database as db } from '../initializers' -import { AccountInstance } from '../models' +import { AccountModel } from '../models/account/account' +import { VideoChannelModel } from '../models/video/video-channel' +import { buildActorInstance, getVideoChannelActivityPubUrl } from './activitypub' + +async function createVideoChannel (videoChannelInfo: VideoChannelCreate, account: AccountModel, t: Sequelize.Transaction) { + const uuid = uuidv4() + const url = getVideoChannelActivityPubUrl(uuid) + // We use the name as uuid + const actorInstance = buildActorInstance('Group', url, uuid, uuid) + + const actorInstanceCreated = await actorInstance.save({ transaction: t }) -async function createVideoChannel (videoChannelInfo: VideoChannelCreate, account: AccountInstance, t: Sequelize.Transaction) { const videoChannelData = { name: videoChannelInfo.name, description: videoChannelInfo.description, - remote: false, - accountId: account.id + support: videoChannelInfo.support, + accountId: account.id, + actorId: actorInstanceCreated.id } - const videoChannel = db.VideoChannel.build(videoChannelData) - videoChannel.set('url', getActivityPubUrl('videoChannel', videoChannel.uuid)) + const videoChannel = VideoChannelModel.build(videoChannelData) const options = { transaction: t } - const videoChannelCreated = await videoChannel.save(options) - // Do not forget to add Account information to the created video channel + // Do not forget to add Account/Actor information to the created video channel videoChannelCreated.Account = account + videoChannelCreated.Actor = actorInstanceCreated // No need to seed this empty video channel to followers return videoChannelCreated } -async function fetchVideoChannelByHostAndUUID (serverHost: string, uuid: string, t: Sequelize.Transaction) { - try { - const videoChannel = await db.VideoChannel.loadByHostAndUUID(serverHost, uuid, t) - if (!videoChannel) throw new Error('Video channel not found') - - return videoChannel - } catch (err) { - logger.error('Cannot load video channel from host and uuid.', { error: err.stack, serverHost, uuid }) - throw err - } -} - // --------------------------------------------------------------------------- export { - createVideoChannel, - fetchVideoChannelByHostAndUUID + createVideoChannel }