summaryrefslogtreecommitdiff
path: root/src/server/activitypub/outbox.ts
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2018-04-01 19:53:38 +0900
committersyuilo <syuilotan@yahoo.co.jp>2018-04-01 19:53:38 +0900
commiteea3efccc4dd09e0a9d22ea9e72bbbf44f851490 (patch)
tree47fe256b5ccd872a440646bcf44254300bf8f9cf /src/server/activitypub/outbox.ts
parentClean up (diff)
parentUpdate README.md (diff)
downloadmisskey-eea3efccc4dd09e0a9d22ea9e72bbbf44f851490.tar.gz
misskey-eea3efccc4dd09e0a9d22ea9e72bbbf44f851490.tar.bz2
misskey-eea3efccc4dd09e0a9d22ea9e72bbbf44f851490.zip
Merge branch 'master' of https://github.com/syuilo/misskey
Diffstat (limited to 'src/server/activitypub/outbox.ts')
-rw-r--r--src/server/activitypub/outbox.ts45
1 files changed, 45 insertions, 0 deletions
diff --git a/src/server/activitypub/outbox.ts b/src/server/activitypub/outbox.ts
new file mode 100644
index 0000000000..c5a42ae0a9
--- /dev/null
+++ b/src/server/activitypub/outbox.ts
@@ -0,0 +1,45 @@
+import * as express from 'express';
+import context from '../../common/remote/activitypub/renderer/context';
+import renderNote from '../../common/remote/activitypub/renderer/note';
+import renderOrderedCollection from '../../common/remote/activitypub/renderer/ordered-collection';
+import parseAcct from '../../common/user/parse-acct';
+import config from '../../conf';
+import Post from '../../models/post';
+import User from '../../models/user';
+
+const app = express();
+app.disable('x-powered-by');
+
+app.get('/@:user/outbox', async (req, res) => {
+ const { username, host } = parseAcct(req.params.user);
+ if (host !== null) {
+ return res.sendStatus(422);
+ }
+
+ const user = await User.findOne({
+ usernameLower: username.toLowerCase(),
+ host: null
+ });
+ if (user === null) {
+ return res.sendStatus(404);
+ }
+
+ const id = `${config.url}/@${user.username}/inbox`;
+
+ if (username !== user.username) {
+ return res.redirect(id);
+ }
+
+ const posts = await Post.find({ userId: user._id }, {
+ limit: 20,
+ sort: { _id: -1 }
+ });
+
+ const renderedPosts = await Promise.all(posts.map(post => renderNote(user, post)));
+ const rendered = renderOrderedCollection(id, user.postsCount, renderedPosts);
+ rendered['@context'] = context;
+
+ res.json(rendered);
+});
+
+export default app;