]>
Commit | Line | Data |
---|---|---|
2539932e C |
1 | import { AllowNull, BelongsTo, Column, CreatedAt, DataType, ForeignKey, Model, Table, UpdatedAt } from 'sequelize-typescript' |
2 | import { CustomPage } from '@shared/models' | |
3 | import { ActorModel } from '../actor/actor' | |
4 | import { getServerActor } from '../application/application' | |
5 | ||
6 | @Table({ | |
7 | tableName: 'actorCustomPage', | |
8 | indexes: [ | |
9 | { | |
10 | fields: [ 'actorId', 'type' ], | |
11 | unique: true | |
12 | } | |
13 | ] | |
14 | }) | |
15 | export class ActorCustomPageModel extends Model { | |
16 | ||
17 | @AllowNull(true) | |
18 | @Column(DataType.TEXT) | |
19 | content: string | |
20 | ||
21 | @AllowNull(false) | |
22 | @Column | |
23 | type: 'homepage' | |
24 | ||
25 | @CreatedAt | |
26 | createdAt: Date | |
27 | ||
28 | @UpdatedAt | |
29 | updatedAt: Date | |
30 | ||
31 | @ForeignKey(() => ActorModel) | |
32 | @Column | |
33 | actorId: number | |
34 | ||
35 | @BelongsTo(() => ActorModel, { | |
36 | foreignKey: { | |
37 | name: 'actorId', | |
38 | allowNull: false | |
39 | }, | |
40 | onDelete: 'cascade' | |
41 | }) | |
42 | Actor: ActorModel | |
43 | ||
44 | static async updateInstanceHomepage (content: string) { | |
45 | const serverActor = await getServerActor() | |
46 | ||
47 | return ActorCustomPageModel.upsert({ | |
48 | content, | |
49 | actorId: serverActor.id, | |
50 | type: 'homepage' | |
51 | }) | |
52 | } | |
53 | ||
54 | static async loadInstanceHomepage () { | |
55 | const serverActor = await getServerActor() | |
56 | ||
57 | return ActorCustomPageModel.findOne({ | |
58 | where: { | |
59 | actorId: serverActor.id | |
60 | } | |
61 | }) | |
62 | } | |
63 | ||
64 | toFormattedJSON (): CustomPage { | |
65 | return { | |
66 | content: this.content | |
67 | } | |
68 | } | |
69 | } |