1
0
Fork 0

Fix sharedInboxUrl list

This commit is contained in:
Chocobozzz 2018-01-09 18:13:00 +01:00
parent ca309a9f64
commit 759f8a29e9
No known key found for this signature in database
GPG key ID: 583A612D890159BE

View file

@ -191,12 +191,13 @@ export class ActorFollowModel extends Model<ActorFollowModel> {
static listAcceptedFollowerSharedInboxUrls (actorIds: number[], t: Sequelize.Transaction) { static listAcceptedFollowerSharedInboxUrls (actorIds: number[], t: Sequelize.Transaction) {
return ActorFollowModel.createListAcceptedFollowForApiQuery( return ActorFollowModel.createListAcceptedFollowForApiQuery(
'DISTINCT(followers)', 'followers',
actorIds, actorIds,
t, t,
undefined, undefined,
undefined, undefined,
'sharedInboxUrl' 'sharedInboxUrl',
true
) )
} }
@ -204,12 +205,15 @@ export class ActorFollowModel extends Model<ActorFollowModel> {
return ActorFollowModel.createListAcceptedFollowForApiQuery('following', actorIds, t, start, count) return ActorFollowModel.createListAcceptedFollowForApiQuery('following', actorIds, t, start, count)
} }
private static async createListAcceptedFollowForApiQuery (type: 'followers' | 'following' | 'DISTINCT(followers)', private static async createListAcceptedFollowForApiQuery (
actorIds: number[], type: 'followers' | 'following',
t: Sequelize.Transaction, actorIds: number[],
start?: number, t: Sequelize.Transaction,
count?: number, start?: number,
columnUrl = 'url') { count?: number,
columnUrl = 'url',
distinct = false
) {
let firstJoin: string let firstJoin: string
let secondJoin: string let secondJoin: string
@ -221,10 +225,15 @@ export class ActorFollowModel extends Model<ActorFollowModel> {
secondJoin = 'targetActorId' secondJoin = 'targetActorId'
} }
const selections = [ '"Follows"."' + columnUrl + '" AS "url"', 'COUNT(*) AS "total"' ] const selections: string[] = []
if (distinct === true) selections.push('DISTINCT("Follows"."' + columnUrl + '") AS "url"')
else selections.push('"Follows"."' + columnUrl + '" AS "url"')
selections.push('COUNT(*) AS "total"')
const tasks: Bluebird<any>[] = [] const tasks: Bluebird<any>[] = []
for (const selection of selections) { for (let selection of selections) {
let query = 'SELECT ' + selection + ' FROM "actor" ' + let query = 'SELECT ' + selection + ' FROM "actor" ' +
'INNER JOIN "actorFollow" ON "actorFollow"."' + firstJoin + '" = "actor"."id" ' + 'INNER JOIN "actorFollow" ON "actorFollow"."' + firstJoin + '" = "actor"."id" ' +
'INNER JOIN "actor" AS "Follows" ON "actorFollow"."' + secondJoin + '" = "Follows"."id" ' + 'INNER JOIN "actor" AS "Follows" ON "actorFollow"."' + secondJoin + '" = "Follows"."id" ' +