summaryrefslogtreecommitdiff
path: root/src/server/activitypub.ts
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/activitypub.ts')
-rw-r--r--src/server/activitypub.ts15
1 files changed, 9 insertions, 6 deletions
diff --git a/src/server/activitypub.ts b/src/server/activitypub.ts
index 6c8a2b915e..92e23380cb 100644
--- a/src/server/activitypub.ts
+++ b/src/server/activitypub.ts
@@ -40,18 +40,21 @@ function inbox(ctx: Router.RouterContext) {
ctx.status = 202;
}
+const ACTIVITY_JSON = 'application/activity+json; charset=utf-8';
+const LD_JSON = 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"; charset=utf-8';
+
function isActivityPubReq(ctx: Router.RouterContext) {
ctx.response.vary('Accept');
- const accepted = ctx.accepts('html', 'application/activity+json', 'application/ld+json');
- return ['application/activity+json', 'application/ld+json'].includes(accepted as string);
+ const accepted = ctx.accepts('html', ACTIVITY_JSON, LD_JSON);
+ return typeof accepted === 'string' && !accepted.match(/html/);
}
export function setResponseType(ctx: Router.RouterContext) {
- const accept = ctx.accepts('application/activity+json', 'application/ld+json');
- if (accept === 'application/ld+json') {
- ctx.response.type = 'application/ld+json; profile="https://www.w3.org/ns/activitystreams"; charset=utf-8';
+ const accept = ctx.accepts(ACTIVITY_JSON, LD_JSON);
+ if (accept === LD_JSON) {
+ ctx.response.type = LD_JSON;
} else {
- ctx.response.type = 'application/activity+json; charset=utf-8';
+ ctx.response.type = ACTIVITY_JSON;
}
}