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

216 lines
5.4 KiB
TypeScript
Raw Normal View History

2018-04-21 02:59:30 -03:00
/*****************************************************************************\
| ( )_ _ |
| _ _ _ __ _ _ __ ___ ___ _ _ | ,_)(_) ___ ___ _ |
| ( '_`\ ( '__)/'_` ) /'_ `\/' _ ` _ `\ /'_` )| | | |/',__)/' _ `\ /'_`\ |
| | (_) )| | ( (_| |( (_) || ( ) ( ) |( (_| || |_ | |\__, \| ( ) |( (_) ) |
| | ,__/'(_) `\__,_)`\__ |(_) (_) (_)`\__,_)`\__)(_)(____/(_) (_)`\___/' |
| | | ( )_) | |
| (_) \___/' |
| |
| 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, |
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-09-11 19:40:53 -03:00
"use strict"
2018-04-21 02:59:30 -03:00
import {
DataTypes,
DataTypeUUIDv4,
DataTypeDate,
DataTypeDecimal
2018-09-11 19:40:53 -03:00
} from "sequelize"
2018-04-21 02:59:30 -03:00
import {
Sequelize,
2018-04-21 02:59:30 -03:00
Table,
Column,
Model,
HasMany,
BelongsTo,
BelongsToMany,
Length,
ForeignKey,
CreatedAt,
UpdatedAt,
DataType,
IsUUID,
PrimaryKey,
AutoIncrement
2018-09-11 19:40:53 -03:00
} from "sequelize-typescript"
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
import { GuaribasUser } from "../../security.gblib/models"
import { GuaribasInstance, GuaribasPackage } from "../../core.gbapp/models/GBModel"
2018-04-21 02:59:30 -03:00
@Table
export class GuaribasSubject extends Model<GuaribasSubject> {
@PrimaryKey
@AutoIncrement
@Column
2018-09-11 19:40:53 -03:00
subjectId: number
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
@Column internalId: string
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
@Column title: string
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
@Column description: string
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
@Column from: string
2018-04-21 02:59:30 -03:00
2018-09-11 19:40:53 -03:00
@Column to: string
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasSubject)
@Column
2018-09-11 19:40:53 -03:00
parentSubjectId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasSubject, "parentSubjectId")
2018-09-11 19:40:53 -03:00
parentSubject: GuaribasSubject
2018-04-21 02:59:30 -03:00
@HasMany(() => GuaribasSubject, { foreignKey: "parentSubjectId" })
2018-09-11 19:40:53 -03:00
childrenSubjects: GuaribasSubject[]
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
@Column
2018-09-11 19:40:53 -03:00
instanceId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasInstance)
2018-09-11 19:40:53 -03:00
instance: GuaribasInstance
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasUser)
@Column
2018-09-11 19:40:53 -03:00
responsibleUserId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasUser)
2018-09-11 19:40:53 -03:00
responsibleUser: GuaribasUser
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
@Column
2018-09-11 19:40:53 -03:00
packageId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2018-09-11 19:40:53 -03:00
package: GuaribasPackage
2018-04-21 02:59:30 -03:00
}
@Table
export class GuaribasQuestion extends Model<GuaribasQuestion> {
@PrimaryKey
@AutoIncrement
@Column
2018-09-11 19:40:53 -03:00
questionId: number
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2018-04-21 02:59:30 -03:00
@Column
2018-09-11 19:40:53 -03:00
subject1: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2018-04-21 02:59:30 -03:00
@Column
2018-09-11 19:40:53 -03:00
subject2: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2018-04-21 02:59:30 -03:00
@Column
2018-09-11 19:40:53 -03:00
subject3: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(64))
2018-04-21 02:59:30 -03:00
@Column
2018-09-11 19:40:53 -03:00
subject4: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(1024))
2018-04-21 02:59:30 -03:00
@Column
2018-09-11 19:40:53 -03:00
keywords: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(512))
2018-09-11 19:40:53 -03:00
from: string
2018-04-21 02:59:30 -03:00
@Column(DataType.STRING(512))
2018-09-11 19:40:53 -03:00
to: string
2018-04-21 02:59:30 -03:00
@Column(DataType.TEXT)
2018-09-11 19:40:53 -03:00
content: string
2018-04-21 02:59:30 -03:00
@Column
@CreatedAt
2018-09-11 19:40:53 -03:00
createdAt: Date
2018-04-21 02:59:30 -03:00
@Column
@UpdatedAt
2018-09-11 19:40:53 -03:00
updatedAt: Date
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasAnswer)
@Column
2018-09-11 19:40:53 -03:00
answerId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasInstance)
2018-09-11 19:40:53 -03:00
instance: GuaribasInstance
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
@Column
2018-09-11 19:40:53 -03:00
instanceId: number
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
@Column
2018-09-11 19:40:53 -03:00
packageId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2018-09-11 19:40:53 -03:00
package: GuaribasPackage
2018-04-21 02:59:30 -03:00
}
@Table
export class GuaribasAnswer extends Model<GuaribasAnswer> {
@PrimaryKey
@AutoIncrement
@Column
2018-09-11 19:40:53 -03:00
answerId: number
2018-04-21 02:59:30 -03:00
@Length({ min: 0, max: 512 })
@Column
2018-09-11 19:40:53 -03:00
media: string
2018-04-21 02:59:30 -03:00
@Length({ min: 0, max: 12 })
@Column
2018-09-11 19:40:53 -03:00
format: string
2018-04-21 02:59:30 -03:00
@Column(DataType.TEXT)
2018-09-11 19:40:53 -03:00
content: string
2018-04-21 02:59:30 -03:00
@Column
@CreatedAt
2018-09-11 19:40:53 -03:00
createdAt: Date
2018-04-21 02:59:30 -03:00
@Column
@UpdatedAt
2018-09-11 19:40:53 -03:00
updatedAt: Date
2018-04-21 02:59:30 -03:00
@HasMany(() => GuaribasQuestion)
2018-09-11 19:40:53 -03:00
questions: GuaribasQuestion[]
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasInstance)
@Column
2018-09-11 19:40:53 -03:00
instanceId: number
2018-04-21 02:59:30 -03:00
@ForeignKey(() => GuaribasPackage)
@Column
2018-09-11 19:40:53 -03:00
packageId: number
2018-04-21 02:59:30 -03:00
@BelongsTo(() => GuaribasPackage)
2018-09-11 19:40:53 -03:00
package: GuaribasPackage
2018-04-21 02:59:30 -03:00
}