Added the required entities for query_permissions and query_users tables

This commit is contained in:
devanshu052000 2025-05-21 11:44:06 +05:30
parent 2d1bc33fe0
commit fbb30fcff9
5 changed files with 76 additions and 0 deletions

View file

@ -10,11 +10,13 @@ import {
JoinTable,
ManyToMany,
AfterLoad,
OneToMany,
} from 'typeorm';
import { App } from './app.entity';
import { AppVersion } from './app_version.entity';
import { DataSource } from './data_source.entity';
import { Plugin } from './plugin.entity';
import { QueryPermission } from './query_permissions.entity';
@Entity({ name: 'data_queries' })
export class DataQuery extends BaseEntity {
@ -81,6 +83,9 @@ export class DataQuery extends BaseEntity {
app: App;
@OneToMany(() => QueryPermission, (permission) => permission.query)
permissions: QueryPermission[];
@AfterLoad()
updatePlugin() {
if (this.plugins?.length) this.plugin = this.plugins[0];

View file

@ -14,6 +14,7 @@ import { GroupUsers } from './group_users.entity';
import { GranularPermissions } from './granular_permissions.entity';
import { GROUP_PERMISSIONS_TYPE } from '@modules/group-permissions/constants';
import { PageUser } from './page_users.entity';
import { QueryUser } from './query_users.entity';
@Entity({ name: 'permission_groups' })
export class GroupPermissions extends BaseEntity {
@ -66,5 +67,8 @@ export class GroupPermissions extends BaseEntity {
@OneToMany(() => PageUser, (pageUser) => pageUser.permissionGroup)
pageUsers: PageUser[];
@OneToMany(() => QueryUser, (queryUser) => queryUser.permissionGroup)
queryUsers: QueryUser[];
disabled?: boolean;
}

View file

@ -0,0 +1,29 @@
import { Entity, PrimaryGeneratedColumn, Column, ManyToOne, JoinColumn, CreateDateColumn, OneToMany } from 'typeorm';
import { DataQuery } from './data_query.entity';
import { QueryUser } from './query_users.entity';
import { PAGE_PERMISSION_TYPE } from '@modules/app-permissions/constants';
@Entity('query_permissions')
export class QueryPermission {
@PrimaryGeneratedColumn('uuid')
id: string;
@Column({ name: 'query_id', type: 'uuid', nullable: false })
queryId: string;
@Column({
type: 'enum',
enum: PAGE_PERMISSION_TYPE,
})
type: PAGE_PERMISSION_TYPE;
@CreateDateColumn({ name: 'created_at' })
createdAt: Date;
@ManyToOne(() => DataQuery, (query) => query.permissions, { onDelete: 'CASCADE' })
@JoinColumn({ name: 'query_id' })
query: DataQuery;
@OneToMany(() => QueryUser, (queryUser) => queryUser.queryPermission)
users: QueryUser[];
}

View file

@ -0,0 +1,34 @@
import { Entity, PrimaryGeneratedColumn, Column, ManyToOne, JoinColumn, CreateDateColumn } from 'typeorm';
import { User } from './user.entity';
import { QueryPermission } from './query_permissions.entity';
import { GroupPermissions } from './group_permissions.entity';
@Entity('query_users')
export class QueryUser {
@PrimaryGeneratedColumn('uuid')
id: string;
@Column({ name: 'query_permissions_id', type: 'uuid' })
queryPermissionsId: string;
@Column({ name: 'user_id', type: 'uuid', nullable: true })
userId: string | null;
@Column({ name: 'permission_groups_id', type: 'uuid', nullable: true })
permissionGroupsId: string | null;
@CreateDateColumn({ name: 'created_at' })
createdAt: Date;
@ManyToOne(() => QueryPermission, { onDelete: 'CASCADE' })
@JoinColumn({ name: 'query_permissions_id' })
queryPermission: QueryPermission;
@ManyToOne(() => User, { onDelete: 'CASCADE', nullable: true })
@JoinColumn({ name: 'user_id' })
user: User;
@ManyToOne(() => GroupPermissions, { onDelete: 'CASCADE', nullable: true })
@JoinColumn({ name: 'permission_groups_id' })
permissionGroup: GroupPermissions;
}

View file

@ -30,6 +30,7 @@ import { AiConversation } from './ai_conversation.entity';
import { AiResponseVote } from './ai_response_vote.entity';
import { USER_ROLE } from '@modules/group-permissions/constants';
import { PageUser } from './page_users.entity';
import { QueryUser } from './query_users.entity';
@Entity({ name: 'users' })
export class User extends BaseEntity {
@ -188,6 +189,9 @@ export class User extends BaseEntity {
@OneToMany(() => PageUser, (pageUser) => pageUser.user)
pageUsers: PageUser[];
@OneToMany(() => QueryUser, (queryUser) => queryUser.user)
queryUsers: QueryUser[];
organizationId: string;
invitedOrganizationId: string;
organizationIds?: Array<string>;