import * as express from 'express'
+import { ResultList } from '../../../../shared/models'
import { VideoCommentCreate } from '../../../../shared/models/videos/video-comment.model'
-import { getFormattedObjects, retryTransactionWrapper } from '../../../helpers'
+import { retryTransactionWrapper } from '../../../helpers/database-utils'
+import { getFormattedObjects } from '../../../helpers/utils'
import { sequelizeTypescript } from '../../../initializers'
import { buildFormattedCommentTree, createVideoComment } from '../../../lib/video-comment'
import { asyncMiddleware, authenticate, paginationValidator, setPagination, setVideoCommentThreadsSort } from '../../../middlewares'
addVideoCommentReplyValidator, addVideoCommentThreadValidator, listVideoCommentThreadsValidator,
listVideoThreadCommentsValidator
} from '../../../middlewares/validators/video-comments'
+import { VideoModel } from '../../../models/video/video'
import { VideoCommentModel } from '../../../models/video/video-comment'
const videoCommentRouter = express.Router()
// ---------------------------------------------------------------------------
async function listVideoThreads (req: express.Request, res: express.Response, next: express.NextFunction) {
- const resultList = await VideoCommentModel.listThreadsForApi(res.locals.video.id, req.query.start, req.query.count, req.query.sort)
+ const video = res.locals.video as VideoModel
+ let resultList: ResultList<VideoCommentModel>
+
+ if (video.commentsEnabled === true) {
+ resultList = await VideoCommentModel.listThreadsForApi(video.id, req.query.start, req.query.count, req.query.sort)
+ } else {
+ resultList = {
+ total: 0,
+ data: []
+ }
+ }
return res.json(getFormattedObjects(resultList.data, resultList.total))
}
async function listVideoThreadComments (req: express.Request, res: express.Response, next: express.NextFunction) {
- const resultList = await VideoCommentModel.listThreadCommentsForApi(res.locals.video.id, res.locals.videoCommentThread.id)
+ const video = res.locals.video as VideoModel
+ let resultList: ResultList<VideoCommentModel>
+
+ if (video.commentsEnabled === true) {
+ resultList = await VideoCommentModel.listThreadCommentsForApi(res.locals.video.id, res.locals.videoCommentThread.id)
+ } else {
+ resultList = {
+ total: 0,
+ data: []
+ }
+ }
return res.json(buildFormattedCommentTree(resultList))
}
const comment = await retryTransactionWrapper(addVideoCommentThread, options)
res.json({
- comment: {
- id: comment.id
- }
+ comment: comment.toFormattedJSON()
}).end()
}
text: videoCommentInfo.text,
inReplyToComment: null,
video: res.locals.video,
- actorId: res.locals.oauth.token.User.Account.Actor.id
+ account: res.locals.oauth.token.User.Account
}, t)
})
}
const comment = await retryTransactionWrapper(addVideoCommentReply, options)
res.json({
- comment: {
- id: comment.id
- }
+ comment: comment.toFormattedJSON()
}).end()
}
return sequelizeTypescript.transaction(async t => {
return createVideoComment({
text: videoCommentInfo.text,
- inReplyToComment: res.locals.videoComment.id,
+ inReplyToComment: res.locals.videoComment,
video: res.locals.video,
- actorId: res.locals.oauth.token.User.Account.Actor.id
+ account: res.locals.oauth.token.User.Account
}, t)
})
}