summaryrefslogtreecommitdiff
path: root/packages/backend/src/server/api/endpoints/ap
diff options
context:
space:
mode:
Diffstat (limited to 'packages/backend/src/server/api/endpoints/ap')
-rw-r--r--packages/backend/src/server/api/endpoints/ap/get.ts8
-rw-r--r--packages/backend/src/server/api/endpoints/ap/show.ts57
2 files changed, 43 insertions, 22 deletions
diff --git a/packages/backend/src/server/api/endpoints/ap/get.ts b/packages/backend/src/server/api/endpoints/ap/get.ts
index 0acce9bdbc..ff8c677b91 100644
--- a/packages/backend/src/server/api/endpoints/ap/get.ts
+++ b/packages/backend/src/server/api/endpoints/ap/get.ts
@@ -7,7 +7,7 @@ import ms from 'ms';
export const meta = {
tags: ['federation'],
- requireCredential: true as const,
+ requireCredential: true,
limit: {
duration: ms('1hour'),
@@ -24,10 +24,10 @@ export const meta = {
},
res: {
- type: 'object' as const,
- optional: false as const, nullable: false as const,
+ type: 'object',
+ optional: false, nullable: false,
},
-};
+} as const;
// eslint-disable-next-line import/no-default-export
export default define(meta, async (ps) => {
diff --git a/packages/backend/src/server/api/endpoints/ap/show.ts b/packages/backend/src/server/api/endpoints/ap/show.ts
index e4e13117e6..7d17d8edce 100644
--- a/packages/backend/src/server/api/endpoints/ap/show.ts
+++ b/packages/backend/src/server/api/endpoints/ap/show.ts
@@ -12,11 +12,12 @@ import { User } from '@/models/entities/user';
import { fetchMeta } from '@/misc/fetch-meta';
import { isActor, isPost, getApId } from '@/remote/activitypub/type';
import ms from 'ms';
+import { SchemaType } from '@/misc/schema';
export const meta = {
tags: ['federation'],
- requireCredential: true as const,
+ requireCredential: true,
limit: {
duration: ms('1hour'),
@@ -38,21 +39,41 @@ export const meta = {
},
res: {
- type: 'object' as const,
- optional: false as const, nullable: false as const,
- properties: {
- type: {
- type: 'string' as const,
- optional: false as const, nullable: false as const,
- enum: ['User', 'Note'],
- },
- object: {
- type: 'object' as const,
- optional: false as const, nullable: false as const,
+ optional: false, nullable: false,
+ oneOf: [
+ {
+ type: 'object',
+ properties: {
+ type: {
+ type: 'string',
+ optional: false, nullable: false,
+ enum: ['User'],
+ },
+ object: {
+ type: 'object',
+ optional: false, nullable: false,
+ ref: 'UserDetailedNotMe',
+ }
+ }
},
- },
+ {
+ type: 'object',
+ properties: {
+ type: {
+ type: 'string',
+ optional: false, nullable: false,
+ enum: ['Note'],
+ },
+ object: {
+ type: 'object',
+ optional: false, nullable: false,
+ ref: 'Note',
+ }
+ }
+ }
+ ],
},
-};
+} as const;
// eslint-disable-next-line import/no-default-export
export default define(meta, async (ps) => {
@@ -67,7 +88,7 @@ export default define(meta, async (ps) => {
/***
* URIからUserかNoteを解決する
*/
-async function fetchAny(uri: string) {
+async function fetchAny(uri: string): Promise<SchemaType<typeof meta['res']> | null> {
// URIがこのサーバーを指しているなら、ローカルユーザーIDとしてDBからフェッチ
if (uri.startsWith(config.url + '/')) {
const parts = uri.split('/');
@@ -96,8 +117,8 @@ async function fetchAny(uri: string) {
}
// ブロックしてたら中断
- const meta = await fetchMeta();
- if (meta.blockedHosts.includes(extractDbHost(uri))) return null;
+ const fetchedMeta = await fetchMeta();
+ if (fetchedMeta.blockedHosts.includes(extractDbHost(uri))) return null;
// URI(AP Object id)としてDB検索
{
@@ -172,7 +193,7 @@ async function fetchAny(uri: string) {
return null;
}
-async function mergePack(user: User | null | undefined, note: Note | null | undefined) {
+async function mergePack(user: User | null | undefined, note: Note | null | undefined): Promise<SchemaType<typeof meta.res> | null> {
if (user != null) {
return {
type: 'User',