2020-02-05 02:15:09 +01:00
|
|
|
import { Entity, Column, PrimaryColumn, ManyToOne, JoinColumn } from 'typeorm';
|
2022-02-27 03:07:39 +01:00
|
|
|
import { id } from '../id.js';
|
2022-09-17 20:27:08 +02:00
|
|
|
import { User } from './User.js';
|
|
|
|
import type { Clip } from './Clip.js';
|
2019-04-07 14:50:36 +02:00
|
|
|
|
|
|
|
@Entity()
|
|
|
|
export class Meta {
|
2019-04-16 17:33:02 +02:00
|
|
|
@PrimaryColumn({
|
|
|
|
type: 'varchar',
|
2021-12-09 15:58:30 +01:00
|
|
|
length: 32,
|
2019-04-16 17:33:02 +02:00
|
|
|
})
|
2019-04-07 14:50:36 +02:00
|
|
|
public id: string;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public name: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2021-12-09 15:58:30 +01:00
|
|
|
length: 1024, nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public description: string | null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* メンテナの名前
|
|
|
|
*/
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public maintainerName: string | null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* メンテナの連絡先
|
|
|
|
*/
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public maintainerEmail: string | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public disableRegistration: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, array: true, default: '{}',
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public langs: string[];
|
|
|
|
|
2019-05-10 10:30:28 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, array: true, default: '{}',
|
2019-05-10 10:30:28 +02:00
|
|
|
})
|
|
|
|
public pinnedUsers: string[];
|
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, array: true, default: '{}',
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public hiddenTags: string[];
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024, array: true, default: '{}',
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public blockedHosts: string[];
|
|
|
|
|
2023-03-13 09:37:22 +01:00
|
|
|
@Column('varchar', {
|
|
|
|
length: 1024, array: true, default: '{}',
|
|
|
|
})
|
|
|
|
public sensitiveWords: string[];
|
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2022-02-09 13:25:48 +01:00
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public themeColor: string | null;
|
|
|
|
|
2020-11-17 06:59:15 +01:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2019-04-07 14:50:36 +02:00
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public mascotImageUrl: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public bannerUrl: string | null;
|
|
|
|
|
2020-11-25 13:31:34 +01:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2020-11-25 13:31:34 +01:00
|
|
|
})
|
|
|
|
public backgroundImageUrl: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2020-11-25 13:31:34 +01:00
|
|
|
})
|
|
|
|
public logoImageUrl: string | null;
|
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2019-04-07 14:50:36 +02:00
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public errorImageUrl: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public iconUrl: string | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public cacheRemoteFiles: boolean;
|
|
|
|
|
2020-02-05 02:15:09 +01:00
|
|
|
@Column({
|
|
|
|
...id(),
|
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public proxyAccountId: User['id'] | null;
|
|
|
|
|
|
|
|
@ManyToOne(type => User, {
|
2021-12-09 15:58:30 +01:00
|
|
|
onDelete: 'SET NULL',
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
2020-02-05 02:15:09 +01:00
|
|
|
@JoinColumn()
|
|
|
|
public proxyAccount: User | null;
|
2019-04-07 14:50:36 +02:00
|
|
|
|
2021-10-08 06:37:02 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public emailRequiredForSignup: boolean;
|
|
|
|
|
2020-04-28 07:29:33 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableHcaptcha: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2020-04-28 07:29:33 +02:00
|
|
|
})
|
|
|
|
public hcaptchaSiteKey: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2020-04-28 07:29:33 +02:00
|
|
|
})
|
|
|
|
public hcaptchaSecretKey: string | null;
|
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableRecaptcha: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public recaptchaSiteKey: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public recaptchaSecretKey: string | null;
|
|
|
|
|
2022-10-13 02:19:57 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableTurnstile: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2022-10-13 02:19:57 +02:00
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public turnstileSiteKey: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2022-10-13 02:19:57 +02:00
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public turnstileSecretKey: string | null;
|
|
|
|
|
2022-07-07 14:06:37 +02:00
|
|
|
@Column('enum', {
|
|
|
|
enum: ['none', 'all', 'local', 'remote'],
|
|
|
|
default: 'none',
|
|
|
|
})
|
|
|
|
public sensitiveMediaDetection: 'none' | 'all' | 'local' | 'remote';
|
|
|
|
|
|
|
|
@Column('enum', {
|
|
|
|
enum: ['medium', 'low', 'high', 'veryLow', 'veryHigh'],
|
|
|
|
default: 'medium',
|
|
|
|
})
|
|
|
|
public sensitiveMediaDetectionSensitivity: 'medium' | 'low' | 'high' | 'veryLow' | 'veryHigh';
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public setSensitiveFlagAutomatically: boolean;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableSensitiveMediaDetectionForVideos: boolean;
|
|
|
|
|
2019-04-07 14:50:36 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public summalyProxy: string | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableEmail: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public email: string | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public smtpSecure: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public smtpHost: string | null;
|
|
|
|
|
|
|
|
@Column('integer', {
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public smtpPort: number | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public smtpUser: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public smtpPass: string | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableServiceWorker: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public swPublicKey: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-04-07 14:50:36 +02:00
|
|
|
})
|
|
|
|
public swPrivateKey: string | null;
|
|
|
|
|
2021-08-15 13:26:44 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2021-08-15 13:26:44 +02:00
|
|
|
})
|
|
|
|
public deeplAuthKey: string | null;
|
|
|
|
|
2021-08-24 06:19:21 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public deeplIsPro: boolean;
|
|
|
|
|
2019-05-13 19:57:04 +02:00
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-13 19:57:04 +02:00
|
|
|
})
|
2023-03-10 06:53:56 +01:00
|
|
|
public termsOfServiceUrl: string | null;
|
2019-05-13 19:57:04 +02:00
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-03-24 04:23:05 +01:00
|
|
|
default: 'https://github.com/misskey-dev/misskey',
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: false,
|
2019-05-13 19:57:04 +02:00
|
|
|
})
|
|
|
|
public repositoryUrl: string;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-03-24 04:23:05 +01:00
|
|
|
default: 'https://github.com/misskey-dev/misskey/issues/new',
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-13 19:57:04 +02:00
|
|
|
})
|
|
|
|
public feedbackUrl: string | null;
|
2019-05-15 18:07:32 +02:00
|
|
|
|
2022-03-01 15:58:01 +01:00
|
|
|
@Column('varchar', {
|
|
|
|
length: 8192,
|
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public defaultLightTheme: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
|
|
|
length: 8192,
|
|
|
|
nullable: true,
|
|
|
|
})
|
|
|
|
public defaultDarkTheme: string | null;
|
|
|
|
|
2019-05-15 18:07:32 +02:00
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public useObjectStorage: boolean;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageBucket: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStoragePrefix: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageBaseUrl: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageEndpoint: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageRegion: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageAccessKey: string | null;
|
|
|
|
|
|
|
|
@Column('varchar', {
|
2023-03-10 06:53:56 +01:00
|
|
|
length: 1024,
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStorageSecretKey: string | null;
|
|
|
|
|
|
|
|
@Column('integer', {
|
2021-12-09 15:58:30 +01:00
|
|
|
nullable: true,
|
2019-05-15 18:07:32 +02:00
|
|
|
})
|
|
|
|
public objectStoragePort: number | null;
|
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public objectStorageUseSSL: boolean;
|
2020-04-12 13:32:34 +02:00
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public objectStorageUseProxy: boolean;
|
2020-08-13 13:05:01 +02:00
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public objectStorageSetPublicRead: boolean;
|
2021-02-06 03:48:57 +01:00
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public objectStorageS3ForcePathStyle: boolean;
|
2022-07-02 08:12:11 +02:00
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: false,
|
|
|
|
})
|
|
|
|
public enableIpLogging: boolean;
|
2022-07-09 08:05:55 +02:00
|
|
|
|
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public enableActiveEmailValidation: boolean;
|
2023-01-12 13:02:26 +01:00
|
|
|
|
2023-03-24 07:43:36 +01:00
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public enableChartsForRemoteUser: boolean;
|
|
|
|
|
2023-03-24 11:08:08 +01:00
|
|
|
@Column('boolean', {
|
|
|
|
default: true,
|
|
|
|
})
|
|
|
|
public enableChartsForFederatedInstances: boolean;
|
|
|
|
|
2023-01-12 13:02:26 +01:00
|
|
|
@Column('jsonb', {
|
|
|
|
default: { },
|
|
|
|
})
|
2023-01-15 12:52:53 +01:00
|
|
|
public policies: Record<string, any>;
|
2023-04-19 14:24:31 +02:00
|
|
|
|
|
|
|
@Column('varchar', {
|
|
|
|
length: 280,
|
|
|
|
array: true,
|
|
|
|
default: '{}',
|
|
|
|
})
|
|
|
|
public serverRules: string[];
|
2019-04-07 14:50:36 +02:00
|
|
|
}
|