2017-12-14 10:38:41 -06:00
|
|
|
import { AllowNull, Column, Default, DefaultScope, HasOne, IsInt, Model, Table } from 'sequelize-typescript'
|
|
|
|
import { AccountModel } from '../account/account'
|
2017-12-12 10:53:50 -06:00
|
|
|
|
2019-04-23 02:50:57 -05:00
|
|
|
@DefaultScope(() => ({
|
2017-12-14 10:38:41 -06:00
|
|
|
include: [
|
|
|
|
{
|
2019-04-23 02:50:57 -05:00
|
|
|
model: AccountModel,
|
2017-12-14 10:38:41 -06:00
|
|
|
required: true
|
|
|
|
}
|
|
|
|
]
|
2019-04-23 02:50:57 -05:00
|
|
|
}))
|
2017-12-12 10:53:50 -06:00
|
|
|
@Table({
|
|
|
|
tableName: 'application'
|
|
|
|
})
|
|
|
|
export class ApplicationModel extends Model<ApplicationModel> {
|
|
|
|
|
|
|
|
@AllowNull(false)
|
|
|
|
@Default(0)
|
|
|
|
@IsInt
|
|
|
|
@Column
|
|
|
|
migrationVersion: number
|
|
|
|
|
2017-12-14 10:38:41 -06:00
|
|
|
@HasOne(() => AccountModel, {
|
|
|
|
foreignKey: {
|
|
|
|
allowNull: true
|
|
|
|
},
|
|
|
|
onDelete: 'cascade'
|
|
|
|
})
|
|
|
|
Account: AccountModel
|
|
|
|
|
2017-12-12 10:53:50 -06:00
|
|
|
static countTotal () {
|
|
|
|
return ApplicationModel.count()
|
|
|
|
}
|
2017-12-14 10:38:41 -06:00
|
|
|
|
|
|
|
static load () {
|
|
|
|
return ApplicationModel.findOne()
|
|
|
|
}
|
2016-09-26 15:36:36 -05:00
|
|
|
}
|