Merge remote-tracking branch 'mi-dev/master' into report

This commit is contained in:
mattyatea 2023-12-28 04:16:03 +09:00
commit cb1586658e
No known key found for this signature in database
GPG key ID: 068E54E2C33BEF9A
567 changed files with 10281 additions and 3996 deletions

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:abuse-user-reports',
res: {
type: 'array',

View file

@ -46,12 +46,12 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
private userEntityService: UserEntityService,
private signupService: SignupService,
) {
super(meta, paramDef, async (ps, _me) => {
super(meta, paramDef, async (ps, _me, token) => {
const me = _me ? await this.usersRepository.findOneByOrFail({ id: _me.id }) : null;
const noUsers = (await this.usersRepository.countBy({
host: IsNull(),
})) === 0;
if (!noUsers && !me?.isRoot) throw new Error('access denied');
if ((!noUsers && !me?.isRoot) || token !== null) throw new Error('access denied');
const { account, secret } = await this.signupService.signup({
username: ps.username,

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:account',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'read:admin:account',
errors: {
userNotFound: {
@ -23,6 +24,11 @@ export const meta = {
id: 'cb865949-8af5-4062-a88c-ef55e8786d1d',
},
},
res: {
type: 'object',
optional: false, nullable: false,
ref: 'User',
},
} as const;
export const paramDef = {

View file

@ -15,6 +15,13 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:ad',
res: {
type: 'object',
optional: false,
nullable: false,
ref: 'Ad',
},
} as const;
export const paramDef = {
@ -61,7 +68,18 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
ad: ad,
});
return ad;
return {
id: ad.id,
expiresAt: ad.expiresAt.toISOString(),
startsAt: ad.startsAt.toISOString(),
dayOfWeek: ad.dayOfWeek,
url: ad.url,
imageUrl: ad.imageUrl,
priority: ad.priority,
ratio: ad.ratio,
place: ad.place,
memo: ad.memo,
};
});
}
}

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:ad',
errors: {
noSuchAd: {

View file

@ -14,6 +14,18 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:ad',
res: {
type: 'array',
optional: false,
nullable: false,
items: {
type: 'object',
optional: false,
nullable: false,
ref: 'Ad',
},
},
} as const;
export const paramDef = {
@ -44,7 +56,18 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
}
const ads = await query.limit(ps.limit).getMany();
return ads;
return ads.map(ad => ({
id: ad.id,
expiresAt: ad.expiresAt.toISOString(),
startsAt: ad.startsAt.toISOString(),
dayOfWeek: ad.dayOfWeek,
url: ad.url,
imageUrl: ad.imageUrl,
memo: ad.memo,
place: ad.place,
priority: ad.priority,
ratio: ad.ratio,
}));
});
}
}

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:ad',
errors: {
noSuchAd: {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:announcements',
res: {
type: 'object',

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:announcements',
errors: {
noSuchAnnouncement: {

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:announcements',
res: {
type: 'array',

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:announcements',
errors: {
noSuchAnnouncement: {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageAvatarDecorations',
kind: 'write:admin:avatar-decorations',
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageAvatarDecorations',
kind: 'write:admin:avatar-decorations',
errors: {
},
} as const;

View file

@ -17,6 +17,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageAvatarDecorations',
kind: 'read:admin:avatar-decorations',
res: {
type: 'array',

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageAvatarDecorations',
kind: 'write:admin:avatar-decorations',
errors: {
},

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:delete-account',
res: {
},

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:delete-all-files-of-a-user',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:drive',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:drive',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:drive',
res: {
type: 'array',

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:drive',
errors: {
noSuchFile: {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
errors: {
noSuchFile: {
@ -29,6 +30,8 @@ export const meta = {
id: 'f7a3462c-4e6e-4069-8421-b9bd4f4c3975',
},
},
ref: 'EmojiDetailed',
} as const;
export const paramDef = {

View file

@ -18,6 +18,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
errors: {
noSuchEmoji: {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
errors: {
noSuchEmoji: {

View file

@ -17,6 +17,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'read:admin:emoji',
res: {
type: 'array',

View file

@ -17,6 +17,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'read:admin:emoji',
res: {
type: 'array',

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireRolePolicy: 'canManageCustomEmojis',
kind: 'write:admin:emoji',
errors: {
noSuchEmoji: {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:federation',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:federation',
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:federation',
} as const;
export const paramDef = {

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:federation',
} as const;
export const paramDef = {

View file

@ -11,8 +11,19 @@ import { DI } from '@/di-symbols.js';
export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'read:admin:index-stats',
tags: ['admin'],
res: {
type: 'array',
items: {
type: 'object',
properties: {
tablename: { type: 'string' },
indexname: { type: 'string' },
},
},
},
} as const;
export const paramDef = {

View file

@ -11,6 +11,7 @@ import { DI } from '@/di-symbols.js';
export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'read:admin:table-stats',
tags: ['admin'],

View file

@ -14,6 +14,26 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:user-ips',
res: {
type: 'array',
optional: false,
nullable: false,
items: {
type: 'object',
optional: false,
nullable: false,
properties: {
ip: { type: 'string' },
createdAt: {
type: 'string',
optional: false,
nullable: false,
format: 'date-time',
},
},
},
},
} as const;
export const paramDef = {

View file

@ -18,6 +18,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:invite-codes',
errors: {
invalidDateTime: {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:invite-codes',
res: {
type: 'array',

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'read:admin:meta',
res: {
type: 'object',
@ -143,6 +144,14 @@ export const meta = {
type: 'string',
},
},
bannedEmailDomains: {
type: 'array',
optional: true, nullable: false,
items: {
type: 'string',
optional: false, nullable: false,
},
},
preservedUsernames: {
type: 'array',
optional: false, nullable: false,
@ -371,6 +380,10 @@ export const meta = {
type: 'string',
optional: false, nullable: true,
},
shortName: {
type: 'string',
optional: false, nullable: true,
},
objectStorageS3ForcePathStyle: {
type: 'boolean',
optional: false, nullable: false,
@ -511,6 +524,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
enableChartsForFederatedInstances: instance.enableChartsForFederatedInstances,
enableServerMachineStats: instance.enableServerMachineStats,
enableIdenticonGeneration: instance.enableIdenticonGeneration,
bannedEmailDomains: instance.bannedEmailDomains,
policies: { ...DEFAULT_POLICIES, ...instance.policies },
manifestJsonOverride: instance.manifestJsonOverride,
enableFanoutTimeline: instance.enableFanoutTimeline,

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:promo',
errors: {
noSuchNote: {

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:queue',
} as const;
export const paramDef = {

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:queue',
res: {
type: 'array',

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:queue',
res: {
type: 'array',

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:queue',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:emoji',
res: {
type: 'object',

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:relays',
errors: {
invalidUrl: {

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:relays',
res: {
type: 'array',

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:relays',
} as const;
export const paramDef = {

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:reset-password',
res: {
type: 'object',

View file

@ -17,6 +17,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:resolve-abuse-user-report',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:roles',
errors: {
noSuchRole: {

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:roles',
res: {
type: 'object',

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:roles',
errors: {
noSuchRole: {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:roles',
res: {
type: 'array',

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:roles',
errors: {
noSuchRole: {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:roles',
errors: {
noSuchRole: {

View file

@ -13,6 +13,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:roles',
} as const;
export const paramDef = {

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:roles',
errors: {
noSuchRole: {

View file

@ -18,6 +18,7 @@ export const meta = {
requireCredential: false,
requireAdmin: true,
kind: 'read:admin:roles',
errors: {
noSuchRole: {
@ -26,6 +27,20 @@ export const meta = {
id: '224eff5e-2488-4b18-b3e7-f50d94421648',
},
},
res: {
type: 'array',
items: {
type: 'object',
properties: {
id: { type: 'string', format: 'misskey:id' },
createdAt: { type: 'string', format: 'date-time' },
user: { ref: 'UserDetailed' },
expiresAt: { type: 'string', format: 'date-time', nullable: true },
},
required: ['id', 'createdAt', 'user'],
},
}
} as const;
export const paramDef = {
@ -78,7 +93,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
id: assign.id,
createdAt: this.idService.parse(assign.id).date.toISOString(),
user: await this.userEntityService.pack(assign.user!, me, { detail: true }),
expiresAt: assign.expiresAt,
expiresAt: assign.expiresAt?.toISOString() ?? null,
})));
});
}

View file

@ -12,6 +12,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:send-email',
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ import { DI } from '@/di-symbols.js';
export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:server-info',
tags: ['admin', 'meta'],

View file

@ -14,7 +14,8 @@ export const meta = {
tags: ['admin'],
requireCredential: true,
requireModerator: true,
requireAdmin: true,
kind: 'read:admin:show-moderation-log',
res: {
type: 'array',

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:show-user',
res: {
type: 'object',

View file

@ -16,6 +16,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'read:admin:show-users',
res: {
type: 'array',

View file

@ -21,6 +21,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:suspend-user',
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:unset-user-avatar',
} as const;
export const paramDef = {
@ -39,7 +40,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> {
if (user == null) {
throw new Error('user not found');
}
if (user.avatarId == null) return;
await this.usersRepository.update(user.id, {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:unset-user-banner',
} as const;
export const paramDef = {

View file

@ -15,6 +15,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:unsuspend-user',
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireAdmin: true,
kind: 'write:admin:meta',
} as const;
export const paramDef = {
@ -120,6 +121,7 @@ export const paramDef = {
enableServerMachineStats: { type: 'boolean' },
enableIdenticonGeneration: { type: 'boolean' },
serverRules: { type: 'array', items: { type: 'string' } },
bannedEmailDomains: { type: 'array', items: { type: 'string' } },
preservedUsernames: { type: 'array', items: { type: 'string' } },
manifestJsonOverride: { type: 'string' },
enableFanoutTimeline: { type: 'boolean' },
@ -524,6 +526,10 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
set.notesPerOneAd = ps.notesPerOneAd;
}
if (ps.bannedEmailDomains !== undefined) {
set.bannedEmailDomains = ps.bannedEmailDomains;
}
const before = await this.metaService.fetch(true);
await this.metaService.update(set);

View file

@ -14,6 +14,7 @@ export const meta = {
requireCredential: true,
requireModerator: true,
kind: 'write:admin:user-note',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ export const meta = {
tags: ['federation'],
requireCredential: true,
kind: 'read:federation',
limit: {
duration: ms('1hour'),

View file

@ -25,6 +25,7 @@ export const meta = {
tags: ['federation'],
requireCredential: true,
kind: 'read:account',
limit: {
duration: ms('1hour'),

View file

@ -11,6 +11,23 @@ export const meta = {
requireCredential: false,
tags: ['meta'],
res: {
type: 'object',
nullable: true,
properties: {
params: {
type: 'array',
items: {
type: 'object',
properties: {
name: { type: 'string' },
type: { type: 'string' },
},
},
},
},
},
} as const;
export const paramDef = {

View file

@ -18,6 +18,38 @@ export const meta = {
allowGet: true,
cacheSec: 60 * 60,
res: {
type: 'object',
optional: false,
nullable: false,
properties: {
topSubInstances: {
type: 'array',
optional: false,
nullable: false,
items: {
type: 'object',
optional: false,
nullable: false,
ref: 'FederationInstance',
},
},
otherFollowersCount: { type: 'number' },
topPubInstances: {
type: 'array',
optional: false,
nullable: false,
items: {
type: 'object',
optional: false,
nullable: false,
ref: 'FederationInstance',
},
},
otherFollowingCount: { type: 'number' },
},
},
} as const;
export const paramDef = {

View file

@ -11,7 +11,7 @@ import { GetterService } from '@/server/api/GetterService.js';
export const meta = {
tags: ['federation'],
requireCredential: true,
requireCredential: false,
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
tags: ['meta'],
requireCredential: true,
secure: true,
limit: {
duration: ms('1hour'),
@ -32,6 +33,18 @@ export const meta = {
id: '693ba8ba-b486-40df-a174-72f8279b56a4',
},
},
res: {
type: 'object',
properties: {
type: {
type: 'string',
},
data: {
type: 'string',
},
},
},
} as const;
export const paramDef = {

View file

@ -16,6 +16,18 @@ export const meta = {
requireCredential: false,
allowGet: true,
cacheSec: 60 * 3,
res: {
type: 'object',
properties: {
items: {
type: 'array',
items: {
type: 'object',
},
}
}
},
} as const;
export const paramDef = {

View file

@ -27,6 +27,12 @@ export const meta = {
errors: {
},
res: {
type: 'object',
optional: false, nullable: false,
ref: 'Flash',
},
} as const;
export const paramDef = {

View file

@ -16,6 +16,16 @@ export const meta = {
requireCredential: false,
allowGet: true,
cacheSec: 60 * 1,
res: {
type: 'object',
optional: false, nullable: false,
properties: {
count: {
type: 'number',
nullable: false,
},
},
},
} as const;
export const paramDef = {

View file

@ -14,6 +14,7 @@ export const meta = {
tags: ['account'],
requireCredential: true,
kind: "read:account",
res: {
type: 'object',

View file

@ -32,6 +32,16 @@ export const meta = {
id: '798d6847-b1ed-4f9c-b1f9-163c42655995',
},
},
res: {
type: 'object',
nullable: false,
optional: false,
properties: {
id: { type: 'string' },
name: { type: 'string' },
},
},
} as const;
export const paramDef = {

View file

@ -36,6 +36,140 @@ export const meta = {
id: 'bf32b864-449b-47b8-974e-f9a5468546f1',
},
},
res: {
type: 'object',
nullable: false,
optional: false,
properties: {
rp: {
type: 'object',
properties: {
id: {
type: 'string',
nullable: true,
},
},
},
user: {
type: 'object',
properties: {
id: {
type: 'string',
},
name: {
type: 'string',
},
displayName: {
type: 'string',
},
},
},
challenge: {
type: 'string',
},
pubKeyCredParams: {
type: 'array',
items: {
type: 'object',
properties: {
type: {
type: 'string',
},
alg: {
type: 'number',
},
},
},
},
timeout: {
type: 'number',
nullable: true,
},
excludeCredentials: {
type: 'array',
nullable: true,
items: {
type: 'object',
properties: {
id: {
type: 'string',
},
type: {
type: 'string',
},
transports: {
type: 'array',
items: {
type: 'string',
enum: [
"ble",
"cable",
"hybrid",
"internal",
"nfc",
"smart-card",
"usb",
],
},
},
},
},
},
authenticatorSelection: {
type: 'object',
nullable: true,
properties: {
authenticatorAttachment: {
type: 'string',
enum: [
"cross-platform",
"platform",
],
},
requireResidentKey: {
type: 'boolean',
},
userVerification: {
type: 'string',
enum: [
"discouraged",
"preferred",
"required",
],
},
},
},
attestation: {
type: 'string',
nullable: true,
enum: [
"direct",
"enterprise",
"indirect",
"none",
],
},
extensions: {
type: 'object',
nullable: true,
properties: {
appid: {
type: 'string',
nullable: true,
},
credProps: {
type: 'boolean',
nullable: true,
},
hmacCreateSecret: {
type: 'boolean',
nullable: true,
},
},
},
},
},
} as const;
export const paramDef = {

View file

@ -26,6 +26,19 @@ export const meta = {
id: '78d6c839-20c9-4c66-b90a-fc0542168b48',
},
},
res: {
type: 'object',
nullable: false,
optional: false,
properties: {
qr: { type: 'string' },
url: { type: 'string' },
secret: { type: 'string' },
label: { type: 'string' },
issuer: { type: 'string' },
},
},
} as const;
export const paramDef = {

View file

@ -13,6 +13,37 @@ export const meta = {
requireCredential: true,
secure: true,
res: {
type: 'array',
items: {
type: 'object',
properties: {
id: {
type: 'string',
format: 'misskey:id',
},
name: {
type: 'string',
},
createdAt: {
type: 'string',
format: 'date-time',
},
lastUsedAt: {
type: 'string',
format: 'date-time',
},
permission: {
type: 'array',
uniqueItems: true,
items: {
type: 'string'
},
}
},
},
},
} as const;
export const paramDef = {
@ -50,7 +81,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
id: token.id,
name: token.name ?? token.app?.name,
createdAt: this.idService.parse(token.id).date.toISOString(),
lastUsedAt: token.lastUsedAt,
lastUsedAt: token.lastUsedAt?.toISOString(),
permission: token.permission,
})));
});

View file

@ -14,6 +14,36 @@ export const meta = {
requireCredential: true,
secure: true,
res: {
type: 'array',
items: {
type: 'object',
properties: {
id: {
type: 'string',
format: 'misskey:id',
},
name: {
type: 'string',
},
callbackUrl: {
type: 'string',
nullable: true,
},
permission: {
type: 'array',
uniqueItems: true,
items: {
type: 'string'
},
},
isAuthorized: {
type: 'boolean',
},
},
},
},
} as const;
export const paramDef = {

View file

@ -10,6 +10,7 @@ import { AchievementService, ACHIEVEMENT_TYPES } from '@/core/AchievementService
export const meta = {
requireCredential: true,
prohibitMoved: true,
kind: 'write:account',
} as const;
export const paramDef = {

View file

@ -64,6 +64,10 @@ export const meta = {
id: 'b234a14e-9ebe-4581-8000-074b3c215962',
},
},
res: {
type: 'object',
},
} as const;
export const paramDef = {

View file

@ -9,6 +9,11 @@ import { RegistryApiService } from '@/core/RegistryApiService.js';
export const meta = {
requireCredential: true,
kind: 'read:account',
res: {
type: 'object',
},
} as const;
export const paramDef = {

View file

@ -10,6 +10,7 @@ import { ApiError } from '../../../error.js';
export const meta = {
requireCredential: true,
kind: 'read:account',
errors: {
noSuchKey: {
@ -18,6 +19,10 @@ export const meta = {
id: '97a1e8e7-c0f7-47d2-957a-92e61256e01a',
},
},
res: {
type: 'object',
}
} as const;
export const paramDef = {

View file

@ -10,6 +10,7 @@ import { ApiError } from '../../../error.js';
export const meta = {
requireCredential: true,
kind: 'read:account',
errors: {
noSuchKey: {
@ -18,6 +19,10 @@ export const meta = {
id: 'ac3ed68a-62f0-422b-a7bc-d5e09e8f6a6a',
},
},
res: {
type: 'object',
}
} as const;
export const paramDef = {

View file

@ -9,6 +9,11 @@ import { RegistryApiService } from '@/core/RegistryApiService.js';
export const meta = {
requireCredential: true,
kind: 'read:account',
res: {
type: 'object',
},
} as const;
export const paramDef = {

View file

@ -9,6 +9,7 @@ import { RegistryApiService } from '@/core/RegistryApiService.js';
export const meta = {
requireCredential: true,
kind: 'read:account',
} as const;
export const paramDef = {

View file

@ -12,6 +12,7 @@ import { ApiError } from '../../../error.js';
export const meta = {
requireCredential: true,
kind: 'write:account',
errors: {
noSuchKey: {

View file

@ -10,6 +10,28 @@ import { RegistryApiService } from '@/core/RegistryApiService.js';
export const meta = {
requireCredential: true,
secure: true,
res: {
type: 'array',
items: {
type: 'object',
properties: {
scopes: {
type: 'array',
items: {
type: 'array',
items: {
type: 'string',
}
}
},
domain: {
type: 'string',
nullable: true,
},
},
},
}
} as const;
export const paramDef = {

View file

@ -9,6 +9,7 @@ import { RegistryApiService } from '@/core/RegistryApiService.js';
export const meta = {
requireCredential: true,
kind: 'write:account',
} as const;
export const paramDef = {

Some files were not shown because too many files have changed in this diff Show more