summaryrefslogtreecommitdiff
path: root/src/processor/http
diff options
context:
space:
mode:
authorAkihiko Odaki <nekomanma@pixiv.co.jp>2018-04-02 19:50:40 +0900
committerAkihiko Odaki <nekomanma@pixiv.co.jp>2018-04-02 19:50:40 +0900
commit7942f76acb5363e065b681f70f91fe785480a298 (patch)
tree14b4c917e87a9e81d01dc120383eebcda2768691 /src/processor/http
parentResolve account by signature in inbox (diff)
downloadsharkey-7942f76acb5363e065b681f70f91fe785480a298.tar.gz
sharkey-7942f76acb5363e065b681f70f91fe785480a298.tar.bz2
sharkey-7942f76acb5363e065b681f70f91fe785480a298.zip
Implement Follow activity
Diffstat (limited to 'src/processor/http')
-rw-r--r--src/processor/http/follow.ts14
1 files changed, 9 insertions, 5 deletions
diff --git a/src/processor/http/follow.ts b/src/processor/http/follow.ts
index a7e4fa23d5..7ec1ee6756 100644
--- a/src/processor/http/follow.ts
+++ b/src/processor/http/follow.ts
@@ -1,7 +1,7 @@
import { request } from 'https';
import { sign } from 'http-signature';
import { URL } from 'url';
-import User, { isLocalUser, pack as packUser, ILocalUser } from '../../models/user';
+import User, { isLocalUser, pack as packUser } from '../../models/user';
import Following from '../../models/following';
import event from '../../publishers/stream';
import notify from '../../publishers/notify';
@@ -10,7 +10,7 @@ import render from '../../remote/activitypub/renderer/follow';
import config from '../../config';
export default ({ data }, done) => Following.findOne({ _id: data.following }).then(({ followerId, followeeId }) => {
- const promisedFollower: Promise<ILocalUser> = User.findOne({ _id: followerId });
+ const promisedFollower = User.findOne({ _id: followerId });
const promisedFollowee = User.findOne({ _id: followeeId });
return Promise.all([
@@ -34,14 +34,18 @@ export default ({ data }, done) => Following.findOne({ _id: data.following }).th
// Publish follow event
Promise.all([promisedFollower, promisedFollowee]).then(([follower, followee]) => {
- const followerEvent = packUser(followee, follower)
- .then(packed => event(follower._id, 'follow', packed));
+ let followerEvent;
let followeeEvent;
+ if (isLocalUser(follower)) {
+ followerEvent = packUser(followee, follower)
+ .then(packed => event(follower._id, 'follow', packed));
+ }
+
if (isLocalUser(followee)) {
followeeEvent = packUser(follower, followee)
.then(packed => event(followee._id, 'followed', packed));
- } else {
+ } else if (isLocalUser(follower)) {
followeeEvent = new Promise((resolve, reject) => {
const {
protocol,