2023-01-12 06:02:26 -06:00
|
|
|
import { Entity, Index, JoinColumn, Column, PrimaryColumn, ManyToOne } from 'typeorm';
|
|
|
|
import { id } from '../id.js';
|
|
|
|
|
2023-01-12 20:03:54 -06:00
|
|
|
type CondFormulaValueAnd = {
|
|
|
|
type: 'and';
|
|
|
|
values: RoleCondFormulaValue[];
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueOr = {
|
|
|
|
type: 'or';
|
|
|
|
values: RoleCondFormulaValue[];
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueNot = {
|
|
|
|
type: 'not';
|
|
|
|
value: RoleCondFormulaValue;
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueIsLocal = {
|
|
|
|
type: 'isLocal';
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueIsRemote = {
|
|
|
|
type: 'isRemote';
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueCreatedLessThan = {
|
|
|
|
type: 'createdLessThan';
|
|
|
|
sec: number;
|
|
|
|
};
|
|
|
|
|
|
|
|
type CondFormulaValueCreatedMoreThan = {
|
|
|
|
type: 'createdMoreThan';
|
|
|
|
sec: number;
|
|
|
|
};
|
|
|
|
|
|
|
|
export type RoleCondFormulaValue =
|
|
|
|
CondFormulaValueAnd |
|
|
|
|
CondFormulaValueOr |
|
|
|
|
CondFormulaValueNot |
|
|
|
|
CondFormulaValueIsLocal |
|
|
|
|
CondFormulaValueIsRemote |
|
|
|
|
CondFormulaValueCreatedLessThan |
|
|
|
|
CondFormulaValueCreatedMoreThan;
|
|
|
|
|
2023-01-12 06:02:26 -06:00
|
|
|
@Entity()
|
|
|
|
export class Role {
|
|
|
|
@PrimaryColumn(id())
|
|
|
|
public id: string;
|
|
|
|
|
|
|
|
@Column('timestamp with time zone', {
|
|
|
|
comment: 'The created date of the Role.',
|
|
|
|
})
|
|
|
|
public createdAt: Date;
|
|
|
|
|
|
|
|
@Column('timestamp with time zone', {
|
|
|
|
comment: 'The updated date of the Role.',
|
|
|
|
})
|
|
|
|
public updatedAt: Date;
|
|
|
|
|
|
|
|
@Column('timestamp with time zone', {
|
|
|
|
comment: 'The last used date of the Role.',
|
|
|
|
})
|
|
|
|
public lastUsedAt: Date;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
|
|
|
length: 256,
|
|
|
|
})
|
|
|
|
public name: string;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
|
|
|
length: 1024,
|
|
|
|
})
|
|
|
|
public description: string;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
|
|
|
length: 256, nullable: true,
|
|
|
|
})
|
|
|
|
public color: string | null;
|
|
|
|
|
2023-01-12 20:03:54 -06:00
|
|
|
@Column('enum', {
|
|
|
|
enum: ['manual', 'conditional'],
|
|
|
|
default: 'manual',
|
|
|
|
})
|
|
|
|
public target: 'manual' | 'conditional';
|
|
|
|
|
|
|
|
@Column('jsonb', {
|
|
|
|
default: { },
|
|
|
|
})
|
|
|
|
public condFormula: RoleCondFormulaValue;
|
|
|
|
|
2023-01-12 06:02:26 -06:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public isPublic: boolean;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public isModerator: boolean;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public isAdministrator: boolean;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public canEditMembersByModerator: boolean;
|
|
|
|
|
|
|
|
@Column('jsonb', {
|
|
|
|
default: { },
|
|
|
|
})
|
|
|
|
public options: Record<string, {
|
|
|
|
useDefault: boolean;
|
|
|
|
value: any;
|
|
|
|
}>;
|
|
|
|
}
|