import { Transaction } from 'sequelize' import { AllowNull, Column, CreatedAt, Default, HasMany, Is, Table, UpdatedAt } from 'sequelize-typescript' import { MServer, MServerFormattable } from '@server/types/models/server/index.js' import { isHostValid } from '../../helpers/custom-validators/servers.js' import { ActorModel } from '../actor/actor.js' import { SequelizeModel, buildSQLAttributes, throwIfNotValid } from '../shared/index.js' import { ServerBlocklistModel } from './server-blocklist.js' @Table({ tableName: 'server', indexes: [ { fields: [ 'host' ], unique: true } ] }) export class ServerModel extends SequelizeModel { @AllowNull(false) @Is('Host', value => throwIfNotValid(value, isHostValid, 'valid host')) @Column host: string @AllowNull(false) @Default(false) @Column redundancyAllowed: boolean @CreatedAt createdAt: Date @UpdatedAt updatedAt: Date @HasMany(() => ActorModel, { foreignKey: { name: 'serverId', allowNull: true }, onDelete: 'CASCADE', hooks: true }) Actors: Awaited[] @HasMany(() => ServerBlocklistModel, { foreignKey: { allowNull: false }, onDelete: 'CASCADE' }) BlockedBy: Awaited[] // --------------------------------------------------------------------------- static getSQLAttributes (tableName: string, aliasPrefix = '') { return buildSQLAttributes({ model: this, tableName, aliasPrefix }) } // --------------------------------------------------------------------------- static load (id: number, transaction?: Transaction): Promise { const query = { where: { id }, transaction } return ServerModel.findOne(query) } static loadByHost (host: string): Promise { const query = { where: { host } } return ServerModel.findOne(query) } static async loadOrCreateByHost (host: string) { let server = await ServerModel.loadByHost(host) if (!server) server = await ServerModel.create({ host }) return server } isBlocked () { return this.BlockedBy && this.BlockedBy.length !== 0 } toFormattedJSON (this: MServerFormattable) { return { host: this.host } } }