/*****************************************************************************\ | ( )_ _ | | _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _ | | ( '_`\ ( '__)/'_` ) /'_ `\/' _ ` _ `\ /'_` )| | | |/',__)/' _ `\ /'_`\ | | | (_) )| | ( (_| |( (_) || ( ) ( ) |( (_| || |_ | |\__, \| ( ) |( (_) ) | | | ,__/'(_) `\__,_)`\__ |(_) (_) (_)`\__,_)`\__)(_)(____/(_) (_)`\___/' | | | | ( )_) | | | (_) \___/' | | | | General Bots Copyright (c) Pragmatismo.io. All rights reserved. | | Licensed under the AGPL-3.0. | | | | According to our dual licensing model, this program can be used either | | under the terms of the GNU Affero General Public License, version 3, | | or under a proprietary license. | | | | The texts of the GNU Affero General Public License with an additional | | permission and of our proprietary license can be found at and | | in the LICENSE file you have received along with this program. | | | | This program is distributed in the hope that it will be useful, | | but WITHOUT ANY WARRANTY, without even the implied warranty of | | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | | GNU Affero General Public License for more details. | | | | "General Bots" is a registered trademark of Pragmatismo.io. | | The licensing of the program under the AGPLv3 does not imply a | | trademark license. Therefore any rights, title and interest in | | our trademarks remain entirely with us. | | | \*****************************************************************************/ "use strict" import { DataTypes, DataTypeUUIDv4, DataTypeDate, DataTypeDecimal } from "sequelize" import { Sequelize, Table, Column, Model, HasMany, BelongsTo, BelongsToMany, Length, ForeignKey, CreatedAt, UpdatedAt, DataType, IsUUID, PrimaryKey, AutoIncrement } from "sequelize-typescript" import { GuaribasUser } from "../../security.gblib/models" import { GuaribasInstance, GuaribasPackage } from "../../core.gbapp/models/GBModel" @Table export class GuaribasSubject extends Model { @PrimaryKey @AutoIncrement @Column subjectId: number @Column internalId: string @Column title: string @Column description: string @Column from: string @Column to: string @ForeignKey(() => GuaribasSubject) @Column parentSubjectId: number @BelongsTo(() => GuaribasSubject, "parentSubjectId") parentSubject: GuaribasSubject @HasMany(() => GuaribasSubject, { foreignKey: "parentSubjectId" }) childrenSubjects: GuaribasSubject[] @ForeignKey(() => GuaribasInstance) @Column instanceId: number @BelongsTo(() => GuaribasInstance) instance: GuaribasInstance @ForeignKey(() => GuaribasUser) @Column responsibleUserId: number @BelongsTo(() => GuaribasUser) responsibleUser: GuaribasUser @ForeignKey(() => GuaribasPackage) @Column packageId: number @BelongsTo(() => GuaribasPackage) package: GuaribasPackage } @Table export class GuaribasQuestion extends Model { @PrimaryKey @AutoIncrement @Column questionId: number @Column(DataType.STRING(64)) @Column subject1: string @Column(DataType.STRING(64)) @Column subject2: string @Column(DataType.STRING(64)) @Column subject3: string @Column(DataType.STRING(64)) @Column subject4: string @Column(DataType.STRING(1024)) @Column keywords: string @Column(DataType.STRING(512)) from: string @Column(DataType.STRING(512)) to: string @Column(DataType.TEXT) content: string @Column @CreatedAt createdAt: Date @Column @UpdatedAt updatedAt: Date @ForeignKey(() => GuaribasAnswer) @Column answerId: number @BelongsTo(() => GuaribasInstance) instance: GuaribasInstance @ForeignKey(() => GuaribasInstance) @Column instanceId: number @ForeignKey(() => GuaribasPackage) @Column packageId: number @BelongsTo(() => GuaribasPackage) package: GuaribasPackage } @Table export class GuaribasAnswer extends Model { @PrimaryKey @AutoIncrement @Column answerId: number @Length({ min: 0, max: 512 }) @Column media: string @Length({ min: 0, max: 12 }) @Column format: string @Column(DataType.TEXT) content: string @Column @CreatedAt createdAt: Date @Column @UpdatedAt updatedAt: Date @HasMany(() => GuaribasQuestion) questions: GuaribasQuestion[] @ForeignKey(() => GuaribasInstance) @Column instanceId: number @ForeignKey(() => GuaribasPackage) @Column packageId: number @BelongsTo(() => GuaribasPackage) package: GuaribasPackage }