diff options
| author | tamaina <tamaina@hotmail.co.jp> | 2018-04-11 20:59:30 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-04-11 20:59:30 +0900 |
| commit | 185805363d244c43e9e91c67fd94dbb7473c283a (patch) | |
| tree | 838914e262c0fca5737588a7bba64e2b9f3d8e5f /src/server/activitypub/note.ts | |
| parent | v2380 (diff) | |
| parent | Merge pull request #1 from syuilo/master (diff) | |
| download | misskey-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.ts | 28 |
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; |