summaryrefslogtreecommitdiff
path: root/src/server/activitypub/note.ts
diff options
context:
space:
mode:
authortamaina <tamaina@hotmail.co.jp>2018-04-11 20:59:30 +0900
committerGitHub <noreply@github.com>2018-04-11 20:59:30 +0900
commit185805363d244c43e9e91c67fd94dbb7473c283a (patch)
tree838914e262c0fca5737588a7bba64e2b9f3d8e5f /src/server/activitypub/note.ts
parentv2380 (diff)
parentMerge pull request #1 from syuilo/master (diff)
downloadmisskey-185805363d244c43e9e91c67fd94dbb7473c283a.tar.gz
misskey-185805363d244c43e9e91c67fd94dbb7473c283a.tar.bz2
misskey-185805363d244c43e9e91c67fd94dbb7473c283a.zip
Merge pull request #2 from tamaina/master
追従
Diffstat (limited to 'src/server/activitypub/note.ts')
-rw-r--r--src/server/activitypub/note.ts28
1 files changed, 28 insertions, 0 deletions
diff --git a/src/server/activitypub/note.ts b/src/server/activitypub/note.ts
new file mode 100644
index 0000000000..1c2e695b80
--- /dev/null
+++ b/src/server/activitypub/note.ts
@@ -0,0 +1,28 @@
+import * as express from 'express';
+import context from '../../remote/activitypub/renderer/context';
+import render from '../../remote/activitypub/renderer/note';
+import Note from '../../models/note';
+
+const app = express.Router();
+
+app.get('/notes/:note', async (req, res, next) => {
+ const accepted = req.accepts(['html', 'application/activity+json', 'application/ld+json']);
+ if (!(['application/activity+json', 'application/ld+json'] as any[]).includes(accepted)) {
+ return next();
+ }
+
+ const note = await Note.findOne({
+ _id: req.params.note
+ });
+
+ if (note === null) {
+ return res.sendStatus(404);
+ }
+
+ const rendered = await render(note);
+ rendered['@context'] = context;
+
+ res.json(rendered);
+});
+
+export default app;