+ where: {
+ [Op.and]: [
+ literal(
+ `EXISTS (` +
+ ` SELECT 1 FROM "videoShare" ` +
+ ` INNER JOIN "video" ON "videoShare"."videoId" = "video"."id" ` +
+ ` WHERE "videoShare"."actorId" = "ActorModel"."id" AND "video"."channelId" = ${safeChannelId} ` +
+ ` LIMIT 1` +
+ `)`
+ )
+ ]
+ },
+ transaction: t
+ }
+
+ return ActorModel.findAll(query)
+ }
+
+ static listAndCountByVideoId (videoId: number, start: number, count: number, t?: Transaction) {
+ const query = {
+ offset: start,
+ limit: count,
+ where: {
+ videoId
+ },
+ transaction: t
+ }
+
+ return VideoShareModel.findAndCountAll(query)
+ }
+
+ static listRemoteShareUrlsOfLocalVideos () {
+ const query = `SELECT "videoShare".url FROM "videoShare" ` +
+ `INNER JOIN actor ON actor.id = "videoShare"."actorId" AND actor."serverId" IS NOT NULL ` +
+ `INNER JOIN video ON video.id = "videoShare"."videoId" AND video.remote IS FALSE`
+
+ return VideoShareModel.sequelize.query<{ url: string }>(query, {
+ type: QueryTypes.SELECT,
+ raw: true
+ }).then(rows => rows.map(r => r.url))
+ }
+
+ static cleanOldSharesOf (videoId: number, beforeUpdatedAt: Date) {
+ const query = {
+ where: {
+ updatedAt: {
+ [Op.lt]: beforeUpdatedAt