+ static load (actorId: number | string, videoId: number | string, t?: Transaction): Bluebird<MVideoShareActor> {
+ return VideoShareModel.scope(ScopeNames.WITH_ACTOR).findOne({
+ where: {
+ actorId,
+ videoId
+ },
+ transaction: t
+ })
+ }
+
+ static loadByUrl (url: string, t: Transaction): Bluebird<MVideoShareFull> {
+ return VideoShareModel.scope(ScopeNames.FULL).findOne({
+ where: {
+ url
+ },
+ transaction: t
+ })
+ }
+
+ static loadActorsByShare (videoId: number, t: Transaction): Bluebird<MActorDefault[]> {
+ const query = {
+ where: {
+ videoId
+ },
+ include: [
+ {
+ model: ActorModel,
+ required: true
+ }
+ ],
+ transaction: t
+ }
+
+ return VideoShareModel.scope(ScopeNames.FULL).findAll(query)
+ .then((res: MVideoShareFull[]) => res.map(r => r.Actor))
+ }
+
+ static loadActorsWhoSharedVideosOf (actorOwnerId: number, t: Transaction): Bluebird<MActorDefault[]> {
+ const safeOwnerId = parseInt(actorOwnerId + '', 10)
+
+ // /!\ On actor model
+ const query = {
+ where: {
+ [Op.and]: [
+ literal(
+ `EXISTS (` +
+ ` SELECT 1 FROM "videoShare" ` +
+ ` INNER JOIN "video" ON "videoShare"."videoId" = "video"."id" ` +
+ ` INNER JOIN "videoChannel" ON "videoChannel"."id" = "video"."channelId" ` +
+ ` INNER JOIN "account" ON "account"."id" = "videoChannel"."accountId" ` +
+ ` WHERE "videoShare"."actorId" = "ActorModel"."id" AND "account"."actorId" = ${safeOwnerId} ` +
+ ` LIMIT 1` +
+ `)`
+ )
+ ]
+ },
+ transaction: t
+ }
+
+ return ActorModel.findAll(query)
+ }
+
+ static loadActorsByVideoChannel (videoChannelId: number, t: Transaction): Bluebird<MActorDefault[]> {
+ const safeChannelId = parseInt(videoChannelId + '', 10)
+
+ // /!\ On actor model
+ const query = {
+ 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)