import { Transaction } from 'sequelize'
-import { getServerAccount } from '../../helpers'
+import { VideoPrivacy } from '../../../shared/models/videos'
+import { getServerActor } from '../../helpers/utils'
import { VideoModel } from '../../models/video/video'
-import { VideoChannelModel } from '../../models/video/video-channel'
-import { VideoChannelShareModel } from '../../models/video/video-channel-share'
import { VideoShareModel } from '../../models/video/video-share'
-import { sendVideoAnnounceToFollowers, sendVideoChannelAnnounceToFollowers } from './send'
+import { sendVideoAnnounceToFollowers } from './send'
+import { getAnnounceActivityPubUrl } from './url'
-async function shareVideoChannelByServer (videoChannel: VideoChannelModel, t: Transaction) {
- const serverAccount = await getServerAccount()
+async function shareVideoByServerAndChannel (video: VideoModel, t: Transaction) {
+ if (video.privacy === VideoPrivacy.PRIVATE) return undefined
- await VideoChannelShareModel.create({
- accountId: serverAccount.id,
- videoChannelId: videoChannel.id
- }, { transaction: t })
-
- return sendVideoChannelAnnounceToFollowers(serverAccount, videoChannel, t)
-}
+ const serverActor = await getServerActor()
-async function shareVideoByServer (video: VideoModel, t: Transaction) {
- const serverAccount = await getServerAccount()
+ const serverShareUrl = getAnnounceActivityPubUrl(video.url, serverActor)
+ const serverSharePromise = VideoShareModel.create({
+ actorId: serverActor.id,
+ videoId: video.id,
+ url: serverShareUrl
+ }, { transaction: t })
- await VideoShareModel.create({
- accountId: serverAccount.id,
- videoId: video.id
+ const videoChannelShareUrl = getAnnounceActivityPubUrl(video.url, video.VideoChannel.Actor)
+ const videoChannelSharePromise = VideoShareModel.create({
+ actorId: video.VideoChannel.actorId,
+ videoId: video.id,
+ url: videoChannelShareUrl
}, { transaction: t })
- return sendVideoAnnounceToFollowers(serverAccount, video, t)
+ const [ serverShare, videoChannelShare ] = await Promise.all([
+ serverSharePromise,
+ videoChannelSharePromise
+ ])
+
+ return Promise.all([
+ sendVideoAnnounceToFollowers(serverActor, videoChannelShare, video, t),
+ sendVideoAnnounceToFollowers(serverActor, serverShare, video, t)
+ ])
}
export {
- shareVideoChannelByServer,
- shareVideoByServer
+ shareVideoByServerAndChannel
}