2023-07-27 00:31:52 -05:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: syuilo and other misskey contributors
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2023-01-12 06:02:26 -06:00
|
|
|
import { Inject, Injectable } from '@nestjs/common';
|
2023-02-28 19:20:03 -06:00
|
|
|
import { Brackets } from 'typeorm';
|
2023-01-12 06:02:26 -06:00
|
|
|
import { DI } from '@/di-symbols.js';
|
2023-09-15 00:28:29 -05:00
|
|
|
import type { RoleAssignmentsRepository, RolesRepository } from '@/models/_.js';
|
2023-01-12 06:02:26 -06:00
|
|
|
import { awaitAll } from '@/misc/prelude/await-all.js';
|
2023-09-19 21:33:36 -05:00
|
|
|
import type { MiUser } from '@/models/User.js';
|
|
|
|
import type { MiRole } from '@/models/Role.js';
|
2023-01-12 06:02:26 -06:00
|
|
|
import { bindThis } from '@/decorators.js';
|
2023-01-15 05:52:53 -06:00
|
|
|
import { DEFAULT_POLICIES } from '@/core/RoleService.js';
|
2023-10-15 20:45:22 -05:00
|
|
|
import { IdService } from '@/core/IdService.js';
|
2023-01-12 06:02:26 -06:00
|
|
|
|
|
|
|
@Injectable()
|
|
|
|
export class RoleEntityService {
|
|
|
|
constructor(
|
|
|
|
@Inject(DI.rolesRepository)
|
|
|
|
private rolesRepository: RolesRepository,
|
|
|
|
|
|
|
|
@Inject(DI.roleAssignmentsRepository)
|
|
|
|
private roleAssignmentsRepository: RoleAssignmentsRepository,
|
2023-10-15 20:45:22 -05:00
|
|
|
|
|
|
|
private idService: IdService,
|
2023-01-12 06:02:26 -06:00
|
|
|
) {
|
|
|
|
}
|
|
|
|
|
|
|
|
@bindThis
|
|
|
|
public async pack(
|
2023-08-16 03:51:28 -05:00
|
|
|
src: MiRole['id'] | MiRole,
|
|
|
|
me?: { id: MiUser['id'] } | null | undefined,
|
2023-01-12 06:02:26 -06:00
|
|
|
) {
|
|
|
|
const role = typeof src === 'object' ? src : await this.rolesRepository.findOneByOrFail({ id: src });
|
|
|
|
|
2023-02-28 19:20:03 -06:00
|
|
|
const assignedCount = await this.roleAssignmentsRepository.createQueryBuilder('assign')
|
|
|
|
.where('assign.roleId = :roleId', { roleId: role.id })
|
2023-10-08 23:32:41 -05:00
|
|
|
.andWhere(new Brackets(qb => {
|
|
|
|
qb
|
|
|
|
.where('assign.expiresAt IS NULL')
|
|
|
|
.orWhere('assign.expiresAt > :now', { now: new Date() });
|
2023-02-28 19:20:03 -06:00
|
|
|
}))
|
|
|
|
.getCount();
|
2023-01-12 06:02:26 -06:00
|
|
|
|
2023-01-15 05:52:53 -06:00
|
|
|
const policies = { ...role.policies };
|
|
|
|
for (const [k, v] of Object.entries(DEFAULT_POLICIES)) {
|
|
|
|
if (policies[k] == null) policies[k] = {
|
2023-01-12 06:02:26 -06:00
|
|
|
useDefault: true,
|
2023-01-15 04:10:39 -06:00
|
|
|
priority: 0,
|
2023-01-12 06:02:26 -06:00
|
|
|
value: v,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return await awaitAll({
|
|
|
|
id: role.id,
|
2023-10-15 20:45:22 -05:00
|
|
|
createdAt: this.idService.parse(role.id).date.toISOString(),
|
2023-01-12 06:02:26 -06:00
|
|
|
updatedAt: role.updatedAt.toISOString(),
|
|
|
|
name: role.name,
|
|
|
|
description: role.description,
|
|
|
|
color: role.color,
|
2023-02-04 19:37:03 -06:00
|
|
|
iconUrl: role.iconUrl,
|
2023-01-12 20:03:54 -06:00
|
|
|
target: role.target,
|
|
|
|
condFormula: role.condFormula,
|
2023-01-12 06:02:26 -06:00
|
|
|
isPublic: role.isPublic,
|
|
|
|
isAdministrator: role.isAdministrator,
|
|
|
|
isModerator: role.isModerator,
|
2023-04-20 06:02:50 -05:00
|
|
|
isExplorable: role.isExplorable,
|
2023-02-04 19:37:03 -06:00
|
|
|
asBadge: role.asBadge,
|
2023-01-12 06:02:26 -06:00
|
|
|
canEditMembersByModerator: role.canEditMembersByModerator,
|
2023-03-12 01:38:08 -06:00
|
|
|
displayOrder: role.displayOrder,
|
2023-01-15 05:52:53 -06:00
|
|
|
policies: policies,
|
2023-02-28 19:20:03 -06:00
|
|
|
usersCount: assignedCount,
|
2023-01-12 06:02:26 -06:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
@bindThis
|
|
|
|
public packMany(
|
|
|
|
roles: any[],
|
2023-08-16 03:51:28 -05:00
|
|
|
me: { id: MiUser['id'] },
|
2023-01-12 06:02:26 -06:00
|
|
|
) {
|
2023-02-21 23:43:18 -06:00
|
|
|
return Promise.all(roles.map(x => this.pack(x, me)));
|
2023-01-12 06:02:26 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|