import { Inject, Injectable } from '@nestjs/common'; import { Brackets } from 'typeorm'; import type { RoleAssignmentsRepository, RolesRepository } from '@/models/index.js'; import { Endpoint } from '@/server/api/endpoint-base.js'; import { QueryService } from '@/core/QueryService.js'; import { DI } from '@/di-symbols.js'; import { UserEntityService } from '@/core/entities/UserEntityService.js'; import { ApiError } from '../../../error.js'; import { Packed } from 'misskey-js'; // eslint-disable-next-line import/no-default-export @Injectable() export default class extends Endpoint<'admin/roles/users'> { name = 'admin/roles/users' as const; constructor( @Inject(DI.rolesRepository) private rolesRepository: RolesRepository, @Inject(DI.roleAssignmentsRepository) private roleAssignmentsRepository: RoleAssignmentsRepository, private queryService: QueryService, private userEntityService: UserEntityService, ) { super(async (ps, me) => { const role = await this.rolesRepository.findOneBy({ id: ps.roleId, }); if (role == null) { throw new ApiError(this.meta.errors.noSuchRole); } const query = this.queryService.makePaginationQuery(this.roleAssignmentsRepository.createQueryBuilder('assign'), ps.sinceId, ps.untilId) .andWhere('assign.roleId = :roleId', { roleId: role.id }) .andWhere(new Brackets(qb => { qb .where('assign.expiresAt IS NULL') .orWhere('assign.expiresAt > :now', { now: new Date() }); })) .innerJoinAndSelect('assign.user', 'user'); const assigns = await query .take(ps.limit) .getMany(); return await Promise.all(assigns.map(async (assign): Promise> => ({ id: assign.id, createdAt: assign.createdAt, user: await this.userEntityService.pack(assign.user!, me, { detail: true }), expiresAt: assign.expiresAt, }))); }); } }