X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmodels%2Fserver%2Fserver.ts;h=8b07115f1f810a43c0403f7ef7b75b3702ff64a0;hb=a30a136c9896c656cab98d2c92cde32c534dc098;hp=300d7093808c568b76e3520ef8304fafa7fc7522;hpb=88108880bbdba473cfe36ecbebc1c3c4f972e102;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/models/server/server.ts b/server/models/server/server.ts index 300d70938..8b07115f1 100644 --- a/server/models/server/server.ts +++ b/server/models/server/server.ts @@ -2,6 +2,9 @@ import { AllowNull, Column, CreatedAt, Default, HasMany, Is, Model, Table, Updat import { isHostValid } from '../../helpers/custom-validators/servers' import { ActorModel } from '../activitypub/actor' import { throwIfNotValid } from '../utils' +import { ServerBlocklistModel } from './server-blocklist' +import * as Bluebird from 'bluebird' +import { MServer, MServerFormattable } from '@server/typings/models/server' @Table({ tableName: 'server', @@ -40,7 +43,25 @@ export class ServerModel extends Model { }) Actors: ActorModel[] - static loadByHost (host: string) { + @HasMany(() => ServerBlocklistModel, { + foreignKey: { + allowNull: false + }, + onDelete: 'CASCADE' + }) + BlockedByAccounts: ServerBlocklistModel[] + + static load (id: number): Bluebird { + const query = { + where: { + id + } + } + + return ServerModel.findOne(query) + } + + static loadByHost (host: string): Bluebird { const query = { where: { host @@ -50,7 +71,11 @@ export class ServerModel extends Model { return ServerModel.findOne(query) } - toFormattedJSON () { + isBlocked () { + return this.BlockedByAccounts && this.BlockedByAccounts.length !== 0 + } + + toFormattedJSON (this: MServerFormattable) { return { host: this.host }