mirror of
https://github.com/SyncrowIOT/backend.git
synced 2025-11-26 12:24:54 +00:00
Refactor activation code handling and user space verification
This commit is contained in:
@ -76,9 +76,7 @@ export class InviteUserController {
|
|||||||
async activationCodeController(
|
async activationCodeController(
|
||||||
@Body() activateCodeDto: ActivateCodeDto,
|
@Body() activateCodeDto: ActivateCodeDto,
|
||||||
): Promise<BaseResponseDto> {
|
): Promise<BaseResponseDto> {
|
||||||
return await this.inviteUserService.activationCodeController(
|
return await this.inviteUserService.activationCode(activateCodeDto);
|
||||||
activateCodeDto,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(JwtAuthGuard)
|
||||||
|
|||||||
@ -23,12 +23,14 @@ import { SpaceModelRepository } from '@app/common/modules/space-model';
|
|||||||
import { CommunityRepository } from '@app/common/modules/community/repositories';
|
import { CommunityRepository } from '@app/common/modules/community/repositories';
|
||||||
import { ProjectRepository } from '@app/common/modules/project/repositiories';
|
import { ProjectRepository } from '@app/common/modules/project/repositiories';
|
||||||
import { TuyaService } from '@app/common/integrations/tuya/services/tuya.service';
|
import { TuyaService } from '@app/common/integrations/tuya/services/tuya.service';
|
||||||
import { UserSpaceService } from 'src/users/services';
|
import { UserService, UserSpaceService } from 'src/users/services';
|
||||||
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
||||||
import { DeviceUserPermissionRepository } from '@app/common/modules/device/repositories';
|
import { DeviceUserPermissionRepository } from '@app/common/modules/device/repositories';
|
||||||
import { PermissionTypeRepository } from '@app/common/modules/permission/repositories';
|
import { PermissionTypeRepository } from '@app/common/modules/permission/repositories';
|
||||||
import { ProjectUserService } from 'src/project/services/project-user.service';
|
import { ProjectUserService } from 'src/project/services/project-user.service';
|
||||||
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
|
import { RegionRepository } from '@app/common/modules/region/repositories';
|
||||||
|
import { TimeZoneRepository } from '@app/common/modules/timezone/repositories';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [ConfigModule, InviteUserRepositoryModule],
|
imports: [ConfigModule, InviteUserRepositoryModule],
|
||||||
@ -55,6 +57,9 @@ import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
|||||||
ProjectUserService,
|
ProjectUserService,
|
||||||
RoleTypeRepository,
|
RoleTypeRepository,
|
||||||
InviteSpaceRepository,
|
InviteSpaceRepository,
|
||||||
|
UserService,
|
||||||
|
RegionRepository,
|
||||||
|
TimeZoneRepository,
|
||||||
],
|
],
|
||||||
exports: [InviteUserService],
|
exports: [InviteUserService],
|
||||||
})
|
})
|
||||||
|
|||||||
@ -29,6 +29,7 @@ import {
|
|||||||
UpdateUserInvitationDto,
|
UpdateUserInvitationDto,
|
||||||
} from '../dtos/update.invite-user.dto';
|
} from '../dtos/update.invite-user.dto';
|
||||||
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
|
import { InviteUserEntity } from '@app/common/modules/Invite-user/entities';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class InviteUserService {
|
export class InviteUserService {
|
||||||
@ -188,76 +189,35 @@ export class InviteUserService {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
async activationCodeController(
|
async activationCode(dto: ActivateCodeDto): Promise<BaseResponseDto> {
|
||||||
dto: ActivateCodeDto,
|
|
||||||
): Promise<BaseResponseDto> {
|
|
||||||
try {
|
|
||||||
const { activationCode, userUuid } = dto;
|
const { activationCode, userUuid } = dto;
|
||||||
const user = await this.userRepository.findOne({
|
|
||||||
where: { uuid: userUuid, isActive: true, isUserVerified: true },
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!user) {
|
try {
|
||||||
throw new HttpException('User not found', HttpStatus.NOT_FOUND);
|
const user = await this.getUser(userUuid);
|
||||||
}
|
|
||||||
const { email } = user;
|
|
||||||
const invitedUser = await this.inviteUserRepository.findOne({
|
const invitedUser = await this.inviteUserRepository.findOne({
|
||||||
where: {
|
where: {
|
||||||
email,
|
email: user.email,
|
||||||
invitationCode: activationCode,
|
|
||||||
status: UserStatusEnum.INVITED,
|
status: UserStatusEnum.INVITED,
|
||||||
isActive: true,
|
isActive: true,
|
||||||
},
|
},
|
||||||
relations: ['project', 'spaces.space.community', 'roleType'],
|
relations: ['project', 'spaces.space.community', 'roleType'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!invitedUser) {
|
if (invitedUser) {
|
||||||
|
if (invitedUser.invitationCode !== activationCode) {
|
||||||
throw new HttpException(
|
throw new HttpException(
|
||||||
'Invalid activation code',
|
'Invalid activation code',
|
||||||
HttpStatus.BAD_REQUEST,
|
HttpStatus.BAD_REQUEST,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (const invitedSpace of invitedUser.spaces) {
|
// Handle invited user with valid activation code
|
||||||
try {
|
await this.handleInvitedUser(user, invitedUser);
|
||||||
const deviceUUIDs =
|
} else {
|
||||||
await this.userSpaceService.getDeviceUUIDsForSpace(
|
// Handle case for non-invited user
|
||||||
invitedSpace.space.uuid,
|
await this.handleNonInvitedUser(activationCode, userUuid);
|
||||||
);
|
|
||||||
|
|
||||||
await this.userSpaceService.addUserPermissionsToDevices(
|
|
||||||
userUuid,
|
|
||||||
deviceUUIDs,
|
|
||||||
);
|
|
||||||
|
|
||||||
await this.spaceUserService.associateUserToSpace({
|
|
||||||
communityUuid: invitedSpace.space.community.uuid,
|
|
||||||
spaceUuid: invitedSpace.space.uuid,
|
|
||||||
userUuid: user.uuid,
|
|
||||||
projectUuid: invitedUser.project.uuid,
|
|
||||||
});
|
|
||||||
} catch (spaceError) {
|
|
||||||
console.error(
|
|
||||||
`Error processing space ${invitedSpace.space.uuid}:`,
|
|
||||||
spaceError,
|
|
||||||
);
|
|
||||||
// Skip to the next space
|
|
||||||
continue;
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
await this.inviteUserRepository.update(
|
|
||||||
{ uuid: invitedUser.uuid },
|
|
||||||
{ status: UserStatusEnum.ACTIVE },
|
|
||||||
);
|
|
||||||
await this.userRepository.update(
|
|
||||||
{ uuid: userUuid },
|
|
||||||
{
|
|
||||||
project: { uuid: invitedUser.project.uuid },
|
|
||||||
inviteUser: { uuid: invitedUser.uuid },
|
|
||||||
roleType: { uuid: invitedUser.roleType.uuid },
|
|
||||||
},
|
|
||||||
);
|
|
||||||
return new SuccessResponseDto({
|
return new SuccessResponseDto({
|
||||||
statusCode: HttpStatus.OK,
|
statusCode: HttpStatus.OK,
|
||||||
success: true,
|
success: true,
|
||||||
@ -272,6 +232,73 @@ export class InviteUserService {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async getUser(userUuid: string): Promise<UserEntity> {
|
||||||
|
const user = await this.userRepository.findOne({
|
||||||
|
where: { uuid: userUuid, isActive: true, isUserVerified: true },
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!user) {
|
||||||
|
throw new HttpException('User not found', HttpStatus.NOT_FOUND);
|
||||||
|
}
|
||||||
|
return user;
|
||||||
|
}
|
||||||
|
|
||||||
|
private async handleNonInvitedUser(
|
||||||
|
activationCode: string,
|
||||||
|
userUuid: string,
|
||||||
|
): Promise<void> {
|
||||||
|
await this.userSpaceService.verifyCodeAndAddUserSpace(
|
||||||
|
{ inviteCode: activationCode },
|
||||||
|
userUuid,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private async handleInvitedUser(
|
||||||
|
user: UserEntity,
|
||||||
|
invitedUser: InviteUserEntity,
|
||||||
|
): Promise<void> {
|
||||||
|
for (const invitedSpace of invitedUser.spaces) {
|
||||||
|
try {
|
||||||
|
const deviceUUIDs = await this.userSpaceService.getDeviceUUIDsForSpace(
|
||||||
|
invitedSpace.space.uuid,
|
||||||
|
);
|
||||||
|
|
||||||
|
await this.userSpaceService.addUserPermissionsToDevices(
|
||||||
|
user.uuid,
|
||||||
|
deviceUUIDs,
|
||||||
|
);
|
||||||
|
|
||||||
|
await this.spaceUserService.associateUserToSpace({
|
||||||
|
communityUuid: invitedSpace.space.community.uuid,
|
||||||
|
spaceUuid: invitedSpace.space.uuid,
|
||||||
|
userUuid: user.uuid,
|
||||||
|
projectUuid: invitedUser.project.uuid,
|
||||||
|
});
|
||||||
|
} catch (spaceError) {
|
||||||
|
console.error(
|
||||||
|
`Error processing space ${invitedSpace.space.uuid}:`,
|
||||||
|
spaceError,
|
||||||
|
);
|
||||||
|
continue; // Skip to the next space
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update invited user and associated user data
|
||||||
|
await this.inviteUserRepository.update(
|
||||||
|
{ uuid: invitedUser.uuid },
|
||||||
|
{ status: UserStatusEnum.ACTIVE },
|
||||||
|
);
|
||||||
|
await this.userRepository.update(
|
||||||
|
{ uuid: user.uuid },
|
||||||
|
{
|
||||||
|
project: { uuid: invitedUser.project.uuid },
|
||||||
|
inviteUser: { uuid: invitedUser.uuid },
|
||||||
|
roleType: { uuid: invitedUser.roleType.uuid },
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
async updateUserInvitation(
|
async updateUserInvitation(
|
||||||
dto: UpdateUserInvitationDto,
|
dto: UpdateUserInvitationDto,
|
||||||
invitedUserUuid: string,
|
invitedUserUuid: string,
|
||||||
|
|||||||
@ -1,20 +1,11 @@
|
|||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import {
|
import { Controller, Get, Param, UseGuards } from '@nestjs/common';
|
||||||
Body,
|
|
||||||
Controller,
|
|
||||||
Get,
|
|
||||||
HttpException,
|
|
||||||
HttpStatus,
|
|
||||||
Param,
|
|
||||||
Post,
|
|
||||||
UseGuards,
|
|
||||||
} from '@nestjs/common';
|
|
||||||
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
||||||
import { UserSpaceService } from '../services';
|
import { UserSpaceService } from '../services';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { AddUserSpaceUsingCodeDto, UserParamDto } from '../dtos';
|
import { UserParamDto } from '../dtos';
|
||||||
|
|
||||||
@ApiTags('User Module')
|
@ApiTags('User Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -36,36 +27,4 @@ export class UserSpaceController {
|
|||||||
): Promise<BaseResponseDto> {
|
): Promise<BaseResponseDto> {
|
||||||
return this.userSpaceService.getSpacesForUser(params.userUuid);
|
return this.userSpaceService.getSpacesForUser(params.userUuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
|
||||||
@UseGuards(JwtAuthGuard)
|
|
||||||
@Post('/verify-code')
|
|
||||||
@ApiOperation({
|
|
||||||
summary:
|
|
||||||
ControllerRoute.USER_SPACE.ACTIONS.VERIFY_CODE_AND_ADD_USER_SPACE_SUMMARY,
|
|
||||||
description:
|
|
||||||
ControllerRoute.USER_SPACE.ACTIONS
|
|
||||||
.VERIFY_CODE_AND_ADD_USER_SPACE_DESCRIPTION,
|
|
||||||
})
|
|
||||||
async verifyCodeAndAddUserSpace(
|
|
||||||
@Body() dto: AddUserSpaceUsingCodeDto,
|
|
||||||
@Param() params: UserParamDto,
|
|
||||||
) {
|
|
||||||
try {
|
|
||||||
await this.userSpaceService.verifyCodeAndAddUserSpace(
|
|
||||||
dto,
|
|
||||||
params.userUuid,
|
|
||||||
);
|
|
||||||
return {
|
|
||||||
statusCode: HttpStatus.CREATED,
|
|
||||||
success: true,
|
|
||||||
message: 'user space added successfully',
|
|
||||||
};
|
|
||||||
} catch (error) {
|
|
||||||
throw new HttpException(
|
|
||||||
error.message || 'Internal server error',
|
|
||||||
error.status || HttpStatus.INTERNAL_SERVER_ERROR,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,4 +1,9 @@
|
|||||||
import { HttpException, HttpStatus, Injectable } from '@nestjs/common';
|
import {
|
||||||
|
BadRequestException,
|
||||||
|
HttpException,
|
||||||
|
HttpStatus,
|
||||||
|
Injectable,
|
||||||
|
} from '@nestjs/common';
|
||||||
import { UserSpaceRepository } from '@app/common/modules/user/repositories';
|
import { UserSpaceRepository } from '@app/common/modules/user/repositories';
|
||||||
import { SuccessResponseDto } from '@app/common/dto/success.response.dto';
|
import { SuccessResponseDto } from '@app/common/dto/success.response.dto';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
@ -11,6 +16,10 @@ import { CommonErrorCodes } from '@app/common/constants/error-codes.enum';
|
|||||||
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
||||||
import { PermissionType } from '@app/common/constants/permission-type.enum';
|
import { PermissionType } from '@app/common/constants/permission-type.enum';
|
||||||
import { InviteSpaceEntity } from '@app/common/modules/space/entities/invite-space.entity';
|
import { InviteSpaceEntity } from '@app/common/modules/space/entities/invite-space.entity';
|
||||||
|
import { UserService } from './user.service';
|
||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
import { InviteUserRepository } from '@app/common/modules/Invite-user/repositiories';
|
||||||
|
import { UserStatusEnum } from '@app/common/constants/user-status.enum';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class UserSpaceService {
|
export class UserSpaceService {
|
||||||
@ -18,6 +27,8 @@ export class UserSpaceService {
|
|||||||
private readonly userSpaceRepository: UserSpaceRepository,
|
private readonly userSpaceRepository: UserSpaceRepository,
|
||||||
private readonly spaceRepository: SpaceRepository,
|
private readonly spaceRepository: SpaceRepository,
|
||||||
private readonly inviteSpaceRepository: InviteSpaceRepository,
|
private readonly inviteSpaceRepository: InviteSpaceRepository,
|
||||||
|
private readonly userService: UserService,
|
||||||
|
private readonly inviteUserRepository: InviteUserRepository,
|
||||||
private readonly userDevicePermissionService: UserDevicePermissionService,
|
private readonly userDevicePermissionService: UserDevicePermissionService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
@ -41,17 +52,24 @@ export class UserSpaceService {
|
|||||||
params: AddUserSpaceUsingCodeDto,
|
params: AddUserSpaceUsingCodeDto,
|
||||||
userUuid: string,
|
userUuid: string,
|
||||||
) {
|
) {
|
||||||
|
const { inviteCode } = params;
|
||||||
try {
|
try {
|
||||||
const inviteSpace = await this.findInviteSpaceByInviteCode(
|
const inviteSpace = await this.findInviteSpaceByInviteCode(inviteCode);
|
||||||
params.inviteCode,
|
const user = await this.userService.getUserDetailsByUserUuid(
|
||||||
|
userUuid,
|
||||||
|
true,
|
||||||
);
|
);
|
||||||
|
await this.checkSpaceMemberRole(user);
|
||||||
await this.addUserToSpace(userUuid, inviteSpace.space.uuid);
|
await this.addUserToSpace(userUuid, inviteSpace.space.uuid);
|
||||||
|
|
||||||
const deviceUUIDs = await this.getDeviceUUIDsForSpace(inviteSpace.uuid);
|
const deviceUUIDs = await this.getDeviceUUIDsForSpace(inviteSpace.uuid);
|
||||||
|
|
||||||
await this.addUserPermissionsToDevices(userUuid, deviceUUIDs);
|
await this.addUserPermissionsToDevices(userUuid, deviceUUIDs);
|
||||||
|
await this.addUserAsActiveInvitation(
|
||||||
|
user,
|
||||||
|
inviteSpace.space.uuid,
|
||||||
|
inviteCode,
|
||||||
|
);
|
||||||
await this.clearSpaceInvitationCode(inviteSpace.uuid);
|
await this.clearSpaceInvitationCode(inviteSpace.uuid);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
if (err instanceof HttpException) {
|
if (err instanceof HttpException) {
|
||||||
@ -64,7 +82,20 @@ export class UserSpaceService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
private async checkSpaceMemberRole(user: any) {
|
||||||
|
try {
|
||||||
|
if (user.role.type !== RoleType.SPACE_MEMBER) {
|
||||||
|
throw new BadRequestException(
|
||||||
|
'You have to be a space member to join this space',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
throw new HttpException(
|
||||||
|
err.message || 'User not found',
|
||||||
|
err.status || HttpStatus.NOT_FOUND,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
private async findInviteSpaceByInviteCode(
|
private async findInviteSpaceByInviteCode(
|
||||||
inviteCode: string,
|
inviteCode: string,
|
||||||
): Promise<InviteSpaceEntity> {
|
): Promise<InviteSpaceEntity> {
|
||||||
@ -90,7 +121,47 @@ export class UserSpaceService {
|
|||||||
{ isActive: false },
|
{ isActive: false },
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
async getProjectBySpaceUuid(spaceUuid: string) {
|
||||||
|
try {
|
||||||
|
const project = await this.spaceRepository.findOne({
|
||||||
|
where: {
|
||||||
|
uuid: spaceUuid,
|
||||||
|
},
|
||||||
|
relations: ['community.project'],
|
||||||
|
});
|
||||||
|
return project;
|
||||||
|
} catch (error) {
|
||||||
|
throw new HttpException('Space not found', HttpStatus.NOT_FOUND);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private async addUserAsActiveInvitation(
|
||||||
|
user: any,
|
||||||
|
spaceUuid: string,
|
||||||
|
inviteCode: string,
|
||||||
|
) {
|
||||||
|
try {
|
||||||
|
const space = await this.getProjectBySpaceUuid(spaceUuid);
|
||||||
|
|
||||||
|
const inviteUser = this.inviteUserRepository.create({
|
||||||
|
firstName: user.firstName,
|
||||||
|
lastName: user.lastName,
|
||||||
|
email: user.email,
|
||||||
|
jobTitle: null,
|
||||||
|
phoneNumber: null,
|
||||||
|
roleType: { uuid: user.role.uuid },
|
||||||
|
status: UserStatusEnum.ACTIVE,
|
||||||
|
invitationCode: inviteCode,
|
||||||
|
invitedBy: RoleType.SPACE_OWNER,
|
||||||
|
project: { uuid: space.community.project.uuid },
|
||||||
|
});
|
||||||
|
await this.inviteUserRepository.save(inviteUser);
|
||||||
|
} catch (err) {
|
||||||
|
throw new HttpException(
|
||||||
|
err.message || 'Internal Server Error',
|
||||||
|
HttpStatus.INTERNAL_SERVER_ERROR,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
private async addUserToSpace(userUuid: string, spaceUuid: string) {
|
private async addUserToSpace(userUuid: string, spaceUuid: string) {
|
||||||
try {
|
try {
|
||||||
const user = await this.addUserSpace({ userUuid, spaceUuid });
|
const user = await this.addUserSpace({ userUuid, spaceUuid });
|
||||||
|
|||||||
@ -23,13 +23,15 @@ export class UserService {
|
|||||||
private readonly regionRepository: RegionRepository,
|
private readonly regionRepository: RegionRepository,
|
||||||
private readonly timeZoneRepository: TimeZoneRepository,
|
private readonly timeZoneRepository: TimeZoneRepository,
|
||||||
) {}
|
) {}
|
||||||
async getUserDetailsByUserUuid(userUuid: string) {
|
async getUserDetailsByUserUuid(userUuid: string, withRole = false) {
|
||||||
try {
|
try {
|
||||||
const user = await this.userRepository.findOne({
|
const user = await this.userRepository.findOne({
|
||||||
where: {
|
where: {
|
||||||
uuid: userUuid,
|
uuid: userUuid,
|
||||||
},
|
},
|
||||||
relations: ['region', 'timezone'],
|
...(withRole
|
||||||
|
? { relations: ['roleType'] }
|
||||||
|
: { relations: ['region', 'timezone'] }),
|
||||||
});
|
});
|
||||||
if (!user) {
|
if (!user) {
|
||||||
throw new BadRequestException('Invalid room UUID');
|
throw new BadRequestException('Invalid room UUID');
|
||||||
@ -39,13 +41,14 @@ export class UserService {
|
|||||||
const cleanedProfilePicture = removeBase64Prefix(user.profilePicture);
|
const cleanedProfilePicture = removeBase64Prefix(user.profilePicture);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
uuid: user.uuid,
|
uuid: user?.uuid,
|
||||||
email: user.email,
|
email: user?.email,
|
||||||
firstName: user.firstName,
|
firstName: user?.firstName,
|
||||||
lastName: user.lastName,
|
lastName: user?.lastName,
|
||||||
profilePicture: cleanedProfilePicture,
|
profilePicture: cleanedProfilePicture,
|
||||||
region: user.region,
|
region: user?.region,
|
||||||
timeZone: user.timezone,
|
timeZone: user?.timezone,
|
||||||
|
...(withRole && { role: user?.roleType }),
|
||||||
};
|
};
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
if (err instanceof BadRequestException) {
|
if (err instanceof BadRequestException) {
|
||||||
|
|||||||
@ -19,6 +19,7 @@ import {
|
|||||||
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
import { UserDevicePermissionService } from 'src/user-device-permission/services';
|
||||||
import { DeviceUserPermissionRepository } from '@app/common/modules/device/repositories';
|
import { DeviceUserPermissionRepository } from '@app/common/modules/device/repositories';
|
||||||
import { PermissionTypeRepository } from '@app/common/modules/permission/repositories';
|
import { PermissionTypeRepository } from '@app/common/modules/permission/repositories';
|
||||||
|
import { InviteUserRepository } from '@app/common/modules/Invite-user/repositiories';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [ConfigModule, CommunityModule],
|
imports: [ConfigModule, CommunityModule],
|
||||||
@ -36,6 +37,7 @@ import { PermissionTypeRepository } from '@app/common/modules/permission/reposit
|
|||||||
PermissionTypeRepository,
|
PermissionTypeRepository,
|
||||||
UserSpaceService,
|
UserSpaceService,
|
||||||
InviteSpaceRepository,
|
InviteSpaceRepository,
|
||||||
|
InviteUserRepository,
|
||||||
],
|
],
|
||||||
exports: [UserService],
|
exports: [UserService],
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user