mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-25 10:44:51 +00:00 
			
		
		
		
	* wip * paramの正規表現で弾くように * apiWithDialogを使用するように * Update CHANGELOG.md --------- Co-authored-by: kakkokari-gtyih <67428053+kakkokari-gtyih@users.noreply.github.com>
		
			
				
	
	
		
			122 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
	
		
			2.3 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| /*
 | |
|  * SPDX-FileCopyrightText: syuilo and misskey-project
 | |
|  * SPDX-License-Identifier: AGPL-3.0-only
 | |
|  */
 | |
| 
 | |
| import { Entity, Index, JoinColumn, Column, PrimaryColumn, ManyToOne } from 'typeorm';
 | |
| import { id } from './util/id.js';
 | |
| import { MiUser } from './User.js';
 | |
| import { MiDriveFile } from './DriveFile.js';
 | |
| 
 | |
| @Entity('page')
 | |
| @Index(['userId', 'name'], { unique: true })
 | |
| export class MiPage {
 | |
| 	@PrimaryColumn(id())
 | |
| 	public id: string;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column('timestamp with time zone', {
 | |
| 		comment: 'The updated date of the Page.',
 | |
| 	})
 | |
| 	public updatedAt: Date;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 256,
 | |
| 	})
 | |
| 	public title: string;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column('varchar', {
 | |
| 		length: 256,
 | |
| 	})
 | |
| 	public name: string;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 256, nullable: true,
 | |
| 	})
 | |
| 	public summary: string | null;
 | |
| 
 | |
| 	@Column('boolean')
 | |
| 	public alignCenter: boolean;
 | |
| 
 | |
| 	@Column('boolean', {
 | |
| 		default: false,
 | |
| 	})
 | |
| 	public hideTitleWhenPinned: boolean;
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 32,
 | |
| 	})
 | |
| 	public font: string;
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 		comment: 'The ID of author.',
 | |
| 	})
 | |
| 	public userId: MiUser['id'];
 | |
| 
 | |
| 	@ManyToOne(type => MiUser, {
 | |
| 		onDelete: 'CASCADE',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public user: MiUser | null;
 | |
| 
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 		nullable: true,
 | |
| 	})
 | |
| 	public eyeCatchingImageId: MiDriveFile['id'] | null;
 | |
| 
 | |
| 	@ManyToOne(type => MiDriveFile, {
 | |
| 		onDelete: 'CASCADE',
 | |
| 	})
 | |
| 	@JoinColumn()
 | |
| 	public eyeCatchingImage: MiDriveFile | null;
 | |
| 
 | |
| 	@Column('jsonb', {
 | |
| 		default: [],
 | |
| 	})
 | |
| 	public content: Record<string, any>[];
 | |
| 
 | |
| 	@Column('jsonb', {
 | |
| 		default: [],
 | |
| 	})
 | |
| 	public variables: Record<string, any>[];
 | |
| 
 | |
| 	@Column('varchar', {
 | |
| 		length: 16384,
 | |
| 		default: '',
 | |
| 	})
 | |
| 	public script: string;
 | |
| 
 | |
| 	/**
 | |
| 	 * public ... 公開
 | |
| 	 * followers ... フォロワーのみ
 | |
| 	 * specified ... visibleUserIds で指定したユーザーのみ
 | |
| 	 */
 | |
| 	@Column('enum', { enum: ['public', 'followers', 'specified'] })
 | |
| 	public visibility: 'public' | 'followers' | 'specified';
 | |
| 
 | |
| 	@Index()
 | |
| 	@Column({
 | |
| 		...id(),
 | |
| 		array: true, default: '{}',
 | |
| 	})
 | |
| 	public visibleUserIds: MiUser['id'][];
 | |
| 
 | |
| 	@Column('integer', {
 | |
| 		default: 0,
 | |
| 	})
 | |
| 	public likedCount: number;
 | |
| 
 | |
| 	constructor(data: Partial<MiPage>) {
 | |
| 		if (data == null) return;
 | |
| 
 | |
| 		for (const [k, v] of Object.entries(data)) {
 | |
| 			(this as any)[k] = v;
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| 
 | |
| export const pageNameSchema = { type: 'string', pattern: /^[^\s:\/?#\[\]@!$&'()*+,;=\\%\x00-\x20]{1,256}$/.source } as const;
 |