import define from '../../../define'; import { Emojis } from '@/models/index'; import { makePaginationQuery } from '../../../common/make-pagination-query'; import { Emoji } from '@/models/entities/emoji'; export const meta = { tags: ['admin'], requireCredential: true, requireModerator: true, res: { type: 'array', optional: false, nullable: false, items: { type: 'object', optional: false, nullable: false, properties: { id: { type: 'string', optional: false, nullable: false, format: 'id', }, aliases: { type: 'array', optional: false, nullable: false, items: { type: 'string', optional: false, nullable: false, }, }, name: { type: 'string', optional: false, nullable: false, }, category: { type: 'string', optional: false, nullable: true, }, host: { type: 'string', optional: false, nullable: true, }, url: { type: 'string', optional: false, nullable: false, }, }, }, }, } as const; const paramDef = { type: 'object', properties: { query: { type: 'string', nullable: true, default: null }, limit: { type: 'integer', minimum: 1, maximum: 100, default: 10 }, sinceId: { type: 'string', format: 'misskey:id' }, untilId: { type: 'string', format: 'misskey:id' }, }, required: [], } as const; // eslint-disable-next-line import/no-default-export export default define(meta, paramDef, async (ps) => { const q = makePaginationQuery(Emojis.createQueryBuilder('emoji'), ps.sinceId, ps.untilId) .andWhere(`emoji.host IS NULL`); let emojis: Emoji[]; if (ps.query) { //q.andWhere('emoji.name ILIKE :q', { q: `%${ps.query}%` }); //const emojis = await q.take(ps.limit).getMany(); emojis = await q.getMany(); emojis = emojis.filter(emoji => emoji.name.includes(ps.query!) || emoji.aliases.some(a => a.includes(ps.query!)) || emoji.category?.includes(ps.query!)); emojis.splice(ps.limit + 1); } else { emojis = await q.take(ps.limit).getMany(); } return Emojis.packMany(emojis); });