PeerTube/server/models/application/application.ts

56 lines
1.2 KiB
TypeScript
Raw Normal View History

2021-08-27 07:32:44 -05:00
import memoizee from 'memoizee'
2017-12-14 10:38:41 -06:00
import { AllowNull, Column, Default, DefaultScope, HasOne, IsInt, Model, Table } from 'sequelize-typescript'
import { AttributesOnly } from '@shared/typescript-utils'
2017-12-14 10:38:41 -06:00
import { AccountModel } from '../account/account'
2020-04-23 02:32:53 -05:00
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
})
2021-05-12 07:09:04 -05:00
export class ApplicationModel extends Model<Partial<AttributesOnly<ApplicationModel>>> {
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()
}
}