import { Transaction } from 'sequelize'
-import { getServerAccount } from '../../helpers/utils'
-import { database as db } from '../../initializers'
-import { VideoChannelInstance } from '../../models/index'
-import { VideoInstance } from '../../models/video/video-interface'
-import { sendVideoAnnounce, sendVideoChannelAnnounce } from './send/send-announce'
+import { VideoPrivacy } from '../../../shared/models/videos'
+import { getServerActor } from '../../helpers/utils'
+import { VideoModel } from '../../models/video/video'
+import { VideoShareModel } from '../../models/video/video-share'
+import { sendVideoAnnounceToFollowers } from './send'
+import { getAnnounceActivityPubUrl } from './url'
-async function shareVideoChannelByServer (videoChannel: VideoChannelInstance, t: Transaction) {
- const serverAccount = await getServerAccount()
+async function shareVideoByServerAndChannel (video: VideoModel, t: Transaction) {
+ if (video.privacy === VideoPrivacy.PRIVATE) return undefined
- await db.VideoChannelShare.create({
- accountId: serverAccount.id,
- videoChannelId: videoChannel.id
- }, { transaction: t })
-
- return sendVideoChannelAnnounce(serverAccount, videoChannel, t)
-}
+ const serverActor = await getServerActor()
-async function shareVideoByServer (video: VideoInstance, 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 db.VideoShare.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 sendVideoAnnounce(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
}