diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2018-07-21 19:33:56 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2018-07-21 19:33:56 +0900 |
| commit | 900a9cb34f286b0993dfea7b3278ee8cf6918cba (patch) | |
| tree | f3ac40545266578a649a961b2f31c5c9571ee4bf /src/services | |
| parent | #1947 (diff) | |
| download | sharkey-900a9cb34f286b0993dfea7b3278ee8cf6918cba.tar.gz sharkey-900a9cb34f286b0993dfea7b3278ee8cf6918cba.tar.bz2 sharkey-900a9cb34f286b0993dfea7b3278ee8cf6918cba.zip | |
sharedInbox対応
Diffstat (limited to 'src/services')
| -rw-r--r-- | src/services/following/create.ts | 6 | ||||
| -rw-r--r-- | src/services/following/requests/accept.ts | 6 | ||||
| -rw-r--r-- | src/services/following/requests/create.ts | 6 | ||||
| -rw-r--r-- | src/services/note/create.ts | 11 |
4 files changed, 21 insertions, 8 deletions
diff --git a/src/services/following/create.ts b/src/services/following/create.ts index ea78a781e7..e1164c0bd9 100644 --- a/src/services/following/create.ts +++ b/src/services/following/create.ts @@ -22,11 +22,13 @@ export default async function(follower: IUser, followee: IUser) { // 非正規化 _follower: { host: follower.host, - inbox: isRemoteUser(follower) ? follower.inbox : undefined + inbox: isRemoteUser(follower) ? follower.inbox : undefined, + sharedInbox: isRemoteUser(follower) ? follower.sharedInbox : undefined }, _followee: { host: followee.host, - inbox: isRemoteUser(followee) ? followee.inbox : undefined + inbox: isRemoteUser(followee) ? followee.inbox : undefined, + sharedInbox: isRemoteUser(followee) ? followee.sharedInbox : undefined } }); diff --git a/src/services/following/requests/accept.ts b/src/services/following/requests/accept.ts index c874adc167..0a7674a4b8 100644 --- a/src/services/following/requests/accept.ts +++ b/src/services/following/requests/accept.ts @@ -18,11 +18,13 @@ export default async function(followee: IUser, follower: IUser) { // 非正規化 _follower: { host: follower.host, - inbox: isRemoteUser(follower) ? follower.inbox : undefined + inbox: isRemoteUser(follower) ? follower.inbox : undefined, + sharedInbox: isRemoteUser(follower) ? follower.sharedInbox : undefined }, _followee: { host: followee.host, - inbox: isRemoteUser(followee) ? followee.inbox : undefined + inbox: isRemoteUser(followee) ? followee.inbox : undefined, + sharedInbox: isRemoteUser(followee) ? followee.sharedInbox : undefined } }); diff --git a/src/services/following/requests/create.ts b/src/services/following/requests/create.ts index 98936f32e6..1b474dd8be 100644 --- a/src/services/following/requests/create.ts +++ b/src/services/following/requests/create.ts @@ -17,11 +17,13 @@ export default async function(follower: IUser, followee: IUser) { // 非正規化 _follower: { host: follower.host, - inbox: isRemoteUser(follower) ? follower.inbox : undefined + inbox: isRemoteUser(follower) ? follower.inbox : undefined, + sharedInbox: isRemoteUser(follower) ? follower.sharedInbox : undefined }, _followee: { host: followee.host, - inbox: isRemoteUser(followee) ? followee.inbox : undefined + inbox: isRemoteUser(followee) ? followee.inbox : undefined, + sharedInbox: isRemoteUser(followee) ? followee.sharedInbox : undefined } }); diff --git a/src/services/note/create.ts b/src/services/note/create.ts index 7bc2dddc4f..8536b8b561 100644 --- a/src/services/note/create.ts +++ b/src/services/note/create.ts @@ -403,7 +403,9 @@ async function publishToFollowers(note: INote, noteObj: any, user: IUser, noteAc followeeId: note.userId }); - followers.map(async (following) => { + const queue: string[] = []; + + followers.map(following => { const follower = following._follower; if (isLocalUser(follower)) { @@ -423,10 +425,15 @@ async function publishToFollowers(note: INote, noteObj: any, user: IUser, noteAc } else { // フォロワーがリモートユーザーかつ投稿者がローカルユーザーなら投稿を配信 if (isLocalUser(user)) { - deliver(user, noteActivity, follower.inbox); + const inbox = follower.sharedInbox || follower.inbox; + if (!queue.includes(inbox)) queue.push(inbox); } } }); + + queue.forEach(inbox => { + deliver(user, noteActivity, inbox); + }); } function deliverNoteToMentionedRemoteUsers(mentionedUsers: IUser[], user: ILocalUser, noteActivity: any) { |