]>
Commit | Line | Data |
---|---|---|
c48e82b5 | 1 | import { AllowNull, Column, CreatedAt, Default, HasMany, Is, Model, Table, UpdatedAt } from 'sequelize-typescript' |
3fd3ab2d | 2 | import { isHostValid } from '../../helpers/custom-validators/servers' |
f05a1c30 | 3 | import { ActorModel } from '../activitypub/actor' |
3fd3ab2d | 4 | import { throwIfNotValid } from '../utils' |
60862425 | 5 | |
3fd3ab2d C |
6 | @Table({ |
7 | tableName: 'server', | |
8 | indexes: [ | |
60862425 | 9 | { |
3fd3ab2d C |
10 | fields: [ 'host' ], |
11 | unique: true | |
60862425 | 12 | } |
60862425 | 13 | ] |
3fd3ab2d C |
14 | }) |
15 | export class ServerModel extends Model<ServerModel> { | |
16 | ||
17 | @AllowNull(false) | |
18 | @Is('Host', value => throwIfNotValid(value, isHostValid, 'valid host')) | |
19 | @Column | |
20 | host: string | |
21 | ||
c48e82b5 C |
22 | @AllowNull(false) |
23 | @Default(false) | |
24 | @Column | |
25 | redundancyAllowed: boolean | |
26 | ||
3fd3ab2d C |
27 | @CreatedAt |
28 | createdAt: Date | |
29 | ||
30 | @UpdatedAt | |
31 | updatedAt: Date | |
f05a1c30 C |
32 | |
33 | @HasMany(() => ActorModel, { | |
34 | foreignKey: { | |
35 | name: 'serverId', | |
36 | allowNull: true | |
37 | }, | |
38 | onDelete: 'CASCADE', | |
39 | hooks: true | |
40 | }) | |
41 | Actors: ActorModel[] | |
c48e82b5 C |
42 | |
43 | static loadByHost (host: string) { | |
44 | const query = { | |
45 | where: { | |
46 | host | |
47 | } | |
48 | } | |
49 | ||
50 | return ServerModel.findOne(query) | |
51 | } | |
39445ead | 52 | } |