mirror of
https://github.com/SyncrowIOT/backend.git
synced 2025-11-27 10:44:54 +00:00
Simplify user retrieval and normalization in ProjectUserService
This commit is contained in:
@ -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),
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user