botserver/packages/kb.gbapp/models/index.ts

239 lines
6.3 KiB
TypeScript
Raw Normal View History

2018-04-21 02:59:30 -03:00
/*****************************************************************************\
| ( )_ _ |
| _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _ |
| ( '_`\ ( '__)/'_` ) /'_ `\/' _ ` _ `\ /'_` )| | | |/',__)/' v `\ /'_`\ |
| | (_) )| | ( (_| |( (_) || ( ) ( ) |( (_| || |_ | |\__, \| (˅) |( (_) ) |
2018-04-21 02:59:30 -03:00
| | ,__/'(_) `\__,_)`\__ |(_) (_) (_)`\__,_)`\__)(_)(____/(_) (_)`\___/' |
| | | ( )_) | |
| (_) \___/' |
| |
| General Bots Copyright (c) Pragmatismo.io. All rights reserved. |
| Licensed under the AGPL-3.0. |
2018-11-11 19:09:18 -02:00
| |
2018-04-21 02:59:30 -03:00
| 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, |
2018-09-11 19:40:53 -03:00
| but WITHOUT ANY WARRANTY, without even the implied warranty of |
2018-04-21 02:59:30 -03:00
| 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. |
| |
\*****************************************************************************/
2018-11-11 19:09:18 -02:00
/**
* @fileoverview General Bots server core.
*/
2018-04-21 02:59:30 -03:00
2018-11-11 19:09:18 -02:00
'use strict';
2018-04-21 02:59:30 -03:00
import {
2018-11-11 19:09:18 -02:00
AutoIncrement,
2018-04-21 02:59:30 -03:00
BelongsTo,
2018-11-11 19:09:18 -02:00
Column,
2018-04-21 02:59:30 -03:00
CreatedAt,
DataType,
2018-11-11 19:09:18 -02:00
ForeignKey,
HasMany,
HasOne,
2018-04-21 02:59:30 -03:00
IsUUID,
2018-11-11 19:09:18 -02:00
Length,
Model,
2018-04-21 02:59:30 -03:00
PrimaryKey,
2018-11-11 19:09:18 -02:00
Sequelize,
Table,
UpdatedAt
} from 'sequelize-typescript';
2018-04-21 02:59:30 -03:00
2022-11-19 23:34:58 -03:00
import { GuaribasInstance, GuaribasPackage } from '../../core.gbapp/models/GBModel.js';
import { GuaribasUser } from '../../security.gbapp/models/index.js';
2018-04-21 02:59:30 -03:00
/**
* Subjects to group the pair of questions and answers.
*/
2018-04-21 02:59:30 -03:00
@Table
export class GuaribasSubject extends Model<GuaribasSubject> {
@PrimaryKey
@AutoIncrement
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
subjectId: number;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
internalId: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.STRING(255))
2022-11-19 23:34:58 -03:00
title: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(512))
2022-11-19 23:34:58 -03:00
description: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.STRING(255))
2022-11-19 23:34:58 -03:00
from: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.STRING(255))
2022-11-19 23:34:58 -03:00
to: string;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasSubject)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
parentSubjectId: number;
2018-04-21 02:59:30 -03:00
2018-11-11 19:09:18 -02:00
@BelongsTo(() => GuaribasSubject, 'parentSubjectId')
2022-11-19 23:34:58 -03:00
parentSubject: GuaribasSubject;
2018-04-21 02:59:30 -03:00
2018-11-11 19:09:18 -02:00
@HasMany(() => GuaribasSubject, { foreignKey: 'parentSubjectId' })
2022-11-19 23:34:58 -03:00
childrenSubjects: GuaribasSubject[];
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
instanceId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasInstance)
2022-11-19 23:34:58 -03:00
instance: GuaribasInstance;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasUser)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
responsibleUserId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasUser)
2022-11-19 23:34:58 -03:00
responsibleUser: GuaribasUser;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
packageId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2022-11-19 23:34:58 -03:00
package: GuaribasPackage;
2018-04-21 02:59:30 -03:00
}
/**
* A question and its metadata.
*/
2018-04-21 02:59:30 -03:00
@Table
export class GuaribasQuestion extends Model<GuaribasQuestion> {
@PrimaryKey
@AutoIncrement
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
questionId: number;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2022-11-19 23:34:58 -03:00
subject1: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2022-11-19 23:34:58 -03:00
subject2: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2022-11-19 23:34:58 -03:00
subject3: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2022-11-19 23:34:58 -03:00
subject4: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(1024))
2022-11-19 23:34:58 -03:00
keywords: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.BOOLEAN)
2022-11-19 23:34:58 -03:00
skipIndex: boolean;
@Column(DataType.STRING(512))
2022-11-19 23:34:58 -03:00
from: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(512))
2022-11-19 23:34:58 -03:00
to: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.TEXT)
2022-11-19 23:34:58 -03:00
content: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.DATE)
2018-04-21 02:59:30 -03:00
@CreatedAt
2022-11-19 23:34:58 -03:00
createdAt: Date;
2018-04-21 02:59:30 -03:00
2022-01-03 13:11:21 -03:00
@Column(DataType.DATE)
2018-04-21 02:59:30 -03:00
@UpdatedAt
2022-11-19 23:34:58 -03:00
updatedAt: Date;
2022-01-03 13:11:21 -03:00
//tslint:disable-next-line:no-use-before-declare
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasAnswer)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
answerId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasInstance)
2022-11-19 23:34:58 -03:00
instance: GuaribasInstance;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
instanceId: number;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
packageId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2022-11-19 23:34:58 -03:00
package: GuaribasPackage;
2018-04-21 02:59:30 -03:00
}
/**
* An answer and its metadata.
*/
2018-04-21 02:59:30 -03:00
@Table
export class GuaribasAnswer extends Model<GuaribasAnswer> {
@PrimaryKey
@AutoIncrement
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
answerId: number;
2018-04-21 02:59:30 -03:00
@Length({ min: 0, max: 512 })
2022-01-03 13:42:12 -03:00
@Column(DataType.STRING(512))
2022-11-19 23:34:58 -03:00
media: string;
2018-04-21 02:59:30 -03:00
@Length({ min: 0, max: 12 })
2022-01-03 13:42:12 -03:00
@Column(DataType.STRING(12))
2022-11-19 23:34:58 -03:00
format: string;
2018-04-21 02:59:30 -03:00
@Column(DataType.TEXT)
2022-11-19 23:34:58 -03:00
content: string;
2018-04-21 02:59:30 -03:00
2022-01-03 13:42:12 -03:00
@Column(DataType.DATE)
2018-04-21 02:59:30 -03:00
@CreatedAt
2022-11-19 23:34:58 -03:00
createdAt: Date;
2018-04-21 02:59:30 -03:00
2022-01-03 13:11:21 -03:00
@Column(DataType.DATE)
2018-04-21 02:59:30 -03:00
@UpdatedAt
2022-11-19 23:34:58 -03:00
updatedAt: Date;
2022-01-03 13:11:21 -03:00
2018-04-21 02:59:30 -03:00
@HasMany(() => GuaribasQuestion)
2022-11-19 23:34:58 -03:00
questions: GuaribasQuestion[];
2018-04-21 02:59:30 -03:00
@HasOne(() => GuaribasQuestion)
2022-11-19 23:34:58 -03:00
prev: GuaribasQuestion;
@HasOne(() => GuaribasQuestion)
2022-11-19 23:34:58 -03:00
next: GuaribasQuestion;
@ForeignKey(() => GuaribasQuestion)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
nextId: number;
@ForeignKey(() => GuaribasQuestion)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
prevId: number;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
instanceId: number;
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
2022-01-03 13:42:12 -03:00
@Column(DataType.INTEGER)
2022-11-19 23:34:58 -03:00
packageId: number;
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2022-11-19 23:34:58 -03:00
package: GuaribasPackage;
2018-04-21 02:59:30 -03:00
}