2022-03-26 01:34:00 -05:00
|
|
|
import { db } from '@/db/postgre.js';
|
2022-02-26 20:07:39 -06:00
|
|
|
import { UserGroup } from '@/models/entities/user-group.js';
|
|
|
|
import { UserGroupJoinings } from '../index.js';
|
|
|
|
import { Packed } from '@/misc/schema.js';
|
2019-05-18 06:36:33 -05:00
|
|
|
|
2022-03-26 01:34:00 -05:00
|
|
|
export const UserGroupRepository = db.getRepository(UserGroup).extend({
|
|
|
|
async pack(
|
2019-05-18 06:36:33 -05:00
|
|
|
src: UserGroup['id'] | UserGroup,
|
2021-09-22 08:35:55 -05:00
|
|
|
): Promise<Packed<'UserGroup'>> {
|
2022-03-26 01:34:00 -05:00
|
|
|
const userGroup = typeof src === 'object' ? src : await this.findOneByOrFail({ id: src });
|
2019-05-18 06:36:33 -05:00
|
|
|
|
2022-03-26 01:34:00 -05:00
|
|
|
const users = await UserGroupJoinings.findBy({
|
2021-12-09 08:58:30 -06:00
|
|
|
userGroupId: userGroup.id,
|
2019-05-18 06:36:33 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
return {
|
|
|
|
id: userGroup.id,
|
|
|
|
createdAt: userGroup.createdAt.toISOString(),
|
|
|
|
name: userGroup.name,
|
2019-05-21 22:58:44 -05:00
|
|
|
ownerId: userGroup.userId,
|
2021-12-09 08:58:30 -06:00
|
|
|
userIds: users.map(x => x.userId),
|
2019-05-18 06:36:33 -05:00
|
|
|
};
|
2022-03-26 01:34:00 -05:00
|
|
|
},
|
|
|
|
});
|