import * as Sequelize from 'sequelize'
import { ResultList } from '../../shared/models'
import { VideoCommentThreadTree } from '../../shared/models/videos/video-comment.model'
+import { AccountModel } from '../models/account/account'
import { VideoModel } from '../models/video/video'
import { VideoCommentModel } from '../models/video/video-comment'
-import { getVideoCommentActivityPubUrl, sendVideoRateChangeToFollowers } from './activitypub'
-import { sendCreateVideoCommentToOrigin, sendCreateVideoCommentToVideoFollowers } from './activitypub/send'
+import { getVideoCommentActivityPubUrl } from './activitypub'
+import { sendCreateVideoComment } from './activitypub/send'
async function createVideoComment (obj: {
text: string,
- inReplyToComment: VideoCommentModel,
+ inReplyToComment: VideoCommentModel | null,
video: VideoModel
- accountId: number
+ account: AccountModel
}, t: Sequelize.Transaction) {
- let originCommentId: number = null
+ let originCommentId: number | null = null
+ let inReplyToCommentId: number | null = null
- if (obj.inReplyToComment) {
+ if (obj.inReplyToComment && obj.inReplyToComment !== null) {
originCommentId = obj.inReplyToComment.originCommentId || obj.inReplyToComment.id
+ inReplyToCommentId = obj.inReplyToComment.id
}
const comment = await VideoCommentModel.create({
text: obj.text,
originCommentId,
- inReplyToCommentId: obj.inReplyToComment.id,
+ inReplyToCommentId,
videoId: obj.video.id,
- accountId: obj.accountId,
+ accountId: obj.account.id,
url: 'fake url'
}, { transaction: t, validate: false })
const savedComment = await comment.save({ transaction: t })
savedComment.InReplyToVideoComment = obj.inReplyToComment
savedComment.Video = obj.video
+ savedComment.Account = obj.account
- if (savedComment.Video.isOwned()) {
- await sendCreateVideoCommentToVideoFollowers(savedComment, t)
- } else {
- await sendCreateVideoCommentToOrigin(savedComment, t)
- }
+ await sendCreateVideoComment(savedComment, t)
return savedComment
}