Simplify user retrieval and normalization in ProjectUserService

This commit is contained in:
faris Aljohari
2025-01-04 04:19:48 -06:00
parent 9c03b9e95d
commit eac5fce859

View File

@ -1,18 +1,13 @@
import { HttpException, HttpStatus, Injectable } from '@nestjs/common'; import { HttpException, HttpStatus, Injectable } from '@nestjs/common';
import { BaseResponseDto } from '@app/common/dto/base.response.dto'; import { BaseResponseDto } from '@app/common/dto/base.response.dto';
import { SuccessResponseDto } from '@app/common/dto/success.response.dto'; import { SuccessResponseDto } from '@app/common/dto/success.response.dto';
import { UserStatusEnum } from '@app/common/constants/user-status.enum';
import { RoleType } from '@app/common/constants/role.type.enum';
import { InviteUserRepository } from '@app/common/modules/Invite-user/repositiories'; import { InviteUserRepository } from '@app/common/modules/Invite-user/repositiories';
import { UserRepository } from '@app/common/modules/user/repositories';
import { ProjectService } from './project.service'; import { ProjectService } from './project.service';
@Injectable() @Injectable()
export class ProjectUserService { export class ProjectUserService {
constructor( constructor(
private readonly inviteUserRepository: InviteUserRepository, private readonly inviteUserRepository: InviteUserRepository,
private readonly userRepository: UserRepository,
private readonly projectService: ProjectService, private readonly projectService: ProjectService,
) {} ) {}
@ -25,8 +20,7 @@ export class ProjectUserService {
HttpStatus.NOT_FOUND, HttpStatus.NOT_FOUND,
); );
} }
// Fetch invited users const allUsers = await this.inviteUserRepository.find({
const invitedUsers = await this.inviteUserRepository.find({
where: { project: { uuid }, isActive: true }, where: { project: { uuid }, isActive: true },
select: [ select: [
'uuid', 'uuid',
@ -38,35 +32,20 @@ export class ProjectUserService {
'phoneNumber', 'phoneNumber',
'jobTitle', 'jobTitle',
'invitedBy', 'invitedBy',
'isEnabled',
], ],
relations: ['roleType'], relations: ['roleType'],
}); });
// Fetch project users
const users = await this.userRepository.find({
where: { project: { uuid }, isActive: true },
select: ['uuid', 'firstName', 'lastName', 'email', 'createdAt'],
relations: ['roleType'],
});
// Combine both arrays
const allUsers = [...users, ...invitedUsers];
const normalizedUsers = allUsers.map((user) => { const normalizedUsers = allUsers.map((user) => {
const createdAt = new Date(user.createdAt); const createdAt = new Date(user.createdAt);
const createdDate = createdAt.toLocaleDateString(); const createdDate = createdAt.toLocaleDateString();
const createdTime = createdAt.toLocaleTimeString(); const createdTime = createdAt.toLocaleTimeString();
// Normalize user properties
const normalizedProps = this.normalizeUserProperties(user);
// Return the normalized user object
return { return {
...user, ...user,
roleType: user.roleType.type,
createdDate, createdDate,
createdTime, createdTime,
...normalizedProps,
}; };
}); });
@ -91,8 +70,7 @@ export class ProjectUserService {
userUuid: string, userUuid: string,
): Promise<BaseResponseDto> { ): Promise<BaseResponseDto> {
try { try {
let user; const user = await this.inviteUserRepository.findOne({
user = await this.inviteUserRepository.findOne({
where: { where: {
project: { uuid: projectUuid }, project: { uuid: projectUuid },
uuid: userUuid, uuid: userUuid,
@ -108,31 +86,28 @@ export class ProjectUserService {
'phoneNumber', 'phoneNumber',
'jobTitle', 'jobTitle',
'invitedBy', 'invitedBy',
'isEnabled',
], ],
relations: ['roleType', 'spaces.space'], relations: ['roleType', 'spaces.space'],
}); });
if (!user) {
user = await this.userRepository.findOne({
where: {
project: { uuid: projectUuid },
uuid: userUuid,
isActive: true,
},
select: ['uuid', 'firstName', 'lastName', 'email', 'createdAt'],
relations: ['roleType', 'userSpaces.space'],
});
}
if (!user) { if (!user) {
throw new HttpException( throw new HttpException(
`User with ID ${userUuid} not found in project ${projectUuid}`, `User with ID ${userUuid} not found in project ${projectUuid}`,
HttpStatus.NOT_FOUND, HttpStatus.NOT_FOUND,
); );
} }
const responseData = this.formatUserResponse(user); const createdAt = new Date(user.createdAt);
const createdDate = createdAt.toLocaleDateString();
const createdTime = createdAt.toLocaleTimeString();
return new SuccessResponseDto({ return new SuccessResponseDto({
message: `User in project with ID ${projectUuid} retrieved successfully`, message: `User in project with ID ${projectUuid} retrieved successfully`,
data: responseData, data: {
...user,
roleType: user.roleType.type,
createdDate,
createdTime,
spaces: user.spaces.map((space) => space.space),
},
statusCode: HttpStatus.OK, statusCode: HttpStatus.OK,
}); });
} catch (error) { } catch (error) {
@ -146,29 +121,4 @@ export class ProjectUserService {
); );
} }
} }
private formatUserResponse(user: any) {
const createdAt = new Date(user.createdAt);
return {
uuid: user.uuid,
firstName: user.firstName,
lastName: user.lastName,
email: user.email,
createdDate: createdAt.toLocaleDateString(),
createdTime: createdAt.toLocaleTimeString(),
...this.normalizeUserProperties(user),
};
}
private normalizeUserProperties(user: any) {
return {
status: user.status ?? UserStatusEnum.ACTIVE,
invitedBy: user.invitedBy ?? RoleType.SPACE_MEMBER,
isEnabled: user.isEnabled ?? true,
phoneNumber: user.phoneNumber ?? null,
jobTitle: user.jobTitle ?? null,
roleType: user.roleType?.type ?? null,
spaces:
user?.spaces?.map((space: any) => space?.space) ??
user?.userSpaces?.map((space: any) => space?.space),
};
}
} }