mirror of
https://github.com/SyncrowIOT/backend.git
synced 2025-07-10 15:17:41 +00:00
Merge pull request #171 from SyncrowIOT/SP-901-be-invite-a-new-role-and-assign-spaces
Sp 901 be invite a new role and assign spaces
This commit is contained in:
@ -4,5 +4,5 @@ export class AuthInterface {
|
|||||||
uuid: string;
|
uuid: string;
|
||||||
sessionId: string;
|
sessionId: string;
|
||||||
id: number;
|
id: number;
|
||||||
roles?: string[];
|
role?: object;
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ export class AuthService {
|
|||||||
}
|
}
|
||||||
: undefined,
|
: undefined,
|
||||||
},
|
},
|
||||||
relations: ['roles.roleType'],
|
relations: ['roleType'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (!user.isUserVerified) {
|
if (!user.isUserVerified) {
|
||||||
@ -85,9 +85,8 @@ export class AuthService {
|
|||||||
email: user.email,
|
email: user.email,
|
||||||
userId: user.userId,
|
userId: user.userId,
|
||||||
uuid: user.uuid,
|
uuid: user.uuid,
|
||||||
type: user.type,
|
|
||||||
sessionId: user.sessionId,
|
sessionId: user.sessionId,
|
||||||
roles: user?.roles,
|
role: user?.role,
|
||||||
googleCode: user.googleCode,
|
googleCode: user.googleCode,
|
||||||
};
|
};
|
||||||
if (payload.googleCode) {
|
if (payload.googleCode) {
|
||||||
|
@ -31,7 +31,7 @@ export class JwtStrategy extends PassportStrategy(Strategy, 'jwt') {
|
|||||||
userUuid: payload.uuid,
|
userUuid: payload.uuid,
|
||||||
uuid: payload.uuid,
|
uuid: payload.uuid,
|
||||||
sessionId: payload.sessionId,
|
sessionId: payload.sessionId,
|
||||||
roles: payload?.roles,
|
role: payload?.role,
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
throw new BadRequestException('Unauthorized');
|
throw new BadRequestException('Unauthorized');
|
||||||
|
@ -34,7 +34,7 @@ export class RefreshTokenStrategy extends PassportStrategy(
|
|||||||
userUuid: payload.uuid,
|
userUuid: payload.uuid,
|
||||||
uuid: payload.uuid,
|
uuid: payload.uuid,
|
||||||
sessionId: payload.sessionId,
|
sessionId: payload.sessionId,
|
||||||
roles: payload?.roles,
|
role: payload?.role,
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
throw new BadRequestException('Unauthorized');
|
throw new BadRequestException('Unauthorized');
|
||||||
|
@ -721,4 +721,24 @@ export class ControllerRoute {
|
|||||||
'This endpoint deletes a user’s subscription for device messages.';
|
'This endpoint deletes a user’s subscription for device messages.';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
static INVITE_USER = class {
|
||||||
|
public static readonly ROUTE = 'invite-user';
|
||||||
|
static ACTIONS = class {
|
||||||
|
public static readonly CREATE_USER_INVITATION_SUMMARY =
|
||||||
|
'Create user invitation';
|
||||||
|
|
||||||
|
public static readonly CREATE_USER_INVITATION_DESCRIPTION =
|
||||||
|
'This endpoint creates an invitation for a user to assign to role and spaces.';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
static PERMISSION = class {
|
||||||
|
public static readonly ROUTE = 'permission';
|
||||||
|
static ACTIONS = class {
|
||||||
|
public static readonly GET_PERMISSION_BY_ROLE_SUMMARY =
|
||||||
|
'Get permissions by role';
|
||||||
|
|
||||||
|
public static readonly GET_PERMISSION_BY_ROLE_DESCRIPTION =
|
||||||
|
'This endpoint retrieves the permissions associated with a specific role.';
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
43
libs/common/src/constants/permissions-mapping.ts
Normal file
43
libs/common/src/constants/permissions-mapping.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
export const PermissionMapping = {
|
||||||
|
DEVICE_MANAGEMENT: {
|
||||||
|
DEVICE: ['SINGLE_CONTROL', 'VIEW', 'DELETE', 'UPDATE', 'BATCH_CONTROL'],
|
||||||
|
FIRMWARE: ['CONTROL', 'VIEW'],
|
||||||
|
},
|
||||||
|
COMMUNITY_MANAGEMENT: {
|
||||||
|
COMMUNITY: ['VIEW', 'ADD', 'UPDATE', 'DELETE'],
|
||||||
|
},
|
||||||
|
SPACE_MANAGEMENT: {
|
||||||
|
SPACE: [
|
||||||
|
'VIEW',
|
||||||
|
'ADD',
|
||||||
|
'UPDATE',
|
||||||
|
'DELETE',
|
||||||
|
'MODULE_ADD',
|
||||||
|
'ASSIGN_USER_TO_SPACE',
|
||||||
|
'DELETE_USER_FROM_SPACE',
|
||||||
|
],
|
||||||
|
SUBSPACE: [
|
||||||
|
'VIEW',
|
||||||
|
'ADD',
|
||||||
|
'UPDATE',
|
||||||
|
'DELETE',
|
||||||
|
'ASSIGN_DEVICE_TO_SUBSPACE',
|
||||||
|
'DELETE_DEVICE_FROM_SUBSPACE',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
DEVICE_WIZARD: {
|
||||||
|
DEVICE_WIZARD: ['VIEW_DEVICE_WIZARD'],
|
||||||
|
SPACE_DEVICE: ['VIEW_DEVICE_IN_SPACE', 'ASSIGN_DEVICE_TO_SPACE'],
|
||||||
|
SUBSPACE_DEVICE: ['VIEW_DEVICE_IN_SUBSPACE', 'UPDATE_DEVICE_IN_SUBSPACE'],
|
||||||
|
},
|
||||||
|
AUTOMATION_MANAGEMENT: {
|
||||||
|
AUTOMATION: ['VIEW', 'ADD', 'UPDATE', 'DELETE', 'CONTROL'],
|
||||||
|
SCENES: ['VIEW', 'ADD', 'UPDATE', 'DELETE', 'CONTROL'],
|
||||||
|
},
|
||||||
|
VISITOR_PASSWORD_MANAGEMENT: {
|
||||||
|
VISITOR_PASSWORD: ['VIEW', 'ADD', 'UPDATE', 'DELETE'],
|
||||||
|
},
|
||||||
|
USER_MANAGEMENT: {
|
||||||
|
USER: ['ADD'],
|
||||||
|
},
|
||||||
|
};
|
130
libs/common/src/constants/role-permissions.ts
Normal file
130
libs/common/src/constants/role-permissions.ts
Normal file
@ -0,0 +1,130 @@
|
|||||||
|
import { RoleType } from './role.type.enum';
|
||||||
|
|
||||||
|
export const RolePermissions = {
|
||||||
|
[RoleType.SUPER_ADMIN]: [
|
||||||
|
'DEVICE_SINGLE_CONTROL',
|
||||||
|
'DEVICE_VIEW',
|
||||||
|
'DEVICE_DELETE',
|
||||||
|
'DEVICE_UPDATE',
|
||||||
|
'DEVICE_BATCH_CONTROL',
|
||||||
|
'COMMUNITY_VIEW',
|
||||||
|
'COMMUNITY_ADD',
|
||||||
|
'COMMUNITY_UPDATE',
|
||||||
|
'COMMUNITY_DELETE',
|
||||||
|
'FIRMWARE_CONTROL',
|
||||||
|
'SPACE_VIEW',
|
||||||
|
'SPACE_ADD',
|
||||||
|
'SPACE_UPDATE',
|
||||||
|
'SPACE_DELETE',
|
||||||
|
'SPACE_MODULE_ADD',
|
||||||
|
'ASSIGN_USER_TO_SPACE',
|
||||||
|
'DELETE_USER_FROM_SPACE',
|
||||||
|
'SUBSPACE_VIEW',
|
||||||
|
'SUBSPACE_ADD',
|
||||||
|
'SUBSPACE_UPDATE',
|
||||||
|
'SUBSPACE_DELETE',
|
||||||
|
'ASSIGN_DEVICE_TO_SUBSPACE',
|
||||||
|
'DELETE_DEVICE_FROM_SUBSPACE',
|
||||||
|
'VIEW_DEVICE_WIZARD',
|
||||||
|
'VIEW_DEVICE_IN_SUBSPACE',
|
||||||
|
'VIEW_DEVICE_IN_SPACE',
|
||||||
|
'UPDATE_DEVICE_IN_SUBSPACE',
|
||||||
|
'ASSIGN_DEVICE_TO_SPACE',
|
||||||
|
'AUTOMATION_VIEW',
|
||||||
|
'AUTOMATION_ADD',
|
||||||
|
'AUTOMATION_UPDATE',
|
||||||
|
'AUTOMATION_DELETE',
|
||||||
|
'AUTOMATION_CONTROL',
|
||||||
|
'SCENES_VIEW',
|
||||||
|
'SCENES_ADD',
|
||||||
|
'SCENES_UPDATE',
|
||||||
|
'SCENES_DELETE',
|
||||||
|
'SCENES_CONTROL',
|
||||||
|
'VISITOR_PASSWORD_VIEW',
|
||||||
|
'VISITOR_PASSWORD_ADD',
|
||||||
|
'USER_ADD',
|
||||||
|
],
|
||||||
|
[RoleType.ADMIN]: [
|
||||||
|
'DEVICE_SINGLE_CONTROL',
|
||||||
|
'DEVICE_VIEW',
|
||||||
|
'DEVICE_DELETE',
|
||||||
|
'DEVICE_UPDATE',
|
||||||
|
'DEVICE_BATCH_CONTROL',
|
||||||
|
'COMMUNITY_VIEW',
|
||||||
|
'COMMUNITY_ADD',
|
||||||
|
'COMMUNITY_UPDATE',
|
||||||
|
'COMMUNITY_DELETE',
|
||||||
|
'FIRMWARE_CONTROL',
|
||||||
|
'SPACE_VIEW',
|
||||||
|
'SPACE_ADD',
|
||||||
|
'SPACE_UPDATE',
|
||||||
|
'SPACE_DELETE',
|
||||||
|
'SPACE_MODULE_ADD',
|
||||||
|
'ASSIGN_USER_TO_SPACE',
|
||||||
|
'DELETE_USER_FROM_SPACE',
|
||||||
|
'SUBSPACE_VIEW',
|
||||||
|
'SUBSPACE_ADD',
|
||||||
|
'SUBSPACE_UPDATE',
|
||||||
|
'SUBSPACE_DELETE',
|
||||||
|
'ASSIGN_DEVICE_TO_SUBSPACE',
|
||||||
|
'DELETE_DEVICE_FROM_SUBSPACE',
|
||||||
|
'VIEW_DEVICE_WIZARD',
|
||||||
|
'VIEW_DEVICE_IN_SUBSPACE',
|
||||||
|
'VIEW_DEVICE_IN_SPACE',
|
||||||
|
'UPDATE_DEVICE_IN_SUBSPACE',
|
||||||
|
'ASSIGN_DEVICE_TO_SPACE',
|
||||||
|
'AUTOMATION_VIEW',
|
||||||
|
'AUTOMATION_ADD',
|
||||||
|
'AUTOMATION_UPDATE',
|
||||||
|
'AUTOMATION_DELETE',
|
||||||
|
'AUTOMATION_CONTROL',
|
||||||
|
'SCENES_VIEW',
|
||||||
|
'SCENES_ADD',
|
||||||
|
'SCENES_UPDATE',
|
||||||
|
'SCENES_DELETE',
|
||||||
|
'SCENES_CONTROL',
|
||||||
|
'VISITOR_PASSWORD_VIEW',
|
||||||
|
'VISITOR_PASSWORD_ADD',
|
||||||
|
'USER_ADD',
|
||||||
|
],
|
||||||
|
[RoleType.SPACE_MEMBER]: [
|
||||||
|
'DEVICE_SINGLE_CONTROL',
|
||||||
|
'DEVICE_VIEW',
|
||||||
|
'SPACE_VIEW',
|
||||||
|
'SUBSPACE_VIEW',
|
||||||
|
'VIEW_DEVICE_WIZARD',
|
||||||
|
'VIEW_DEVICE_IN_SUBSPACE',
|
||||||
|
'VIEW_DEVICE_IN_SPACE',
|
||||||
|
'AUTOMATION_VIEW',
|
||||||
|
'AUTOMATION_CONTROL',
|
||||||
|
'SCENES_VIEW',
|
||||||
|
'SCENES_CONTROL',
|
||||||
|
'VISITOR_PASSWORD_VIEW',
|
||||||
|
],
|
||||||
|
[RoleType.SPACE_OWNER]: [
|
||||||
|
'DEVICE_SINGLE_CONTROL',
|
||||||
|
'DEVICE_VIEW',
|
||||||
|
'FIRMWARE_CONTROL',
|
||||||
|
'FIRMWARE_VIEW',
|
||||||
|
'SPACE_VIEW',
|
||||||
|
'SPACE_MEMBER_ADD',
|
||||||
|
'SUBSPACE_VIEW',
|
||||||
|
'SUBSPACE_ADD',
|
||||||
|
'SUBSPACE_UPDATE',
|
||||||
|
'SUBSPACE_DELETE',
|
||||||
|
'AUTOMATION_VIEW',
|
||||||
|
'AUTOMATION_ADD',
|
||||||
|
'AUTOMATION_UPDATE',
|
||||||
|
'AUTOMATION_DELETE',
|
||||||
|
'AUTOMATION_CONTROL',
|
||||||
|
'SCENES_VIEW',
|
||||||
|
'SCENES_ADD',
|
||||||
|
'SCENES_UPDATE',
|
||||||
|
'SCENES_DELETE',
|
||||||
|
'SCENES_CONTROL',
|
||||||
|
'VISITOR_PASSWORD_VIEW',
|
||||||
|
'VISITOR_PASSWORD_ADD',
|
||||||
|
'VISITOR_PASSWORD_UPDATE',
|
||||||
|
'VISITOR_PASSWORD_DELETE',
|
||||||
|
],
|
||||||
|
};
|
@ -1,4 +1,6 @@
|
|||||||
export enum RoleType {
|
export enum RoleType {
|
||||||
SUPER_ADMIN = 'SUPER_ADMIN',
|
SUPER_ADMIN = 'SUPER_ADMIN',
|
||||||
ADMIN = 'ADMIN',
|
ADMIN = 'ADMIN',
|
||||||
|
SPACE_OWNER = 'SPACE_OWNER',
|
||||||
|
SPACE_MEMBER = 'SPACE_MEMBER',
|
||||||
}
|
}
|
||||||
|
5
libs/common/src/constants/user-status.enum.ts
Normal file
5
libs/common/src/constants/user-status.enum.ts
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
export enum UserStatusEnum {
|
||||||
|
ACTIVE = 'active',
|
||||||
|
INVITED = 'invited',
|
||||||
|
DISABLED = 'disabled',
|
||||||
|
}
|
@ -15,7 +15,6 @@ import {
|
|||||||
} from '../modules/space/entities';
|
} from '../modules/space/entities';
|
||||||
import { UserSpaceEntity } from '../modules/user/entities';
|
import { UserSpaceEntity } from '../modules/user/entities';
|
||||||
import { DeviceUserPermissionEntity } from '../modules/device/entities';
|
import { DeviceUserPermissionEntity } from '../modules/device/entities';
|
||||||
import { UserRoleEntity } from '../modules/user/entities';
|
|
||||||
import { RoleTypeEntity } from '../modules/role-type/entities';
|
import { RoleTypeEntity } from '../modules/role-type/entities';
|
||||||
import { UserNotificationEntity } from '../modules/user/entities';
|
import { UserNotificationEntity } from '../modules/user/entities';
|
||||||
import { DeviceNotificationEntity } from '../modules/device/entities';
|
import { DeviceNotificationEntity } from '../modules/device/entities';
|
||||||
@ -34,6 +33,10 @@ import {
|
|||||||
SpaceProductModelEntity,
|
SpaceProductModelEntity,
|
||||||
SubspaceModelEntity,
|
SubspaceModelEntity,
|
||||||
} from '../modules/space-model/entities';
|
} from '../modules/space-model/entities';
|
||||||
|
import {
|
||||||
|
InviteUserEntity,
|
||||||
|
InviteUserSpaceEntity,
|
||||||
|
} from '../modules/invite-user/entities';
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
TypeOrmModule.forRootAsync({
|
TypeOrmModule.forRootAsync({
|
||||||
@ -63,7 +66,6 @@ import {
|
|||||||
SpaceProductEntity,
|
SpaceProductEntity,
|
||||||
UserSpaceEntity,
|
UserSpaceEntity,
|
||||||
DeviceUserPermissionEntity,
|
DeviceUserPermissionEntity,
|
||||||
UserRoleEntity,
|
|
||||||
RoleTypeEntity,
|
RoleTypeEntity,
|
||||||
UserNotificationEntity,
|
UserNotificationEntity,
|
||||||
DeviceNotificationEntity,
|
DeviceNotificationEntity,
|
||||||
@ -78,6 +80,8 @@ import {
|
|||||||
SpaceProductModelEntity,
|
SpaceProductModelEntity,
|
||||||
SpaceProductItemModelEntity,
|
SpaceProductItemModelEntity,
|
||||||
SubspaceModelEntity,
|
SubspaceModelEntity,
|
||||||
|
InviteUserEntity,
|
||||||
|
InviteUserSpaceEntity,
|
||||||
],
|
],
|
||||||
namingStrategy: new SnakeNamingStrategy(),
|
namingStrategy: new SnakeNamingStrategy(),
|
||||||
synchronize: Boolean(JSON.parse(configService.get('DB_SYNC'))),
|
synchronize: Boolean(JSON.parse(configService.get('DB_SYNC'))),
|
||||||
|
@ -0,0 +1,13 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { TypeOrmModule } from '@nestjs/typeorm';
|
||||||
|
import { InviteUserEntity, InviteUserSpaceEntity } from './entities';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
providers: [],
|
||||||
|
exports: [],
|
||||||
|
controllers: [],
|
||||||
|
imports: [
|
||||||
|
TypeOrmModule.forFeature([InviteUserEntity, InviteUserSpaceEntity]),
|
||||||
|
],
|
||||||
|
})
|
||||||
|
export class InviteUserRepositoryModule {}
|
50
libs/common/src/modules/Invite-user/dtos/Invite-user.dto.ts
Normal file
50
libs/common/src/modules/Invite-user/dtos/Invite-user.dto.ts
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
import { UserStatusEnum } from '@app/common/constants/user-status.enum';
|
||||||
|
import { IsEnum, IsNotEmpty, IsString } from 'class-validator';
|
||||||
|
|
||||||
|
export class InviteUserDto {
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public email: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public jobTitle: string;
|
||||||
|
|
||||||
|
@IsEnum(UserStatusEnum)
|
||||||
|
@IsNotEmpty()
|
||||||
|
public status: UserStatusEnum;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public firstName: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public lastName: string;
|
||||||
|
|
||||||
|
@IsEnum(RoleType)
|
||||||
|
@IsNotEmpty()
|
||||||
|
public invitedBy: RoleType;
|
||||||
|
}
|
||||||
|
export class InviteUserSpaceDto {
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public inviteUserUuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public spaceUuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public invitationCode: string;
|
||||||
|
}
|
1
libs/common/src/modules/Invite-user/dtos/index.ts
Normal file
1
libs/common/src/modules/Invite-user/dtos/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './invite-user.dto';
|
@ -0,0 +1,119 @@
|
|||||||
|
import {
|
||||||
|
Column,
|
||||||
|
Entity,
|
||||||
|
JoinColumn,
|
||||||
|
ManyToOne,
|
||||||
|
OneToMany,
|
||||||
|
OneToOne,
|
||||||
|
Unique,
|
||||||
|
} from 'typeorm';
|
||||||
|
import { InviteUserDto, InviteUserSpaceDto } from '../dtos';
|
||||||
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
|
import { RoleTypeEntity } from '../../role-type/entities';
|
||||||
|
import { UserStatusEnum } from '@app/common/constants/user-status.enum';
|
||||||
|
import { UserEntity } from '../../user/entities';
|
||||||
|
import { SpaceEntity } from '../../space/entities';
|
||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
|
||||||
|
@Entity({ name: 'invite-user' })
|
||||||
|
@Unique(['email', 'invitationCode'])
|
||||||
|
export class InviteUserEntity extends AbstractEntity<InviteUserDto> {
|
||||||
|
@Column({
|
||||||
|
type: 'uuid',
|
||||||
|
default: () => 'gen_random_uuid()',
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
unique: true,
|
||||||
|
})
|
||||||
|
email: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
jobTitle: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
enum: Object.values(UserStatusEnum),
|
||||||
|
})
|
||||||
|
status: string;
|
||||||
|
|
||||||
|
@Column()
|
||||||
|
public firstName: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public lastName: string;
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public phoneNumber: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
default: true,
|
||||||
|
})
|
||||||
|
public isEnabled: boolean;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
default: true,
|
||||||
|
})
|
||||||
|
public isActive: boolean;
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
unique: true,
|
||||||
|
})
|
||||||
|
public invitationCode: string;
|
||||||
|
|
||||||
|
@Column({
|
||||||
|
nullable: false,
|
||||||
|
enum: Object.values(RoleType),
|
||||||
|
})
|
||||||
|
public invitedBy: string;
|
||||||
|
|
||||||
|
@ManyToOne(() => RoleTypeEntity, (roleType) => roleType.invitedUsers, {
|
||||||
|
nullable: false,
|
||||||
|
onDelete: 'CASCADE',
|
||||||
|
})
|
||||||
|
public roleType: RoleTypeEntity;
|
||||||
|
@OneToOne(() => UserEntity, (user) => user.inviteUser, { nullable: true })
|
||||||
|
@JoinColumn({ name: 'user_uuid' })
|
||||||
|
user: UserEntity;
|
||||||
|
@OneToMany(
|
||||||
|
() => InviteUserSpaceEntity,
|
||||||
|
(inviteUserSpace) => inviteUserSpace.inviteUser,
|
||||||
|
)
|
||||||
|
spaces: InviteUserSpaceEntity[];
|
||||||
|
constructor(partial: Partial<InviteUserEntity>) {
|
||||||
|
super();
|
||||||
|
Object.assign(this, partial);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@Entity({ name: 'invite-user-space' })
|
||||||
|
@Unique(['inviteUser', 'space'])
|
||||||
|
export class InviteUserSpaceEntity extends AbstractEntity<InviteUserSpaceDto> {
|
||||||
|
@Column({
|
||||||
|
type: 'uuid',
|
||||||
|
default: () => 'gen_random_uuid()',
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@ManyToOne(() => InviteUserEntity, (inviteUser) => inviteUser.spaces)
|
||||||
|
@JoinColumn({ name: 'invite_user_uuid' })
|
||||||
|
public inviteUser: InviteUserEntity;
|
||||||
|
|
||||||
|
@ManyToOne(() => SpaceEntity, (space) => space.invitedUsers)
|
||||||
|
@JoinColumn({ name: 'space_uuid' })
|
||||||
|
public space: SpaceEntity;
|
||||||
|
constructor(partial: Partial<InviteUserSpaceEntity>) {
|
||||||
|
super();
|
||||||
|
Object.assign(this, partial);
|
||||||
|
}
|
||||||
|
}
|
1
libs/common/src/modules/Invite-user/entities/index.ts
Normal file
1
libs/common/src/modules/Invite-user/entities/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './invite-user.entity';
|
@ -0,0 +1,16 @@
|
|||||||
|
import { DataSource, Repository } from 'typeorm';
|
||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import { InviteUserEntity, InviteUserSpaceEntity } from '../entities';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class InviteUserRepository extends Repository<InviteUserEntity> {
|
||||||
|
constructor(private dataSource: DataSource) {
|
||||||
|
super(InviteUserEntity, dataSource.createEntityManager());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@Injectable()
|
||||||
|
export class InviteUserSpaceRepository extends Repository<InviteUserSpaceEntity> {
|
||||||
|
constructor(private dataSource: DataSource) {
|
||||||
|
super(InviteUserSpaceEntity, dataSource.createEntityManager());
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1 @@
|
|||||||
|
export * from './invite-user.repository';
|
@ -3,6 +3,7 @@ import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
|||||||
import { ProjectDto } from '../dtos';
|
import { ProjectDto } from '../dtos';
|
||||||
import { CommunityEntity } from '../../community/entities';
|
import { CommunityEntity } from '../../community/entities';
|
||||||
import { SpaceModelEntity } from '../../space-model';
|
import { SpaceModelEntity } from '../../space-model';
|
||||||
|
import { UserEntity } from '../../user/entities';
|
||||||
|
|
||||||
@Entity({ name: 'project' })
|
@Entity({ name: 'project' })
|
||||||
@Unique(['name'])
|
@Unique(['name'])
|
||||||
@ -28,6 +29,9 @@ export class ProjectEntity extends AbstractEntity<ProjectDto> {
|
|||||||
@OneToMany(() => CommunityEntity, (community) => community.project)
|
@OneToMany(() => CommunityEntity, (community) => community.project)
|
||||||
communities: CommunityEntity[];
|
communities: CommunityEntity[];
|
||||||
|
|
||||||
|
@OneToMany(() => UserEntity, (user) => user.project)
|
||||||
|
public users: UserEntity[];
|
||||||
|
|
||||||
constructor(partial: Partial<ProjectEntity>) {
|
constructor(partial: Partial<ProjectEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
|
@ -2,7 +2,8 @@ import { Column, Entity, OneToMany, Unique } from 'typeorm';
|
|||||||
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
import { RoleTypeDto } from '../dtos/role.type.dto';
|
import { RoleTypeDto } from '../dtos/role.type.dto';
|
||||||
import { RoleType } from '@app/common/constants/role.type.enum';
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
import { UserRoleEntity } from '../../user/entities';
|
import { UserEntity } from '../../user/entities';
|
||||||
|
import { InviteUserEntity } from '../../invite-user/entities';
|
||||||
|
|
||||||
@Entity({ name: 'role-type' })
|
@Entity({ name: 'role-type' })
|
||||||
@Unique(['type'])
|
@Unique(['type'])
|
||||||
@ -12,10 +13,14 @@ export class RoleTypeEntity extends AbstractEntity<RoleTypeDto> {
|
|||||||
enum: Object.values(RoleType),
|
enum: Object.values(RoleType),
|
||||||
})
|
})
|
||||||
type: string;
|
type: string;
|
||||||
@OneToMany(() => UserRoleEntity, (role) => role.roleType, {
|
@OneToMany(() => UserEntity, (inviteUser) => inviteUser.roleType, {
|
||||||
nullable: true,
|
nullable: true,
|
||||||
})
|
})
|
||||||
roles: UserRoleEntity[];
|
users: UserEntity[];
|
||||||
|
@OneToMany(() => InviteUserEntity, (inviteUser) => inviteUser.roleType, {
|
||||||
|
nullable: true,
|
||||||
|
})
|
||||||
|
invitedUsers: InviteUserEntity[];
|
||||||
constructor(partial: Partial<RoleTypeEntity>) {
|
constructor(partial: Partial<RoleTypeEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
|
@ -15,6 +15,7 @@ import { SubspaceEntity } from './subspace.entity';
|
|||||||
import { SpaceLinkEntity } from './space-link.entity';
|
import { SpaceLinkEntity } from './space-link.entity';
|
||||||
import { SpaceProductEntity } from './space-product.entity';
|
import { SpaceProductEntity } from './space-product.entity';
|
||||||
import { SceneEntity } from '../../scene/entities';
|
import { SceneEntity } from '../../scene/entities';
|
||||||
|
import { InviteUserSpaceEntity } from '../../invite-user/entities';
|
||||||
|
|
||||||
@Entity({ name: 'space' })
|
@Entity({ name: 'space' })
|
||||||
@Unique(['invitationCode'])
|
@Unique(['invitationCode'])
|
||||||
@ -97,7 +98,11 @@ export class SpaceEntity extends AbstractEntity<SpaceDto> {
|
|||||||
|
|
||||||
@OneToMany(() => SceneEntity, (scene) => scene.space)
|
@OneToMany(() => SceneEntity, (scene) => scene.space)
|
||||||
scenes: SceneEntity[];
|
scenes: SceneEntity[];
|
||||||
|
@OneToMany(
|
||||||
|
() => InviteUserSpaceEntity,
|
||||||
|
(inviteUserSpace) => inviteUserSpace.space,
|
||||||
|
)
|
||||||
|
invitedUsers: InviteUserSpaceEntity[];
|
||||||
constructor(partial: Partial<SpaceEntity>) {
|
constructor(partial: Partial<SpaceEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
|
@ -58,20 +58,6 @@ export class UserOtpDto {
|
|||||||
public expiryTime: string;
|
public expiryTime: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export class UserRoleDto {
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
public uuid: string;
|
|
||||||
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
public userUuid: string;
|
|
||||||
|
|
||||||
@IsString()
|
|
||||||
@IsNotEmpty()
|
|
||||||
public roleTypeUuid: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export class UserSpaceDto {
|
export class UserSpaceDto {
|
||||||
@IsString()
|
@IsString()
|
||||||
@IsNotEmpty()
|
@IsNotEmpty()
|
||||||
|
@ -2,15 +2,16 @@ import {
|
|||||||
Column,
|
Column,
|
||||||
DeleteDateColumn,
|
DeleteDateColumn,
|
||||||
Entity,
|
Entity,
|
||||||
|
JoinColumn,
|
||||||
ManyToOne,
|
ManyToOne,
|
||||||
OneToMany,
|
OneToMany,
|
||||||
|
OneToOne,
|
||||||
Unique,
|
Unique,
|
||||||
} from 'typeorm';
|
} from 'typeorm';
|
||||||
import {
|
import {
|
||||||
UserDto,
|
UserDto,
|
||||||
UserNotificationDto,
|
UserNotificationDto,
|
||||||
UserOtpDto,
|
UserOtpDto,
|
||||||
UserRoleDto,
|
|
||||||
UserSpaceDto,
|
UserSpaceDto,
|
||||||
} from '../dtos';
|
} from '../dtos';
|
||||||
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
@ -26,6 +27,8 @@ import { OtpType } from '../../../../src/constants/otp-type.enum';
|
|||||||
import { RoleTypeEntity } from '../../role-type/entities';
|
import { RoleTypeEntity } from '../../role-type/entities';
|
||||||
import { SpaceEntity } from '../../space/entities';
|
import { SpaceEntity } from '../../space/entities';
|
||||||
import { VisitorPasswordEntity } from '../../visitor-password/entities';
|
import { VisitorPasswordEntity } from '../../visitor-password/entities';
|
||||||
|
import { InviteUserEntity } from '../../invite-user/entities';
|
||||||
|
import { ProjectEntity } from '../../project/entities';
|
||||||
|
|
||||||
@Entity({ name: 'user' })
|
@Entity({ name: 'user' })
|
||||||
export class UserEntity extends AbstractEntity<UserDto> {
|
export class UserEntity extends AbstractEntity<UserDto> {
|
||||||
@ -100,10 +103,7 @@ export class UserEntity extends AbstractEntity<UserDto> {
|
|||||||
(deviceUserNotification) => deviceUserNotification.user,
|
(deviceUserNotification) => deviceUserNotification.user,
|
||||||
)
|
)
|
||||||
deviceUserNotification: DeviceNotificationEntity[];
|
deviceUserNotification: DeviceNotificationEntity[];
|
||||||
@OneToMany(() => UserRoleEntity, (role) => role.user, {
|
|
||||||
nullable: true,
|
|
||||||
})
|
|
||||||
roles: UserRoleEntity[];
|
|
||||||
@ManyToOne(() => RegionEntity, (region) => region.users, { nullable: true })
|
@ManyToOne(() => RegionEntity, (region) => region.users, { nullable: true })
|
||||||
region: RegionEntity;
|
region: RegionEntity;
|
||||||
@ManyToOne(() => TimeZoneEntity, (timezone) => timezone.users, {
|
@ManyToOne(() => TimeZoneEntity, (timezone) => timezone.users, {
|
||||||
@ -116,6 +116,21 @@ export class UserEntity extends AbstractEntity<UserDto> {
|
|||||||
)
|
)
|
||||||
public visitorPasswords: VisitorPasswordEntity[];
|
public visitorPasswords: VisitorPasswordEntity[];
|
||||||
|
|
||||||
|
@ManyToOne(() => RoleTypeEntity, (roleType) => roleType.users, {
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public roleType: RoleTypeEntity;
|
||||||
|
@OneToOne(() => InviteUserEntity, (inviteUser) => inviteUser.user, {
|
||||||
|
nullable: true,
|
||||||
|
})
|
||||||
|
@JoinColumn({ name: 'invite_user_uuid' })
|
||||||
|
inviteUser: InviteUserEntity;
|
||||||
|
|
||||||
|
@ManyToOne(() => ProjectEntity, (project) => project.users, {
|
||||||
|
nullable: true,
|
||||||
|
})
|
||||||
|
@JoinColumn({ name: 'project_uuid' })
|
||||||
|
public project: ProjectEntity;
|
||||||
constructor(partial: Partial<UserEntity>) {
|
constructor(partial: Partial<UserEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
@ -125,7 +140,7 @@ export class UserEntity extends AbstractEntity<UserDto> {
|
|||||||
@Entity({ name: 'user-notification' })
|
@Entity({ name: 'user-notification' })
|
||||||
@Unique(['user', 'subscriptionUuid'])
|
@Unique(['user', 'subscriptionUuid'])
|
||||||
export class UserNotificationEntity extends AbstractEntity<UserNotificationDto> {
|
export class UserNotificationEntity extends AbstractEntity<UserNotificationDto> {
|
||||||
@ManyToOne(() => UserEntity, (user) => user.roles, {
|
@ManyToOne(() => UserEntity, (user) => user.roleType, {
|
||||||
nullable: false,
|
nullable: false,
|
||||||
})
|
})
|
||||||
user: UserEntity;
|
user: UserEntity;
|
||||||
@ -178,25 +193,6 @@ export class UserOtpEntity extends AbstractEntity<UserOtpDto> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Entity({ name: 'user-role' })
|
|
||||||
@Unique(['user', 'roleType'])
|
|
||||||
export class UserRoleEntity extends AbstractEntity<UserRoleDto> {
|
|
||||||
@ManyToOne(() => UserEntity, (user) => user.roles, {
|
|
||||||
nullable: false,
|
|
||||||
})
|
|
||||||
user: UserEntity;
|
|
||||||
|
|
||||||
@ManyToOne(() => RoleTypeEntity, (roleType) => roleType.roles, {
|
|
||||||
nullable: false,
|
|
||||||
})
|
|
||||||
roleType: RoleTypeEntity;
|
|
||||||
|
|
||||||
constructor(partial: Partial<UserRoleEntity>) {
|
|
||||||
super();
|
|
||||||
Object.assign(this, partial);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Entity({ name: 'user-space' })
|
@Entity({ name: 'user-space' })
|
||||||
@Unique(['user', 'space'])
|
@Unique(['user', 'space'])
|
||||||
export class UserSpaceEntity extends AbstractEntity<UserSpaceDto> {
|
export class UserSpaceEntity extends AbstractEntity<UserSpaceDto> {
|
||||||
|
@ -4,7 +4,6 @@ import {
|
|||||||
UserEntity,
|
UserEntity,
|
||||||
UserNotificationEntity,
|
UserNotificationEntity,
|
||||||
UserOtpEntity,
|
UserOtpEntity,
|
||||||
UserRoleEntity,
|
|
||||||
UserSpaceEntity,
|
UserSpaceEntity,
|
||||||
} from '../entities/';
|
} from '../entities/';
|
||||||
|
|
||||||
@ -29,13 +28,6 @@ export class UserOtpRepository extends Repository<UserOtpEntity> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Injectable()
|
|
||||||
export class UserRoleRepository extends Repository<UserRoleEntity> {
|
|
||||||
constructor(private dataSource: DataSource) {
|
|
||||||
super(UserRoleEntity, dataSource.createEntityManager());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class UserSpaceRepository extends Repository<UserSpaceEntity> {
|
export class UserSpaceRepository extends Repository<UserSpaceEntity> {
|
||||||
constructor(private dataSource: DataSource) {
|
constructor(private dataSource: DataSource) {
|
||||||
|
@ -4,7 +4,6 @@ import {
|
|||||||
UserEntity,
|
UserEntity,
|
||||||
UserNotificationEntity,
|
UserNotificationEntity,
|
||||||
UserOtpEntity,
|
UserOtpEntity,
|
||||||
UserRoleEntity,
|
|
||||||
UserSpaceEntity,
|
UserSpaceEntity,
|
||||||
} from './entities';
|
} from './entities';
|
||||||
|
|
||||||
@ -17,7 +16,6 @@ import {
|
|||||||
UserEntity,
|
UserEntity,
|
||||||
UserNotificationEntity,
|
UserNotificationEntity,
|
||||||
UserOtpEntity,
|
UserOtpEntity,
|
||||||
UserRoleEntity,
|
|
||||||
UserSpaceEntity,
|
UserSpaceEntity,
|
||||||
]),
|
]),
|
||||||
],
|
],
|
||||||
|
@ -10,7 +10,6 @@ import { RoleTypeSeeder } from './services/role.type.seeder';
|
|||||||
import { SpaceRepositoryModule } from '../modules/space/space.repository.module';
|
import { SpaceRepositoryModule } from '../modules/space/space.repository.module';
|
||||||
import { SuperAdminSeeder } from './services/supper.admin.seeder';
|
import { SuperAdminSeeder } from './services/supper.admin.seeder';
|
||||||
import { UserRepository } from '../modules/user/repositories';
|
import { UserRepository } from '../modules/user/repositories';
|
||||||
import { UserRoleRepository } from '../modules/user/repositories';
|
|
||||||
import { UserRepositoryModule } from '../modules/user/user.repository.module';
|
import { UserRepositoryModule } from '../modules/user/user.repository.module';
|
||||||
import { RegionSeeder } from './services/regions.seeder';
|
import { RegionSeeder } from './services/regions.seeder';
|
||||||
import { RegionRepository } from '../modules/region/repositories';
|
import { RegionRepository } from '../modules/region/repositories';
|
||||||
@ -28,7 +27,6 @@ import { SceneIconRepository } from '../modules/scene/repositories';
|
|||||||
RoleTypeRepository,
|
RoleTypeRepository,
|
||||||
SuperAdminSeeder,
|
SuperAdminSeeder,
|
||||||
UserRepository,
|
UserRepository,
|
||||||
UserRoleRepository,
|
|
||||||
RegionSeeder,
|
RegionSeeder,
|
||||||
RegionRepository,
|
RegionRepository,
|
||||||
TimeZoneSeeder,
|
TimeZoneSeeder,
|
||||||
|
@ -19,7 +19,12 @@ export class RoleTypeSeeder {
|
|||||||
if (!roleTypeNames.includes(RoleType.ADMIN)) {
|
if (!roleTypeNames.includes(RoleType.ADMIN)) {
|
||||||
missingRoleTypes.push(RoleType.ADMIN);
|
missingRoleTypes.push(RoleType.ADMIN);
|
||||||
}
|
}
|
||||||
|
if (!roleTypeNames.includes(RoleType.SPACE_OWNER)) {
|
||||||
|
missingRoleTypes.push(RoleType.SPACE_OWNER);
|
||||||
|
}
|
||||||
|
if (!roleTypeNames.includes(RoleType.SPACE_MEMBER)) {
|
||||||
|
missingRoleTypes.push(RoleType.SPACE_MEMBER);
|
||||||
|
}
|
||||||
if (missingRoleTypes.length > 0) {
|
if (missingRoleTypes.length > 0) {
|
||||||
await this.addRoleTypeData(missingRoleTypes);
|
await this.addRoleTypeData(missingRoleTypes);
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,6 @@
|
|||||||
import { Injectable } from '@nestjs/common';
|
import { Injectable } from '@nestjs/common';
|
||||||
import { UserRepository } from '@app/common/modules/user/repositories';
|
import { UserRepository } from '@app/common/modules/user/repositories';
|
||||||
import { RoleType } from '@app/common/constants/role.type.enum';
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
import { UserRoleRepository } from '@app/common/modules/user/repositories';
|
|
||||||
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
import { ConfigService } from '@nestjs/config';
|
import { ConfigService } from '@nestjs/config';
|
||||||
import { HelperHashService } from '../../helper/services';
|
import { HelperHashService } from '../../helper/services';
|
||||||
@ -11,19 +10,23 @@ export class SuperAdminSeeder {
|
|||||||
constructor(
|
constructor(
|
||||||
private readonly configService: ConfigService,
|
private readonly configService: ConfigService,
|
||||||
private readonly userRepository: UserRepository,
|
private readonly userRepository: UserRepository,
|
||||||
private readonly userRoleRepository: UserRoleRepository,
|
|
||||||
private readonly roleTypeRepository: RoleTypeRepository,
|
private readonly roleTypeRepository: RoleTypeRepository,
|
||||||
private readonly helperHashService: HelperHashService,
|
private readonly helperHashService: HelperHashService,
|
||||||
) {}
|
) {}
|
||||||
|
|
||||||
async createSuperAdminIfNotFound(): Promise<void> {
|
async createSuperAdminIfNotFound(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
const superAdminData = await this.userRoleRepository.find({
|
const superAdmin = await this.userRepository.findOne({
|
||||||
where: { roleType: { type: RoleType.SUPER_ADMIN } },
|
where: {
|
||||||
|
roleType: { type: RoleType.SUPER_ADMIN },
|
||||||
|
email: this.configService.get<string>(
|
||||||
|
'super-admin.SUPER_ADMIN_EMAIL',
|
||||||
|
),
|
||||||
|
},
|
||||||
relations: ['roleType'],
|
relations: ['roleType'],
|
||||||
});
|
});
|
||||||
|
|
||||||
if (superAdminData.length <= 0) {
|
if (!superAdmin) {
|
||||||
// Create the super admin user if not found
|
// Create the super admin user if not found
|
||||||
console.log('Creating super admin user...');
|
console.log('Creating super admin user...');
|
||||||
|
|
||||||
@ -48,20 +51,16 @@ export class SuperAdminSeeder {
|
|||||||
salt,
|
salt,
|
||||||
);
|
);
|
||||||
try {
|
try {
|
||||||
const user = await this.userRepository.save({
|
const defaultUserRoleUuid = await this.getRoleUuidByRoleType(
|
||||||
|
RoleType.SUPER_ADMIN,
|
||||||
|
);
|
||||||
|
await this.userRepository.save({
|
||||||
email: this.configService.get<string>('super-admin.SUPER_ADMIN_EMAIL'),
|
email: this.configService.get<string>('super-admin.SUPER_ADMIN_EMAIL'),
|
||||||
password: hashedPassword,
|
password: hashedPassword,
|
||||||
firstName: 'Super',
|
firstName: 'Super',
|
||||||
lastName: 'Admin',
|
lastName: 'Admin',
|
||||||
isUserVerified: true,
|
isUserVerified: true,
|
||||||
isActive: true,
|
isActive: true,
|
||||||
});
|
|
||||||
const defaultUserRoleUuid = await this.getRoleUuidByRoleType(
|
|
||||||
RoleType.SUPER_ADMIN,
|
|
||||||
);
|
|
||||||
|
|
||||||
await this.userRoleRepository.save({
|
|
||||||
user: { uuid: user.uuid },
|
|
||||||
roleType: { uuid: defaultUserRoleUuid },
|
roleType: { uuid: defaultUserRoleUuid },
|
||||||
});
|
});
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
|
@ -7,7 +7,6 @@ import { GroupModule } from './group/group.module';
|
|||||||
import { DeviceModule } from './device/device.module';
|
import { DeviceModule } from './device/device.module';
|
||||||
import { UserDevicePermissionModule } from './user-device-permission/user-device-permission.module';
|
import { UserDevicePermissionModule } from './user-device-permission/user-device-permission.module';
|
||||||
import { CommunityModule } from './community/community.module';
|
import { CommunityModule } from './community/community.module';
|
||||||
import { RoleModule } from './role/role.module';
|
|
||||||
import { SeederModule } from '@app/common/seed/seeder.module';
|
import { SeederModule } from '@app/common/seed/seeder.module';
|
||||||
import { UserNotificationModule } from './user-notification/user-notification.module';
|
import { UserNotificationModule } from './user-notification/user-notification.module';
|
||||||
import { DeviceMessagesSubscriptionModule } from './device-messages/device-messages.module';
|
import { DeviceMessagesSubscriptionModule } from './device-messages/device-messages.module';
|
||||||
@ -24,6 +23,8 @@ import { SpaceModule } from './space/space.module';
|
|||||||
import { ProductModule } from './product';
|
import { ProductModule } from './product';
|
||||||
import { ProjectModule } from './project';
|
import { ProjectModule } from './project';
|
||||||
import { SpaceModelModule } from './space-model';
|
import { SpaceModelModule } from './space-model';
|
||||||
|
import { InviteUserModule } from './invite-user/invite-user.module';
|
||||||
|
import { PermissionModule } from './permission/permission.module';
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
ConfigModule.forRoot({
|
ConfigModule.forRoot({
|
||||||
@ -31,7 +32,7 @@ import { SpaceModelModule } from './space-model';
|
|||||||
}),
|
}),
|
||||||
AuthenticationModule,
|
AuthenticationModule,
|
||||||
UserModule,
|
UserModule,
|
||||||
RoleModule,
|
InviteUserModule,
|
||||||
CommunityModule,
|
CommunityModule,
|
||||||
|
|
||||||
SpaceModule,
|
SpaceModule,
|
||||||
@ -51,6 +52,7 @@ import { SpaceModelModule } from './space-model';
|
|||||||
ScheduleModule,
|
ScheduleModule,
|
||||||
ProductModule,
|
ProductModule,
|
||||||
ProjectModule,
|
ProjectModule,
|
||||||
|
PermissionModule,
|
||||||
],
|
],
|
||||||
providers: [
|
providers: [
|
||||||
{
|
{
|
||||||
|
@ -6,10 +6,7 @@ import { UserAuthController } from './controllers';
|
|||||||
import { UserAuthService } from './services';
|
import { UserAuthService } from './services';
|
||||||
import { UserRepository } from '@app/common/modules/user/repositories';
|
import { UserRepository } from '@app/common/modules/user/repositories';
|
||||||
import { UserSessionRepository } from '@app/common/modules/session/repositories/session.repository';
|
import { UserSessionRepository } from '@app/common/modules/session/repositories/session.repository';
|
||||||
import {
|
import { UserOtpRepository } from '@app/common/modules/user/repositories';
|
||||||
UserRoleRepository,
|
|
||||||
UserOtpRepository,
|
|
||||||
} from '@app/common/modules/user/repositories';
|
|
||||||
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
@ -20,7 +17,6 @@ import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
|||||||
UserRepository,
|
UserRepository,
|
||||||
UserSessionRepository,
|
UserSessionRepository,
|
||||||
UserOtpRepository,
|
UserOtpRepository,
|
||||||
UserRoleRepository,
|
|
||||||
RoleTypeRepository,
|
RoleTypeRepository,
|
||||||
],
|
],
|
||||||
exports: [UserAuthService],
|
exports: [UserAuthService],
|
||||||
|
@ -134,13 +134,12 @@ export class UserAuthService {
|
|||||||
isLoggedOut: false,
|
isLoggedOut: false,
|
||||||
}),
|
}),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
const res = await this.authService.login({
|
const res = await this.authService.login({
|
||||||
email: user.email,
|
email: user.email,
|
||||||
userId: user.uuid,
|
userId: user.uuid,
|
||||||
uuid: user.uuid,
|
uuid: user.uuid,
|
||||||
roles: user?.roles?.map((role) => {
|
role: user.roleType,
|
||||||
return { uuid: role.uuid, type: role.roleType.type };
|
|
||||||
}),
|
|
||||||
sessionId: session[1].uuid,
|
sessionId: session[1].uuid,
|
||||||
});
|
});
|
||||||
return res;
|
return res;
|
||||||
|
@ -16,10 +16,11 @@ import {
|
|||||||
UpdateAutomationDto,
|
UpdateAutomationDto,
|
||||||
UpdateAutomationStatusDto,
|
UpdateAutomationStatusDto,
|
||||||
} from '../dtos/automation.dto';
|
} from '../dtos/automation.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import { AutomationParamDto, SpaceParamDto } from '../dtos';
|
import { AutomationParamDto, SpaceParamDto } from '../dtos';
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Automation Module')
|
@ApiTags('Automation Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -30,7 +31,8 @@ export class AutomationController {
|
|||||||
constructor(private readonly automationService: AutomationService) {}
|
constructor(private readonly automationService: AutomationService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_ADD')
|
||||||
@Post()
|
@Post()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.AUTOMATION.ACTIONS.ADD_AUTOMATION_SUMMARY,
|
summary: ControllerRoute.AUTOMATION.ACTIONS.ADD_AUTOMATION_SUMMARY,
|
||||||
@ -48,7 +50,8 @@ export class AutomationController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_VIEW')
|
||||||
@Get(':spaceUuid')
|
@Get(':spaceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.AUTOMATION.ACTIONS.GET_AUTOMATION_BY_SPACE_SUMMARY,
|
summary: ControllerRoute.AUTOMATION.ACTIONS.GET_AUTOMATION_BY_SPACE_SUMMARY,
|
||||||
@ -63,7 +66,8 @@ export class AutomationController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_VIEW')
|
||||||
@Get('details/:automationUuid')
|
@Get('details/:automationUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.AUTOMATION.ACTIONS.GET_AUTOMATION_DETAILS_SUMMARY,
|
summary: ControllerRoute.AUTOMATION.ACTIONS.GET_AUTOMATION_DETAILS_SUMMARY,
|
||||||
@ -78,7 +82,8 @@ export class AutomationController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_DELETE')
|
||||||
@Delete(':automationUuid')
|
@Delete(':automationUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.AUTOMATION.ACTIONS.DELETE_AUTOMATION_SUMMARY,
|
summary: ControllerRoute.AUTOMATION.ACTIONS.DELETE_AUTOMATION_SUMMARY,
|
||||||
@ -94,7 +99,8 @@ export class AutomationController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_UPDATE')
|
||||||
@Put(':automationUuid')
|
@Put(':automationUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.AUTOMATION.ACTIONS.UPDATE_AUTOMATION_SUMMARY,
|
summary: ControllerRoute.AUTOMATION.ACTIONS.UPDATE_AUTOMATION_SUMMARY,
|
||||||
@ -118,7 +124,8 @@ export class AutomationController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('AUTOMATION_UPDATE')
|
||||||
@Put('status/:automationUuid')
|
@Put('status/:automationUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
|
@ -15,11 +15,12 @@ import { AddCommunityDto } from '../dtos/add.community.dto';
|
|||||||
import { GetCommunityParams } from '../dtos/get.community.dto';
|
import { GetCommunityParams } from '../dtos/get.community.dto';
|
||||||
import { UpdateCommunityNameDto } from '../dtos/update.community.dto';
|
import { UpdateCommunityNameDto } from '../dtos/update.community.dto';
|
||||||
// import { CheckUserCommunityGuard } from 'src/guards/user.community.guard';
|
// import { CheckUserCommunityGuard } from 'src/guards/user.community.guard';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { PaginationRequestGetListDto } from '@app/common/dto/pagination.request.dto';
|
import { PaginationRequestGetListDto } from '@app/common/dto/pagination.request.dto';
|
||||||
import { ProjectParam } from '../dtos';
|
import { ProjectParam } from '../dtos';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Community Module')
|
@ApiTags('Community Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -30,7 +31,8 @@ export class CommunityController {
|
|||||||
constructor(private readonly communityService: CommunityService) {}
|
constructor(private readonly communityService: CommunityService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('COMMUNITY_ADD')
|
||||||
@Post()
|
@Post()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.COMMUNITY.ACTIONS.CREATE_COMMUNITY_SUMMARY,
|
summary: ControllerRoute.COMMUNITY.ACTIONS.CREATE_COMMUNITY_SUMMARY,
|
||||||
@ -44,7 +46,8 @@ export class CommunityController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('COMMUNITY_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.COMMUNITY.ACTIONS.GET_COMMUNITY_BY_ID_SUMMARY,
|
summary: ControllerRoute.COMMUNITY.ACTIONS.GET_COMMUNITY_BY_ID_SUMMARY,
|
||||||
description:
|
description:
|
||||||
@ -58,7 +61,8 @@ export class CommunityController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('COMMUNITY_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.COMMUNITY.ACTIONS.LIST_COMMUNITY_SUMMARY,
|
summary: ControllerRoute.COMMUNITY.ACTIONS.LIST_COMMUNITY_SUMMARY,
|
||||||
description: ControllerRoute.COMMUNITY.ACTIONS.LIST_COMMUNITY_DESCRIPTION,
|
description: ControllerRoute.COMMUNITY.ACTIONS.LIST_COMMUNITY_DESCRIPTION,
|
||||||
@ -72,7 +76,8 @@ export class CommunityController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('COMMUNITY_UPDATE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.COMMUNITY.ACTIONS.UPDATE_COMMUNITY_SUMMARY,
|
summary: ControllerRoute.COMMUNITY.ACTIONS.UPDATE_COMMUNITY_SUMMARY,
|
||||||
description: ControllerRoute.COMMUNITY.ACTIONS.UPDATE_COMMUNITY_DESCRIPTION,
|
description: ControllerRoute.COMMUNITY.ACTIONS.UPDATE_COMMUNITY_DESCRIPTION,
|
||||||
@ -86,7 +91,8 @@ export class CommunityController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('COMMUNITY_DELETE')
|
||||||
@Delete('/:communityUuid')
|
@Delete('/:communityUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.COMMUNITY.ACTIONS.DELETE_COMMUNITY_SUMMARY,
|
summary: ControllerRoute.COMMUNITY.ACTIONS.DELETE_COMMUNITY_SUMMARY,
|
||||||
|
4
src/decorators/permissions.decorator.ts
Normal file
4
src/decorators/permissions.decorator.ts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
import { SetMetadata } from '@nestjs/common';
|
||||||
|
|
||||||
|
export const Permissions = (...permissions: string[]) =>
|
||||||
|
SetMetadata('permissions', permissions);
|
@ -28,15 +28,15 @@ import {
|
|||||||
GetSceneFourSceneDeviceDto,
|
GetSceneFourSceneDeviceDto,
|
||||||
} from '../dtos/control.device.dto';
|
} from '../dtos/control.device.dto';
|
||||||
import { CheckRoomGuard } from 'src/guards/room.guard';
|
import { CheckRoomGuard } from 'src/guards/room.guard';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { CheckDeviceGuard } from 'src/guards/device.guard';
|
import { CheckDeviceGuard } from 'src/guards/device.guard';
|
||||||
import { SuperAdminRoleGuard } from 'src/guards/super.admin.role.guard';
|
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import { CheckFourAndSixSceneDeviceTypeGuard } from 'src/guards/scene.device.type.guard';
|
import { CheckFourAndSixSceneDeviceTypeGuard } from 'src/guards/scene.device.type.guard';
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { DeviceSceneParamDto } from '../dtos/device.param.dto';
|
import { DeviceSceneParamDto } from '../dtos/device.param.dto';
|
||||||
import { DeleteSceneFromSceneDeviceDto } from '../dtos/delete.device.dto';
|
import { DeleteSceneFromSceneDeviceDto } from '../dtos/delete.device.dto';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Device Module')
|
@ApiTags('Device Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -46,7 +46,8 @@ import { DeleteSceneFromSceneDeviceDto } from '../dtos/delete.device.dto';
|
|||||||
export class DeviceController {
|
export class DeviceController {
|
||||||
constructor(private readonly deviceService: DeviceService) {}
|
constructor(private readonly deviceService: DeviceService) {}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(SuperAdminRoleGuard, CheckDeviceGuard)
|
@UseGuards(PermissionsGuard, CheckDeviceGuard)
|
||||||
|
@Permissions('ASSIGN_DEVICE_TO_SPACE')
|
||||||
@Post()
|
@Post()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.ADD_DEVICE_TO_USER_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.ADD_DEVICE_TO_USER_SUMMARY,
|
||||||
@ -63,7 +64,8 @@ export class DeviceController {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get('user/:userUuid')
|
@Get('user/:userUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_BY_USER_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_BY_USER_SUMMARY,
|
||||||
@ -74,7 +76,8 @@ export class DeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VIEW_DEVICE_IN_SPACE')
|
||||||
@Get('space/:spaceUuid')
|
@Get('space/:spaceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_BY_SPACE_UUID_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_BY_SPACE_UUID_SUMMARY,
|
||||||
@ -85,7 +88,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.getDevicesBySpaceUuid(spaceUuid);
|
return await this.deviceService.getDevicesBySpaceUuid(spaceUuid);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard, CheckRoomGuard)
|
@UseGuards(PermissionsGuard, CheckRoomGuard)
|
||||||
|
@Permissions('UPDATE_DEVICE_IN_SUBSPACE')
|
||||||
@Put('space')
|
@Put('space')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_IN_ROOM_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_IN_ROOM_SUMMARY,
|
||||||
@ -108,7 +112,8 @@ export class DeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get(':deviceUuid')
|
@Get(':deviceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_DETAILS_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_DETAILS_SUMMARY,
|
||||||
@ -125,7 +130,8 @@ export class DeviceController {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_UPDATE')
|
||||||
@Put(':deviceUuid')
|
@Put(':deviceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_SUMMARY,
|
||||||
@ -149,7 +155,8 @@ export class DeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get(':deviceUuid/functions')
|
@Get(':deviceUuid/functions')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_INSTRUCTION_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_INSTRUCTION_SUMMARY,
|
||||||
@ -162,7 +169,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.getDeviceInstructionByDeviceId(deviceUuid);
|
return await this.deviceService.getDeviceInstructionByDeviceId(deviceUuid);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get(':deviceUuid/functions/status')
|
@Get(':deviceUuid/functions/status')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_STATUS_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_STATUS_SUMMARY,
|
||||||
@ -173,7 +181,8 @@ export class DeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_SINGLE_CONTROL')
|
||||||
@Post(':deviceUuid/control')
|
@Post(':deviceUuid/control')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.CONTROL_DEVICE_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.CONTROL_DEVICE_SUMMARY,
|
||||||
@ -186,7 +195,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.controlDevice(controlDeviceDto, deviceUuid);
|
return await this.deviceService.controlDevice(controlDeviceDto, deviceUuid);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('FIRMWARE_CONTROL')
|
||||||
@Post(':deviceUuid/firmware/:firmwareVersion')
|
@Post(':deviceUuid/firmware/:firmwareVersion')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_FIRMWARE_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.UPDATE_DEVICE_FIRMWARE_SUMMARY,
|
||||||
@ -203,7 +213,8 @@ export class DeviceController {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get('gateway/:gatewayUuid/devices')
|
@Get('gateway/:gatewayUuid/devices')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_IN_GATEWAY_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICES_IN_GATEWAY_SUMMARY,
|
||||||
@ -214,7 +225,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.getDevicesInGateway(gatewayUuid);
|
return await this.deviceService.getDevicesInGateway(gatewayUuid);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get()
|
@Get()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_ALL_DEVICES_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_ALL_DEVICES_SUMMARY,
|
||||||
@ -225,7 +237,8 @@ export class DeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get('report-logs/:deviceUuid')
|
@Get('report-logs/:deviceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_LOGS_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_DEVICE_LOGS_SUMMARY,
|
||||||
@ -238,7 +251,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.getDeviceLogs(deviceUuid, query);
|
return await this.deviceService.getDeviceLogs(deviceUuid, query);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_BATCH_CONTROL')
|
||||||
@Post('control/batch')
|
@Post('control/batch')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_CONTROL_DEVICES_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_CONTROL_DEVICES_SUMMARY,
|
||||||
@ -251,7 +265,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.batchControlDevices(batchControlDevicesDto);
|
return await this.deviceService.batchControlDevices(batchControlDevicesDto);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_BATCH_CONTROL')
|
||||||
@Get('status/batch')
|
@Get('status/batch')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_STATUS_DEVICES_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_STATUS_DEVICES_SUMMARY,
|
||||||
@ -264,7 +279,8 @@ export class DeviceController {
|
|||||||
return await this.deviceService.batchStatusDevices(batchStatusDevicesDto);
|
return await this.deviceService.batchStatusDevices(batchStatusDevicesDto);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_DELETE')
|
||||||
@Post('factory/reset/:deviceUuid')
|
@Post('factory/reset/:deviceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_FACTORY_RESET_DEVICES_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.BATCH_FACTORY_RESET_DEVICES_SUMMARY,
|
||||||
@ -279,7 +295,8 @@ export class DeviceController {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get(':powerClampUuid/power-clamp/status')
|
@Get(':powerClampUuid/power-clamp/status')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_POWER_CLAMP_STATUS_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_POWER_CLAMP_STATUS_SUMMARY,
|
||||||
@ -294,7 +311,8 @@ export class DeviceController {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard, CheckFourAndSixSceneDeviceTypeGuard)
|
@UseGuards(PermissionsGuard, CheckFourAndSixSceneDeviceTypeGuard)
|
||||||
|
@Permissions('DEVICE_SINGLE_CONTROL')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.ADD_SCENE_TO_DEVICE_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.ADD_SCENE_TO_DEVICE_SUMMARY,
|
||||||
description: ControllerRoute.DEVICE.ACTIONS.ADD_SCENE_TO_DEVICE_DESCRIPTION,
|
description: ControllerRoute.DEVICE.ACTIONS.ADD_SCENE_TO_DEVICE_DESCRIPTION,
|
||||||
@ -317,7 +335,8 @@ export class DeviceController {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard, CheckFourAndSixSceneDeviceTypeGuard)
|
@UseGuards(PermissionsGuard, CheckFourAndSixSceneDeviceTypeGuard)
|
||||||
|
@Permissions('DEVICE_VIEW')
|
||||||
@Get(':deviceUuid/scenes')
|
@Get(':deviceUuid/scenes')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.DEVICE.ACTIONS.GET_SCENES_BY_DEVICE_SUMMARY,
|
summary: ControllerRoute.DEVICE.ACTIONS.GET_SCENES_BY_DEVICE_SUMMARY,
|
||||||
@ -334,7 +353,8 @@ export class DeviceController {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DEVICE_DELETE')
|
||||||
@Delete(':deviceUuid/scenes')
|
@Delete(':deviceUuid/scenes')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
|
@ -1,9 +1,10 @@
|
|||||||
import { GroupService } from '../services/group.service';
|
import { GroupService } from '../services/group.service';
|
||||||
import { Controller, Get, UseGuards, Param, Req } from '@nestjs/common';
|
import { Controller, Get, UseGuards, Param, Req } from '@nestjs/common';
|
||||||
import { ApiTags, ApiBearerAuth, ApiOperation } from '@nestjs/swagger';
|
import { ApiTags, ApiBearerAuth, ApiOperation } from '@nestjs/swagger';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route'; // Assuming this is where the routes are defined
|
import { ControllerRoute } from '@app/common/constants/controller-route'; // Assuming this is where the routes are defined
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Group Module')
|
@ApiTags('Group Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -14,7 +15,8 @@ export class GroupController {
|
|||||||
constructor(private readonly groupService: GroupService) {}
|
constructor(private readonly groupService: GroupService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VIEW_DEVICE_WIZARD')
|
||||||
@Get(':spaceUuid')
|
@Get(':spaceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.GROUP.ACTIONS.GET_GROUPS_BY_SPACE_UUID_SUMMARY,
|
summary: ControllerRoute.GROUP.ACTIONS.GET_GROUPS_BY_SPACE_UUID_SUMMARY,
|
||||||
@ -26,7 +28,8 @@ export class GroupController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VIEW_DEVICE_WIZARD')
|
||||||
@Get(':spaceUuid/devices/:groupName')
|
@Get(':spaceUuid/devices/:groupName')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
|
@ -7,11 +7,12 @@ export class AdminRoleGuard extends AuthGuard('jwt') {
|
|||||||
if (err || !user) {
|
if (err || !user) {
|
||||||
throw err || new UnauthorizedException();
|
throw err || new UnauthorizedException();
|
||||||
} else {
|
} else {
|
||||||
const isAdmin = user.roles.some(
|
if (
|
||||||
(role) =>
|
!(
|
||||||
role.type === RoleType.SUPER_ADMIN || role.type === RoleType.ADMIN,
|
user.role.type === RoleType.ADMIN ||
|
||||||
);
|
user.role.type === RoleType.SUPER_ADMIN
|
||||||
if (!isAdmin) {
|
)
|
||||||
|
) {
|
||||||
throw new BadRequestException('Only admin role can access this route');
|
throw new BadRequestException('Only admin role can access this route');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -20,10 +20,10 @@ export class CommunityPermissionGuard implements CanActivate {
|
|||||||
|
|
||||||
if (
|
if (
|
||||||
user &&
|
user &&
|
||||||
user.roles &&
|
user.role &&
|
||||||
user.roles.some(
|
!(
|
||||||
(role) =>
|
user.role.type === RoleType.ADMIN ||
|
||||||
role.type === RoleType.ADMIN || role.type === RoleType.SUPER_ADMIN,
|
user.role.type === RoleType.SUPER_ADMIN
|
||||||
)
|
)
|
||||||
) {
|
) {
|
||||||
return true;
|
return true;
|
||||||
|
43
src/guards/permissions.guard.ts
Normal file
43
src/guards/permissions.guard.ts
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
import { Injectable, ExecutionContext } from '@nestjs/common';
|
||||||
|
import { AuthGuard } from '@nestjs/passport';
|
||||||
|
import { Reflector } from '@nestjs/core';
|
||||||
|
import { RolePermissions } from '@app/common/constants/role-permissions';
|
||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class PermissionsGuard extends AuthGuard('jwt') {
|
||||||
|
constructor(private reflector: Reflector) {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
async canActivate(context: ExecutionContext): Promise<boolean> {
|
||||||
|
// First, run the AuthGuard logic to validate the JWT
|
||||||
|
const isAuthenticated = await super.canActivate(context);
|
||||||
|
if (!isAuthenticated) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Authorization logic
|
||||||
|
const requiredPermissions = this.reflector.get<string[]>(
|
||||||
|
'permissions',
|
||||||
|
context.getHandler(),
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!requiredPermissions) {
|
||||||
|
return true; // Allow if no permissions are specified
|
||||||
|
}
|
||||||
|
|
||||||
|
const request = context.switchToHttp().getRequest();
|
||||||
|
const user = request.user; // User is now available after AuthGuard
|
||||||
|
|
||||||
|
const userRole = user?.role.type as RoleType;
|
||||||
|
if (!userRole || !RolePermissions[userRole]) {
|
||||||
|
return false; // Deny if role or permissions are missing
|
||||||
|
}
|
||||||
|
|
||||||
|
const userPermissions = RolePermissions[userRole];
|
||||||
|
|
||||||
|
// Check if the user has the required permissions
|
||||||
|
return requiredPermissions.every((perm) => userPermissions.includes(perm));
|
||||||
|
}
|
||||||
|
}
|
@ -7,10 +7,7 @@ export class SuperAdminRoleGuard extends AuthGuard('jwt') {
|
|||||||
if (err || !user) {
|
if (err || !user) {
|
||||||
throw err || new UnauthorizedException();
|
throw err || new UnauthorizedException();
|
||||||
} else {
|
} else {
|
||||||
const isSuperAdmin = user.roles.some(
|
if (!(user.role.type === RoleType.SUPER_ADMIN)) {
|
||||||
(role) => role.type === RoleType.SUPER_ADMIN,
|
|
||||||
);
|
|
||||||
if (!isSuperAdmin) {
|
|
||||||
throw new BadRequestException(
|
throw new BadRequestException(
|
||||||
'Only super admin role can access this route',
|
'Only super admin role can access this route',
|
||||||
);
|
);
|
||||||
|
1
src/invite-user/controllers/index.ts
Normal file
1
src/invite-user/controllers/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './invite-user.controller';
|
37
src/invite-user/controllers/invite-user.controller.ts
Normal file
37
src/invite-user/controllers/invite-user.controller.ts
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
import { InviteUserService } from '../services/invite-user.service';
|
||||||
|
import { Body, Controller, Post, Req, UseGuards } from '@nestjs/common';
|
||||||
|
import { ApiTags, ApiBearerAuth, ApiOperation } from '@nestjs/swagger';
|
||||||
|
import { AddUserInvitationDto } from '../dtos/add.invite-user.dto';
|
||||||
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
|
@ApiTags('Invite User Module')
|
||||||
|
@Controller({
|
||||||
|
version: '1',
|
||||||
|
path: ControllerRoute.INVITE_USER.ROUTE,
|
||||||
|
})
|
||||||
|
export class InviteUserController {
|
||||||
|
constructor(private readonly inviteUserService: InviteUserService) {}
|
||||||
|
|
||||||
|
@ApiBearerAuth()
|
||||||
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('USER_ADD')
|
||||||
|
@Post()
|
||||||
|
@ApiOperation({
|
||||||
|
summary: ControllerRoute.INVITE_USER.ACTIONS.CREATE_USER_INVITATION_SUMMARY,
|
||||||
|
description:
|
||||||
|
ControllerRoute.INVITE_USER.ACTIONS.CREATE_USER_INVITATION_DESCRIPTION,
|
||||||
|
})
|
||||||
|
async createUserInvitation(
|
||||||
|
@Body() addUserInvitationDto: AddUserInvitationDto,
|
||||||
|
@Req() request: any,
|
||||||
|
): Promise<BaseResponseDto> {
|
||||||
|
const user = request.user;
|
||||||
|
return await this.inviteUserService.createUserInvitation(
|
||||||
|
addUserInvitationDto,
|
||||||
|
user.role.type,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
75
src/invite-user/dtos/add.invite-user.dto.ts
Normal file
75
src/invite-user/dtos/add.invite-user.dto.ts
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
import { ApiProperty } from '@nestjs/swagger';
|
||||||
|
import {
|
||||||
|
ArrayMinSize,
|
||||||
|
IsArray,
|
||||||
|
IsNotEmpty,
|
||||||
|
IsOptional,
|
||||||
|
IsString,
|
||||||
|
} from 'class-validator';
|
||||||
|
|
||||||
|
export class AddUserInvitationDto {
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The first name of the user',
|
||||||
|
example: 'John',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public firstName: string;
|
||||||
|
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The last name of the user',
|
||||||
|
example: 'Doe',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public lastName: string;
|
||||||
|
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The email of the user',
|
||||||
|
example: 'OqM9A@example.com',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public email: string;
|
||||||
|
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The job title of the user',
|
||||||
|
example: 'Software Engineer',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public jobTitle: string;
|
||||||
|
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The phone number of the user',
|
||||||
|
example: '+1234567890',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsOptional()
|
||||||
|
public phoneNumber?: string;
|
||||||
|
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The role uuid of the user',
|
||||||
|
example: 'd290f1ee-6c54-4b01-90e6-d701748f0851',
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public roleUuid: string;
|
||||||
|
@ApiProperty({
|
||||||
|
description: 'The array of space UUIDs (at least one required)',
|
||||||
|
example: ['b5f3c9d2-58b7-4377-b3f7-60acb711d5d9'],
|
||||||
|
required: true,
|
||||||
|
})
|
||||||
|
@IsArray()
|
||||||
|
@ArrayMinSize(1)
|
||||||
|
public spaceUuids: string[];
|
||||||
|
constructor(dto: Partial<AddUserInvitationDto>) {
|
||||||
|
Object.assign(this, dto);
|
||||||
|
}
|
||||||
|
}
|
1
src/invite-user/dtos/index.ts
Normal file
1
src/invite-user/dtos/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './add.invite-user.dto';
|
23
src/invite-user/invite-user.module.ts
Normal file
23
src/invite-user/invite-user.module.ts
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { InviteUserService } from './services/invite-user.service';
|
||||||
|
import { InviteUserController } from './controllers/invite-user.controller';
|
||||||
|
import { ConfigModule } from '@nestjs/config';
|
||||||
|
import {
|
||||||
|
InviteUserRepository,
|
||||||
|
InviteUserSpaceRepository,
|
||||||
|
} from '@app/common/modules/invite-user/repositories';
|
||||||
|
import { UserRepository } from '@app/common/modules/user/repositories';
|
||||||
|
import { InviteUserRepositoryModule } from '@app/common/modules/invite-user/invite-user.repository.module';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [ConfigModule, InviteUserRepositoryModule],
|
||||||
|
controllers: [InviteUserController],
|
||||||
|
providers: [
|
||||||
|
InviteUserService,
|
||||||
|
InviteUserRepository,
|
||||||
|
UserRepository,
|
||||||
|
InviteUserSpaceRepository,
|
||||||
|
],
|
||||||
|
exports: [InviteUserService],
|
||||||
|
})
|
||||||
|
export class InviteUserModule {}
|
1
src/invite-user/services/index.ts
Normal file
1
src/invite-user/services/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './invite-user.service';
|
106
src/invite-user/services/invite-user.service.ts
Normal file
106
src/invite-user/services/invite-user.service.ts
Normal file
@ -0,0 +1,106 @@
|
|||||||
|
import { InviteUserSpaceRepository } from '../../../libs/common/src/modules/invite-user/repositories/invite-user.repository';
|
||||||
|
import { Injectable, HttpException, HttpStatus } from '@nestjs/common';
|
||||||
|
import { AddUserInvitationDto } from '../dtos';
|
||||||
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
|
import { InviteUserRepository } from '@app/common/modules/invite-user/repositories';
|
||||||
|
import { UserStatusEnum } from '@app/common/constants/user-status.enum';
|
||||||
|
import { SuccessResponseDto } from '@app/common/dto/success.response.dto';
|
||||||
|
import { generateRandomString } from '@app/common/helper/randomString';
|
||||||
|
import { IsNull, Not } from 'typeorm';
|
||||||
|
import { DataSource } from 'typeorm';
|
||||||
|
import { UserEntity } from '@app/common/modules/user/entities';
|
||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class InviteUserService {
|
||||||
|
constructor(
|
||||||
|
private readonly inviteUserRepository: InviteUserRepository,
|
||||||
|
private readonly inviteUserSpaceRepository: InviteUserSpaceRepository,
|
||||||
|
private readonly dataSource: DataSource,
|
||||||
|
) {}
|
||||||
|
|
||||||
|
async createUserInvitation(
|
||||||
|
dto: AddUserInvitationDto,
|
||||||
|
roleType: RoleType,
|
||||||
|
): Promise<BaseResponseDto> {
|
||||||
|
const {
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
email,
|
||||||
|
jobTitle,
|
||||||
|
phoneNumber,
|
||||||
|
roleUuid,
|
||||||
|
spaceUuids,
|
||||||
|
} = dto;
|
||||||
|
|
||||||
|
const invitationCode = generateRandomString(6);
|
||||||
|
const queryRunner = this.dataSource.createQueryRunner();
|
||||||
|
|
||||||
|
await queryRunner.startTransaction();
|
||||||
|
|
||||||
|
try {
|
||||||
|
const userRepo = queryRunner.manager.getRepository(UserEntity);
|
||||||
|
|
||||||
|
const user = await userRepo.findOne({
|
||||||
|
where: {
|
||||||
|
email,
|
||||||
|
project: Not(IsNull()),
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (user) {
|
||||||
|
throw new HttpException(
|
||||||
|
'User already has a project',
|
||||||
|
HttpStatus.BAD_REQUEST,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const inviteUser = this.inviteUserRepository.create({
|
||||||
|
firstName,
|
||||||
|
lastName,
|
||||||
|
email,
|
||||||
|
jobTitle,
|
||||||
|
phoneNumber,
|
||||||
|
roleType: { uuid: roleUuid },
|
||||||
|
status: UserStatusEnum.INVITED,
|
||||||
|
invitationCode,
|
||||||
|
invitedBy: roleType,
|
||||||
|
});
|
||||||
|
|
||||||
|
const invitedUser = await queryRunner.manager.save(inviteUser);
|
||||||
|
|
||||||
|
const spacePromises = spaceUuids.map(async (spaceUuid) => {
|
||||||
|
const inviteUserSpace = this.inviteUserSpaceRepository.create({
|
||||||
|
inviteUser: { uuid: invitedUser.uuid },
|
||||||
|
space: { uuid: spaceUuid },
|
||||||
|
});
|
||||||
|
return queryRunner.manager.save(inviteUserSpace);
|
||||||
|
});
|
||||||
|
|
||||||
|
await Promise.all(spacePromises);
|
||||||
|
|
||||||
|
await queryRunner.commitTransaction();
|
||||||
|
|
||||||
|
return new SuccessResponseDto({
|
||||||
|
statusCode: HttpStatus.CREATED,
|
||||||
|
success: true,
|
||||||
|
data: {
|
||||||
|
invitationCode: invitedUser.invitationCode,
|
||||||
|
},
|
||||||
|
message: 'User invited successfully',
|
||||||
|
});
|
||||||
|
} catch (error) {
|
||||||
|
await queryRunner.rollbackTransaction();
|
||||||
|
if (error instanceof HttpException) {
|
||||||
|
throw error;
|
||||||
|
}
|
||||||
|
console.error('Error creating user invitation:', error);
|
||||||
|
throw new HttpException(
|
||||||
|
error.message || 'An unexpected error occurred while inviting the user',
|
||||||
|
error.status || HttpStatus.INTERNAL_SERVER_ERROR,
|
||||||
|
);
|
||||||
|
} finally {
|
||||||
|
await queryRunner.release();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1
src/permission/controllers/index.ts
Normal file
1
src/permission/controllers/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './permission.controller';
|
24
src/permission/controllers/permission.controller.ts
Normal file
24
src/permission/controllers/permission.controller.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
import { Controller, Get, Param } from '@nestjs/common';
|
||||||
|
import { ApiTags, ApiOperation } from '@nestjs/swagger';
|
||||||
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
|
import { PermissionService } from '../services';
|
||||||
|
|
||||||
|
@ApiTags('Permission Module')
|
||||||
|
@Controller({
|
||||||
|
version: EnableDisableStatusEnum.ENABLED,
|
||||||
|
path: ControllerRoute.PERMISSION.ROUTE,
|
||||||
|
})
|
||||||
|
export class PermissionController {
|
||||||
|
constructor(private readonly permissionService: PermissionService) {}
|
||||||
|
|
||||||
|
@Get(':roleUuid')
|
||||||
|
@ApiOperation({
|
||||||
|
summary: ControllerRoute.PERMISSION.ACTIONS.GET_PERMISSION_BY_ROLE_SUMMARY,
|
||||||
|
description:
|
||||||
|
ControllerRoute.PERMISSION.ACTIONS.GET_PERMISSION_BY_ROLE_DESCRIPTION,
|
||||||
|
})
|
||||||
|
async getPermissionsByRole(@Param('roleUuid') roleUuid: string) {
|
||||||
|
return await this.permissionService.getPermissionsByRole(roleUuid);
|
||||||
|
}
|
||||||
|
}
|
14
src/permission/permission.module.ts
Normal file
14
src/permission/permission.module.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { ConfigModule } from '@nestjs/config';
|
||||||
|
import { CommonModule } from '@app/common';
|
||||||
|
import { PermissionController } from './controllers';
|
||||||
|
import { PermissionService } from './services';
|
||||||
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
imports: [ConfigModule, CommonModule],
|
||||||
|
controllers: [PermissionController],
|
||||||
|
providers: [PermissionService, RoleTypeRepository],
|
||||||
|
exports: [PermissionService],
|
||||||
|
})
|
||||||
|
export class PermissionModule {}
|
1
src/permission/services/index.ts
Normal file
1
src/permission/services/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './permission.service';
|
52
src/permission/services/permission.service.ts
Normal file
52
src/permission/services/permission.service.ts
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
import { PermissionMapping } from '@app/common/constants/permissions-mapping';
|
||||||
|
import { RolePermissions } from '@app/common/constants/role-permissions';
|
||||||
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
|
import { HttpException, HttpStatus, Injectable } from '@nestjs/common';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class PermissionService {
|
||||||
|
constructor(private readonly roleTypeRepository: RoleTypeRepository) {}
|
||||||
|
|
||||||
|
async getPermissionsByRole(roleUuid: string) {
|
||||||
|
try {
|
||||||
|
const role = await this.roleTypeRepository.findOne({
|
||||||
|
where: {
|
||||||
|
uuid: roleUuid,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!role) {
|
||||||
|
throw new HttpException('Role not found', HttpStatus.NOT_FOUND);
|
||||||
|
}
|
||||||
|
|
||||||
|
const permissions = this.mapPermissions(role.type.toString() as RoleType);
|
||||||
|
return permissions;
|
||||||
|
} catch (err) {
|
||||||
|
throw new HttpException(
|
||||||
|
err.message || 'Internal Server Error',
|
||||||
|
err.status || HttpStatus.INTERNAL_SERVER_ERROR,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mapPermissions(role: RoleType): any[] {
|
||||||
|
const rolePermissions = RolePermissions[role]; // Permissions for the role
|
||||||
|
|
||||||
|
const mappedPermissions = Object.entries(PermissionMapping).map(
|
||||||
|
([title, subOptions]) => ({
|
||||||
|
title,
|
||||||
|
subOptions: Object.entries(subOptions).map(
|
||||||
|
([subTitle, permissions]) => ({
|
||||||
|
title: subTitle,
|
||||||
|
subOptions: permissions.map((permission) => ({
|
||||||
|
title: permission,
|
||||||
|
isChecked: rolePermissions.includes(`${subTitle}_${permission}`), // Check if the role has the permission
|
||||||
|
})),
|
||||||
|
}),
|
||||||
|
),
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
|
return mappedPermissions;
|
||||||
|
}
|
||||||
|
}
|
@ -36,19 +36,4 @@ export class RoleController {
|
|||||||
data: roleTypes,
|
data: roleTypes,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
|
||||||
@UseGuards(SuperAdminRoleGuard)
|
|
||||||
@Post()
|
|
||||||
@ApiOperation({
|
|
||||||
summary: ControllerRoute.ROLE.ACTIONS.ADD_USER_ROLE_SUMMARY,
|
|
||||||
description: ControllerRoute.ROLE.ACTIONS.ADD_USER_ROLE_DESCRIPTION,
|
|
||||||
})
|
|
||||||
async addUserRoleType(@Body() addUserRoleDto: AddUserRoleDto) {
|
|
||||||
await this.roleService.addUserRoleType(addUserRoleDto);
|
|
||||||
return {
|
|
||||||
statusCode: HttpStatus.OK,
|
|
||||||
message: 'User Role Added Successfully',
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,6 @@ import { RoleController } from './controllers/role.controller';
|
|||||||
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 { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
import { RoleTypeRepository } from '@app/common/modules/role-type/repositories';
|
||||||
import { UserRoleRepository } from '@app/common/modules/user/repositories';
|
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [ConfigModule, DeviceRepositoryModule],
|
imports: [ConfigModule, DeviceRepositoryModule],
|
||||||
@ -18,7 +17,6 @@ import { UserRoleRepository } from '@app/common/modules/user/repositories';
|
|||||||
DeviceRepository,
|
DeviceRepository,
|
||||||
RoleService,
|
RoleService,
|
||||||
RoleTypeRepository,
|
RoleTypeRepository,
|
||||||
UserRoleRepository,
|
|
||||||
],
|
],
|
||||||
exports: [RoleService],
|
exports: [RoleService],
|
||||||
})
|
})
|
||||||
|
@ -1,55 +1,16 @@
|
|||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
import { RoleTypeRepository } from './../../../libs/common/src/modules/role-type/repositories/role.type.repository';
|
import { RoleTypeRepository } from './../../../libs/common/src/modules/role-type/repositories/role.type.repository';
|
||||||
import { HttpException, HttpStatus, Injectable } from '@nestjs/common';
|
import { RoleType } from '@app/common/constants/role.type.enum';
|
||||||
import { AddUserRoleDto } from '../dtos/role.add.dto';
|
|
||||||
import { UserRoleRepository } from '@app/common/modules/user/repositories';
|
|
||||||
import { QueryFailedError } from 'typeorm';
|
|
||||||
import { CommonErrorCodes } from '@app/common/constants/error-codes.enum';
|
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class RoleService {
|
export class RoleService {
|
||||||
constructor(
|
constructor(private readonly roleTypeRepository: RoleTypeRepository) {}
|
||||||
private readonly roleTypeRepository: RoleTypeRepository,
|
|
||||||
private readonly userRoleRepository: UserRoleRepository,
|
|
||||||
) {}
|
|
||||||
|
|
||||||
async addUserRoleType(addUserRoleDto: AddUserRoleDto) {
|
|
||||||
try {
|
|
||||||
const roleType = await this.fetchRoleByType(addUserRoleDto.roleType);
|
|
||||||
|
|
||||||
if (roleType.uuid) {
|
|
||||||
return await this.userRoleRepository.save({
|
|
||||||
user: { uuid: addUserRoleDto.userUuid },
|
|
||||||
roleType: { uuid: roleType.uuid },
|
|
||||||
});
|
|
||||||
}
|
|
||||||
} catch (error) {
|
|
||||||
if (
|
|
||||||
error instanceof QueryFailedError &&
|
|
||||||
error.driverError.code === CommonErrorCodes.DUPLICATE_ENTITY
|
|
||||||
) {
|
|
||||||
// Postgres unique constraint violation error code
|
|
||||||
throw new HttpException(
|
|
||||||
'This role already exists for this user',
|
|
||||||
HttpStatus.CONFLICT,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
throw new HttpException(
|
|
||||||
error.message || 'Internal Server Error',
|
|
||||||
HttpStatus.INTERNAL_SERVER_ERROR,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async fetchRoleTypes() {
|
async fetchRoleTypes() {
|
||||||
const roleTypes = await this.roleTypeRepository.find();
|
const roleTypes = await this.roleTypeRepository.find();
|
||||||
|
const roles = roleTypes.filter(
|
||||||
return roleTypes;
|
(roleType) => roleType.type !== RoleType.SUPER_ADMIN,
|
||||||
}
|
);
|
||||||
private async fetchRoleByType(roleType: string) {
|
return roles;
|
||||||
return await this.roleTypeRepository.findOne({
|
|
||||||
where: {
|
|
||||||
type: roleType,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,11 +16,12 @@ import {
|
|||||||
AddSceneTapToRunDto,
|
AddSceneTapToRunDto,
|
||||||
UpdateSceneTapToRunDto,
|
UpdateSceneTapToRunDto,
|
||||||
} from '../dtos/scene.dto';
|
} from '../dtos/scene.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import { SceneParamDto } from '../dtos';
|
import { SceneParamDto } from '../dtos';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Scene Module')
|
@ApiTags('Scene Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -31,7 +32,8 @@ export class SceneController {
|
|||||||
constructor(private readonly sceneService: SceneService) {}
|
constructor(private readonly sceneService: SceneService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_ADD')
|
||||||
@Post('tap-to-run')
|
@Post('tap-to-run')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SCENE.ACTIONS.CREATE_TAP_TO_RUN_SCENE_SUMMARY,
|
summary: ControllerRoute.SCENE.ACTIONS.CREATE_TAP_TO_RUN_SCENE_SUMMARY,
|
||||||
@ -45,7 +47,8 @@ export class SceneController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_DELETE')
|
||||||
@Delete('tap-to-run/:sceneUuid')
|
@Delete('tap-to-run/:sceneUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SCENE.ACTIONS.DELETE_TAP_TO_RUN_SCENE_SUMMARY,
|
summary: ControllerRoute.SCENE.ACTIONS.DELETE_TAP_TO_RUN_SCENE_SUMMARY,
|
||||||
@ -59,7 +62,8 @@ export class SceneController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_CONTROL')
|
||||||
@Post('tap-to-run/:sceneUuid/trigger')
|
@Post('tap-to-run/:sceneUuid/trigger')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SCENE.ACTIONS.TRIGGER_TAP_TO_RUN_SCENE_SUMMARY,
|
summary: ControllerRoute.SCENE.ACTIONS.TRIGGER_TAP_TO_RUN_SCENE_SUMMARY,
|
||||||
@ -71,7 +75,8 @@ export class SceneController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_VIEW')
|
||||||
@Get('tap-to-run/:sceneUuid')
|
@Get('tap-to-run/:sceneUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SCENE.ACTIONS.GET_TAP_TO_RUN_SCENE_SUMMARY,
|
summary: ControllerRoute.SCENE.ACTIONS.GET_TAP_TO_RUN_SCENE_SUMMARY,
|
||||||
@ -84,7 +89,8 @@ export class SceneController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_UPDATE')
|
||||||
@Put('tap-to-run/:sceneUuid')
|
@Put('tap-to-run/:sceneUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SCENE.ACTIONS.UPDATE_TAP_TO_RUN_SCENE_SUMMARY,
|
summary: ControllerRoute.SCENE.ACTIONS.UPDATE_TAP_TO_RUN_SCENE_SUMMARY,
|
||||||
@ -102,7 +108,8 @@ export class SceneController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_ADD')
|
||||||
@Post('icon')
|
@Post('icon')
|
||||||
async addSceneIcon(@Body() addSceneIconDto: AddSceneIconDto) {
|
async addSceneIcon(@Body() addSceneIconDto: AddSceneIconDto) {
|
||||||
const tapToRunScene = await this.sceneService.addSceneIcon(addSceneIconDto);
|
const tapToRunScene = await this.sceneService.addSceneIcon(addSceneIconDto);
|
||||||
@ -114,7 +121,8 @@ export class SceneController {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_VIEW')
|
||||||
@Get('icon')
|
@Get('icon')
|
||||||
async getAllIcons() {
|
async getAllIcons() {
|
||||||
const icons = await this.sceneService.getAllIcons();
|
const icons = await this.sceneService.getAllIcons();
|
||||||
|
@ -4,8 +4,9 @@ import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
|||||||
import { SpaceModelService } from '../services';
|
import { SpaceModelService } from '../services';
|
||||||
import { CreateSpaceModelDto } from '../dtos';
|
import { CreateSpaceModelDto } from '../dtos';
|
||||||
import { ProjectParam } from 'src/community/dtos';
|
import { ProjectParam } from 'src/community/dtos';
|
||||||
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 { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Model Module')
|
@ApiTags('Space Model Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -16,7 +17,8 @@ export class SpaceModelController {
|
|||||||
constructor(private readonly spaceModelService: SpaceModelService) {}
|
constructor(private readonly spaceModelService: SpaceModelService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_MODULE_ADD')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE_MODEL.ACTIONS.CREATE_SPACE_MODEL_SUMMARY,
|
summary: ControllerRoute.SPACE_MODEL.ACTIONS.CREATE_SPACE_MODEL_SUMMARY,
|
||||||
description:
|
description:
|
||||||
|
@ -1,10 +1,11 @@
|
|||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { Controller, Get, Param, UseGuards } from '@nestjs/common';
|
import { Controller, Get, Param, UseGuards } from '@nestjs/common';
|
||||||
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { GetSpaceParam } from '../dtos';
|
import { GetSpaceParam } from '../dtos';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { SpaceDeviceService } from '../services';
|
import { SpaceDeviceService } from '../services';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -15,7 +16,8 @@ export class SpaceDeviceController {
|
|||||||
constructor(private readonly spaceDeviceService: SpaceDeviceService) {}
|
constructor(private readonly spaceDeviceService: SpaceDeviceService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VIEW_DEVICE_IN_SPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE_DEVICES.ACTIONS.LIST_SPACE_DEVICE_SUMMARY,
|
summary: ControllerRoute.SPACE_DEVICES.ACTIONS.LIST_SPACE_DEVICE_SUMMARY,
|
||||||
description:
|
description:
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { Controller, Get, Param, Query, UseGuards } from '@nestjs/common';
|
import { Controller, Get, Param, Query, UseGuards } from '@nestjs/common';
|
||||||
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
||||||
import { SpaceSceneService } from '../services';
|
import { SpaceSceneService } from '../services';
|
||||||
import { GetSceneDto } from '../../scene/dtos';
|
import { GetSceneDto } from '../../scene/dtos';
|
||||||
import { GetSpaceParam } from '../dtos';
|
import { GetSpaceParam } from '../dtos';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -16,7 +17,8 @@ export class SpaceSceneController {
|
|||||||
constructor(private readonly sceneService: SpaceSceneService) {}
|
constructor(private readonly sceneService: SpaceSceneService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SCENES_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SPACE_SCENE.ACTIONS.GET_TAP_TO_RUN_SCENE_BY_SPACE_SUMMARY,
|
ControllerRoute.SPACE_SCENE.ACTIONS.GET_TAP_TO_RUN_SCENE_BY_SPACE_SUMMARY,
|
||||||
|
@ -3,8 +3,9 @@ import { Controller, Delete, Param, Post, UseGuards } from '@nestjs/common';
|
|||||||
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
||||||
import { SpaceUserService } from '../services';
|
import { SpaceUserService } from '../services';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { UserSpaceParam } from '../dtos';
|
import { UserSpaceParam } from '../dtos';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -16,7 +17,8 @@ export class SpaceUserController {
|
|||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@Post('/:userUuid')
|
@Post('/:userUuid')
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('ASSIGN_USER_TO_SPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SPACE_USER.ACTIONS.ASSOCIATE_SPACE_USER_DESCRIPTION,
|
ControllerRoute.SPACE_USER.ACTIONS.ASSOCIATE_SPACE_USER_DESCRIPTION,
|
||||||
@ -31,7 +33,8 @@ export class SpaceUserController {
|
|||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@Delete('/:userUuid')
|
@Delete('/:userUuid')
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DELETE_USER_FROM_SPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE_USER.ACTIONS.DISSOCIATE_SPACE_USER_SUMMARY,
|
summary: ControllerRoute.SPACE_USER.ACTIONS.DISSOCIATE_SPACE_USER_SUMMARY,
|
||||||
description:
|
description:
|
||||||
|
@ -11,10 +11,11 @@ import {
|
|||||||
Put,
|
Put,
|
||||||
UseGuards,
|
UseGuards,
|
||||||
} from '@nestjs/common';
|
} from '@nestjs/common';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { AddSpaceDto, CommunitySpaceParam, UpdateSpaceDto } from '../dtos';
|
import { AddSpaceDto, CommunitySpaceParam, UpdateSpaceDto } from '../dtos';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { GetSpaceParam } from '../dtos/get.space.param';
|
import { GetSpaceParam } from '../dtos/get.space.param';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -25,7 +26,8 @@ export class SpaceController {
|
|||||||
constructor(private readonly spaceService: SpaceService) {}
|
constructor(private readonly spaceService: SpaceService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_ADD')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.CREATE_SPACE_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.CREATE_SPACE_SUMMARY,
|
||||||
description: ControllerRoute.SPACE.ACTIONS.CREATE_SPACE_DESCRIPTION,
|
description: ControllerRoute.SPACE.ACTIONS.CREATE_SPACE_DESCRIPTION,
|
||||||
@ -42,7 +44,8 @@ export class SpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SPACE.ACTIONS.GET_COMMUNITY_SPACES_HIERARCHY_SUMMARY,
|
ControllerRoute.SPACE.ACTIONS.GET_COMMUNITY_SPACES_HIERARCHY_SUMMARY,
|
||||||
@ -57,7 +60,8 @@ export class SpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_DELETE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.DELETE_SPACE_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.DELETE_SPACE_SUMMARY,
|
||||||
description: ControllerRoute.SPACE.ACTIONS.DELETE_SPACE_DESCRIPTION,
|
description: ControllerRoute.SPACE.ACTIONS.DELETE_SPACE_DESCRIPTION,
|
||||||
@ -68,7 +72,8 @@ export class SpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_UPDATE')
|
||||||
@Put('/:spaceUuid')
|
@Put('/:spaceUuid')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.UPDATE_SPACE_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.UPDATE_SPACE_SUMMARY,
|
||||||
@ -82,7 +87,8 @@ export class SpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.GET_SPACE_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.GET_SPACE_SUMMARY,
|
||||||
description: ControllerRoute.SPACE.ACTIONS.GET_SPACE_DESCRIPTION,
|
description: ControllerRoute.SPACE.ACTIONS.GET_SPACE_DESCRIPTION,
|
||||||
@ -93,7 +99,8 @@ export class SpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.GET_HEIRARCHY_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.GET_HEIRARCHY_SUMMARY,
|
||||||
description: ControllerRoute.SPACE.ACTIONS.GET_HEIRARCHY_DESCRIPTION,
|
description: ControllerRoute.SPACE.ACTIONS.GET_HEIRARCHY_DESCRIPTION,
|
||||||
@ -107,7 +114,8 @@ export class SpaceController {
|
|||||||
|
|
||||||
//should it be post?
|
//should it be post?
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SPACE_MEMBER_ADD')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SPACE.ACTIONS.CREATE_INVITATION_CODE_SPACE_SUMMARY,
|
summary: ControllerRoute.SPACE.ACTIONS.CREATE_INVITATION_CODE_SPACE_SUMMARY,
|
||||||
description:
|
description:
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import {
|
import {
|
||||||
Controller,
|
Controller,
|
||||||
Delete,
|
Delete,
|
||||||
@ -12,6 +11,8 @@ import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
|||||||
import { DeviceSubSpaceParam, GetSubSpaceParam } from '../../dtos';
|
import { DeviceSubSpaceParam, GetSubSpaceParam } from '../../dtos';
|
||||||
import { SubspaceDeviceService } from 'src/space/services';
|
import { SubspaceDeviceService } from 'src/space/services';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -22,7 +23,8 @@ export class SubSpaceDeviceController {
|
|||||||
constructor(private readonly subspaceDeviceService: SubspaceDeviceService) {}
|
constructor(private readonly subspaceDeviceService: SubspaceDeviceService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VIEW_DEVICE_IN_SUBSPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SUBSPACE_DEVICE.ACTIONS.LIST_SUBSPACE_DEVICE_SUMMARY,
|
ControllerRoute.SUBSPACE_DEVICE.ACTIONS.LIST_SUBSPACE_DEVICE_SUMMARY,
|
||||||
@ -37,7 +39,8 @@ export class SubSpaceDeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('ASSIGN_DEVICE_TO_SUBSPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SUBSPACE_DEVICE.ACTIONS.ASSOCIATE_SUBSPACE_DEVICE_SUMMARY,
|
ControllerRoute.SUBSPACE_DEVICE.ACTIONS.ASSOCIATE_SUBSPACE_DEVICE_SUMMARY,
|
||||||
@ -53,7 +56,8 @@ export class SubSpaceDeviceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('DELETE_DEVICE_FROM_SUBSPACE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
ControllerRoute.SUBSPACE_DEVICE.ACTIONS
|
ControllerRoute.SUBSPACE_DEVICE.ACTIONS
|
||||||
|
@ -14,8 +14,9 @@ import { SubSpaceService } from '../../services';
|
|||||||
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
import { ApiBearerAuth, ApiOperation, ApiTags } from '@nestjs/swagger';
|
||||||
import { AddSubspaceDto, GetSpaceParam, GetSubSpaceParam } from '../../dtos';
|
import { AddSubspaceDto, GetSpaceParam, GetSubSpaceParam } from '../../dtos';
|
||||||
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
import { BaseResponseDto } from '@app/common/dto/base.response.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { PaginationRequestGetListDto } from '@app/common/dto/pagination.request.dto';
|
import { PaginationRequestGetListDto } from '@app/common/dto/pagination.request.dto';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Space Module')
|
@ApiTags('Space Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -26,7 +27,8 @@ export class SubSpaceController {
|
|||||||
constructor(private readonly subSpaceService: SubSpaceService) {}
|
constructor(private readonly subSpaceService: SubSpaceService) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SUBSPACE_ADD')
|
||||||
@Post()
|
@Post()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SUBSPACE.ACTIONS.CREATE_SUBSPACE_SUMMARY,
|
summary: ControllerRoute.SUBSPACE.ACTIONS.CREATE_SUBSPACE_SUMMARY,
|
||||||
@ -40,7 +42,8 @@ export class SubSpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SUBSPACE_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SUBSPACE.ACTIONS.LIST_SUBSPACES_SUMMARY,
|
summary: ControllerRoute.SUBSPACE.ACTIONS.LIST_SUBSPACES_SUMMARY,
|
||||||
description: ControllerRoute.SUBSPACE.ACTIONS.LIST_SUBSPACES_DESCRIPTION,
|
description: ControllerRoute.SUBSPACE.ACTIONS.LIST_SUBSPACES_DESCRIPTION,
|
||||||
@ -54,7 +57,8 @@ export class SubSpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SUBSPACE_VIEW')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SUBSPACE.ACTIONS.GET_SUBSPACE_SUMMARY,
|
summary: ControllerRoute.SUBSPACE.ACTIONS.GET_SUBSPACE_SUMMARY,
|
||||||
description: ControllerRoute.SUBSPACE.ACTIONS.GET_SUBSPACE_DESCRIPTION,
|
description: ControllerRoute.SUBSPACE.ACTIONS.GET_SUBSPACE_DESCRIPTION,
|
||||||
@ -65,7 +69,8 @@ export class SubSpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SUBSPACE_UPDATE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SUBSPACE.ACTIONS.UPDATE_SUBSPACE_SUMMARY,
|
summary: ControllerRoute.SUBSPACE.ACTIONS.UPDATE_SUBSPACE_SUMMARY,
|
||||||
description: ControllerRoute.SUBSPACE.ACTIONS.UPDATE_SUBSPACE_DESCRIPTION,
|
description: ControllerRoute.SUBSPACE.ACTIONS.UPDATE_SUBSPACE_DESCRIPTION,
|
||||||
@ -79,7 +84,8 @@ export class SubSpaceController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('SUBSPACE_DELETE')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary: ControllerRoute.SUBSPACE.ACTIONS.DELETE_SUBSPACE_SUMMARY,
|
summary: ControllerRoute.SUBSPACE.ACTIONS.DELETE_SUBSPACE_SUMMARY,
|
||||||
description: ControllerRoute.SUBSPACE.ACTIONS.DELETE_SUBSPACE_DESCRIPTION,
|
description: ControllerRoute.SUBSPACE.ACTIONS.DELETE_SUBSPACE_DESCRIPTION,
|
||||||
|
@ -15,9 +15,10 @@ import {
|
|||||||
AddDoorLockOnlineMultipleDto,
|
AddDoorLockOnlineMultipleDto,
|
||||||
AddDoorLockOnlineOneTimeDto,
|
AddDoorLockOnlineOneTimeDto,
|
||||||
} from '../dtos/temp-pass.dto';
|
} from '../dtos/temp-pass.dto';
|
||||||
import { JwtAuthGuard } from '@app/common/guards/jwt.auth.guard';
|
|
||||||
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
import { EnableDisableStatusEnum } from '@app/common/constants/days.enum';
|
||||||
import { ControllerRoute } from '@app/common/constants/controller-route';
|
import { ControllerRoute } from '@app/common/constants/controller-route';
|
||||||
|
import { PermissionsGuard } from 'src/guards/permissions.guard';
|
||||||
|
import { Permissions } from 'src/decorators/permissions.decorator';
|
||||||
|
|
||||||
@ApiTags('Visitor Password Module')
|
@ApiTags('Visitor Password Module')
|
||||||
@Controller({
|
@Controller({
|
||||||
@ -30,7 +31,8 @@ export class VisitorPasswordController {
|
|||||||
) {}
|
) {}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_ADD')
|
||||||
@Post('temporary-password/online/multiple-time')
|
@Post('temporary-password/online/multiple-time')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
@ -58,7 +60,8 @@ export class VisitorPasswordController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_ADD')
|
||||||
@Post('temporary-password/online/one-time')
|
@Post('temporary-password/online/one-time')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
@ -86,7 +89,8 @@ export class VisitorPasswordController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_ADD')
|
||||||
@Post('temporary-password/offline/one-time')
|
@Post('temporary-password/offline/one-time')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
@ -114,7 +118,8 @@ export class VisitorPasswordController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_ADD')
|
||||||
@Post('temporary-password/offline/multiple-time')
|
@Post('temporary-password/offline/multiple-time')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
@ -143,7 +148,8 @@ export class VisitorPasswordController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_VIEW')
|
||||||
@Get()
|
@Get()
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
@ -156,7 +162,8 @@ export class VisitorPasswordController {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ApiBearerAuth()
|
@ApiBearerAuth()
|
||||||
@UseGuards(JwtAuthGuard)
|
@UseGuards(PermissionsGuard)
|
||||||
|
@Permissions('VISITOR_PASSWORD_VIEW')
|
||||||
@Get('/devices')
|
@Get('/devices')
|
||||||
@ApiOperation({
|
@ApiOperation({
|
||||||
summary:
|
summary:
|
||||||
|
Reference in New Issue
Block a user