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'
|
2020-04-23 02:32:53 -05:00
|
|
|
import * as memoizee from 'memoizee'
|
|
|
|
|
|
|
|
export const getServerActor = memoizee(async function () {
|
|
|
|
const application = await ApplicationModel.load()
|
|
|
|
if (!application) throw Error('Could not load Application from database.')
|
|
|
|
|
|
|
|
const actor = application.Account.Actor
|
|
|
|
actor.Account = application.Account
|
|
|
|
|
|
|
|
return actor
|
|
|
|
}, { promise: true })
|
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({
|
2019-04-26 02:16:43 -05:00
|
|
|
tableName: 'application',
|
|
|
|
timestamps: false
|
2017-12-12 10:53:50 -06:00
|
|
|
})
|
2020-12-08 07:30:29 -06:00
|
|
|
export class ApplicationModel extends Model {
|
2017-12-12 10:53:50 -06:00
|
|
|
|
|
|
|
@AllowNull(false)
|
|
|
|
@Default(0)
|
|
|
|
@IsInt
|
|
|
|
@Column
|
|
|
|
migrationVersion: number
|
|
|
|
|
2021-03-11 09:54:52 -06:00
|
|
|
@AllowNull(true)
|
|
|
|
@Column
|
|
|
|
latestPeerTubeVersion: string
|
|
|
|
|
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
|
|
|
}
|