mirror of
https://github.com/SyncrowIOT/backend.git
synced 2025-11-27 14:54:54 +00:00
Add GroupDeviceEntity and related modules
This commit is contained in:
@ -7,12 +7,16 @@ import { UserSessionEntity } from '../modules/session/entities/session.entity';
|
|||||||
import { UserOtpEntity } from '../modules/user-otp/entities';
|
import { UserOtpEntity } from '../modules/user-otp/entities';
|
||||||
import { HomeEntity } from '../modules/home/entities';
|
import { HomeEntity } from '../modules/home/entities';
|
||||||
import { ProductEntity } from '../modules/product/entities';
|
import { ProductEntity } from '../modules/product/entities';
|
||||||
import { DeviceEntity, DeviceUserPermissionEntity } from '../modules/device/entities';
|
import {
|
||||||
|
DeviceEntity,
|
||||||
|
DeviceUserPermissionEntity,
|
||||||
|
} from '../modules/device/entities';
|
||||||
import { PermissionTypeEntity } from '../modules/permission/entities';
|
import { PermissionTypeEntity } from '../modules/permission/entities';
|
||||||
import { SpaceEntity } from '../modules/space/entities';
|
import { SpaceEntity } from '../modules/space/entities';
|
||||||
import { SpaceTypeEntity } from '../modules/space-type/entities';
|
import { SpaceTypeEntity } from '../modules/space-type/entities';
|
||||||
import { UserSpaceEntity } from '../modules/user-space/entities';
|
import { UserSpaceEntity } from '../modules/user-space/entities';
|
||||||
import { GroupEntity } from '../modules/group/entities';
|
import { GroupEntity } from '../modules/group/entities';
|
||||||
|
import { GroupDeviceEntity } from '../modules/group-device/entities';
|
||||||
|
|
||||||
@Module({
|
@Module({
|
||||||
imports: [
|
imports: [
|
||||||
@ -40,6 +44,7 @@ import { GroupEntity } from '../modules/group/entities';
|
|||||||
SpaceTypeEntity,
|
SpaceTypeEntity,
|
||||||
UserSpaceEntity,
|
UserSpaceEntity,
|
||||||
GroupEntity,
|
GroupEntity,
|
||||||
|
GroupDeviceEntity,
|
||||||
],
|
],
|
||||||
namingStrategy: new SnakeNamingStrategy(),
|
namingStrategy: new SnakeNamingStrategy(),
|
||||||
synchronize: Boolean(JSON.parse(configService.get('DB_SYNC'))),
|
synchronize: Boolean(JSON.parse(configService.get('DB_SYNC'))),
|
||||||
|
|||||||
@ -2,6 +2,7 @@ import { Column, Entity, OneToMany } from 'typeorm';
|
|||||||
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
import { DeviceDto } from '../dtos/device.dto';
|
import { DeviceDto } from '../dtos/device.dto';
|
||||||
import { DeviceUserPermissionEntity } from './device-user-type.entity';
|
import { DeviceUserPermissionEntity } from './device-user-type.entity';
|
||||||
|
import { GroupDeviceEntity } from '../../group-device/entities';
|
||||||
|
|
||||||
@Entity({ name: 'device' })
|
@Entity({ name: 'device' })
|
||||||
export class DeviceEntity extends AbstractEntity<DeviceDto> {
|
export class DeviceEntity extends AbstractEntity<DeviceDto> {
|
||||||
@ -37,6 +38,12 @@ export class DeviceEntity extends AbstractEntity<DeviceDto> {
|
|||||||
)
|
)
|
||||||
permission: DeviceUserPermissionEntity[];
|
permission: DeviceUserPermissionEntity[];
|
||||||
|
|
||||||
|
@OneToMany(
|
||||||
|
() => GroupDeviceEntity,
|
||||||
|
(userGroupDevices) => userGroupDevices.device,
|
||||||
|
)
|
||||||
|
userGroupDevices: GroupDeviceEntity[];
|
||||||
|
|
||||||
constructor(partial: Partial<DeviceEntity>) {
|
constructor(partial: Partial<DeviceEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
|
|||||||
@ -0,0 +1,15 @@
|
|||||||
|
import { IsNotEmpty, IsString } from 'class-validator';
|
||||||
|
|
||||||
|
export class GroupDeviceDto {
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public deviceUuid: string;
|
||||||
|
|
||||||
|
@IsString()
|
||||||
|
@IsNotEmpty()
|
||||||
|
public groupUuid: string;
|
||||||
|
}
|
||||||
1
libs/common/src/modules/group-device/dtos/index.ts
Normal file
1
libs/common/src/modules/group-device/dtos/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './group.device.dto';
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
import { Column, Entity, ManyToOne } from 'typeorm';
|
||||||
|
import { GroupDeviceDto } from '../dtos';
|
||||||
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
|
import { DeviceEntity } from '../../device/entities';
|
||||||
|
import { GroupEntity } from '../../group/entities';
|
||||||
|
|
||||||
|
@Entity({ name: 'group-device' })
|
||||||
|
export class GroupDeviceEntity extends AbstractEntity<GroupDeviceDto> {
|
||||||
|
@Column({
|
||||||
|
type: 'uuid',
|
||||||
|
default: () => 'gen_random_uuid()', // Use gen_random_uuid() for default value
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
public uuid: string;
|
||||||
|
|
||||||
|
@ManyToOne(() => DeviceEntity, (device) => device.userGroupDevices, {
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
device: DeviceEntity;
|
||||||
|
|
||||||
|
@ManyToOne(() => GroupEntity, (group) => group.groupDevices, {
|
||||||
|
nullable: false,
|
||||||
|
})
|
||||||
|
group: GroupEntity;
|
||||||
|
|
||||||
|
constructor(partial: Partial<GroupDeviceEntity>) {
|
||||||
|
super();
|
||||||
|
Object.assign(this, partial);
|
||||||
|
}
|
||||||
|
}
|
||||||
1
libs/common/src/modules/group-device/entities/index.ts
Normal file
1
libs/common/src/modules/group-device/entities/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './group.device.entity';
|
||||||
@ -0,0 +1,11 @@
|
|||||||
|
import { Module } from '@nestjs/common';
|
||||||
|
import { TypeOrmModule } from '@nestjs/typeorm';
|
||||||
|
import { GroupDeviceEntity } from './entities/group.device.entity';
|
||||||
|
|
||||||
|
@Module({
|
||||||
|
providers: [],
|
||||||
|
exports: [],
|
||||||
|
controllers: [],
|
||||||
|
imports: [TypeOrmModule.forFeature([GroupDeviceEntity])],
|
||||||
|
})
|
||||||
|
export class GroupDeviceRepositoryModule {}
|
||||||
@ -0,0 +1,10 @@
|
|||||||
|
import { DataSource, Repository } from 'typeorm';
|
||||||
|
import { Injectable } from '@nestjs/common';
|
||||||
|
import { GroupDeviceEntity } from '../entities/group.device.entity';
|
||||||
|
|
||||||
|
@Injectable()
|
||||||
|
export class GroupDeviceRepository extends Repository<GroupDeviceEntity> {
|
||||||
|
constructor(private dataSource: DataSource) {
|
||||||
|
super(GroupDeviceEntity, dataSource.createEntityManager());
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
export * from './group.device.repository';
|
||||||
@ -1,6 +1,7 @@
|
|||||||
import { Column, Entity } from 'typeorm';
|
import { Column, Entity, OneToMany } from 'typeorm';
|
||||||
import { GroupDto } from '../dtos';
|
import { GroupDto } from '../dtos';
|
||||||
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
import { AbstractEntity } from '../../abstract/entities/abstract.entity';
|
||||||
|
import { GroupDeviceEntity } from '../../group-device/entities';
|
||||||
|
|
||||||
@Entity({ name: 'group' })
|
@Entity({ name: 'group' })
|
||||||
export class GroupEntity extends AbstractEntity<GroupDto> {
|
export class GroupEntity extends AbstractEntity<GroupDto> {
|
||||||
@ -16,6 +17,9 @@ export class GroupEntity extends AbstractEntity<GroupDto> {
|
|||||||
})
|
})
|
||||||
public groupName: string;
|
public groupName: string;
|
||||||
|
|
||||||
|
@OneToMany(() => GroupDeviceEntity, (groupDevice) => groupDevice.group)
|
||||||
|
groupDevices: GroupDeviceEntity[];
|
||||||
|
|
||||||
constructor(partial: Partial<GroupEntity>) {
|
constructor(partial: Partial<GroupEntity>) {
|
||||||
super();
|
super();
|
||||||
Object.assign(this, partial);
|
Object.assign(this, partial);
|
||||||
|
|||||||
Reference in New Issue
Block a user