Role (#9437)
* wip * Update CHANGELOG.md * wip * wip * wip * Update create.ts * wip * wip * Update CHANGELOG.md * wip * wip * wip * wip * wip * wip * wip * Update CHANGELOG.md * wip * wip * Update delete.ts * Update delete.ts * wip * wip * wip * Update account-info.vue * wip * wip * Update settings.vue * Update user-info.vue * wip * Update show-file.ts * Update show-user.ts * wip * wip * Update delete.ts * wip * wip * Update overview.moderators.vue * Create 1673500412259-Role.js * wip * wip * Update roles.vue * 色 * Update roles.vue * integrate silence * wip * wip
This commit is contained in:
		| @@ -1,6 +1,6 @@ | ||||
| import { Module } from '@nestjs/common'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import { User, Note, Announcement, AnnouncementRead, App, NoteFavorite, NoteThreadMuting, NoteReaction, NoteUnread, Notification, Poll, PollVote, UserProfile, UserKeypair, UserPending, AttestationChallenge, UserSecurityKey, UserPublickey, UserList, UserListJoining, UserGroup, UserGroupJoining, UserGroupInvitation, UserNotePining, UserIp, UsedUsername, Following, FollowRequest, Instance, Emoji, DriveFile, DriveFolder, Meta, Muting, Blocking, SwSubscription, Hashtag, AbuseUserReport, RegistrationTicket, AuthSession, AccessToken, Signin, MessagingMessage, Page, PageLike, GalleryPost, GalleryLike, ModerationLog, Clip, ClipNote, Antenna, AntennaNote, PromoNote, PromoRead, Relay, MutedNote, Channel, ChannelFollowing, ChannelNotePining, RegistryItem, Webhook, Ad, PasswordResetRequest, RetentionAggregation, FlashLike, Flash } from './index.js'; | ||||
| import { User, Note, Announcement, AnnouncementRead, App, NoteFavorite, NoteThreadMuting, NoteReaction, NoteUnread, Notification, Poll, PollVote, UserProfile, UserKeypair, UserPending, AttestationChallenge, UserSecurityKey, UserPublickey, UserList, UserListJoining, UserGroup, UserGroupJoining, UserGroupInvitation, UserNotePining, UserIp, UsedUsername, Following, FollowRequest, Instance, Emoji, DriveFile, DriveFolder, Meta, Muting, Blocking, SwSubscription, Hashtag, AbuseUserReport, RegistrationTicket, AuthSession, AccessToken, Signin, MessagingMessage, Page, PageLike, GalleryPost, GalleryLike, ModerationLog, Clip, ClipNote, Antenna, AntennaNote, PromoNote, PromoRead, Relay, MutedNote, Channel, ChannelFollowing, ChannelNotePining, RegistryItem, Webhook, Ad, PasswordResetRequest, RetentionAggregation, FlashLike, Flash, Role, RoleAssignment } from './index.js'; | ||||
| import type { DataSource } from 'typeorm'; | ||||
| import type { Provider } from '@nestjs/common'; | ||||
|  | ||||
| @@ -400,6 +400,18 @@ const $flashLikesRepository: Provider = { | ||||
| 	inject: [DI.db], | ||||
| }; | ||||
|  | ||||
| const $rolesRepository: Provider = { | ||||
| 	provide: DI.rolesRepository, | ||||
| 	useFactory: (db: DataSource) => db.getRepository(Role), | ||||
| 	inject: [DI.db], | ||||
| }; | ||||
|  | ||||
| const $roleAssignmentsRepository: Provider = { | ||||
| 	provide: DI.roleAssignmentsRepository, | ||||
| 	useFactory: (db: DataSource) => db.getRepository(RoleAssignment), | ||||
| 	inject: [DI.db], | ||||
| }; | ||||
|  | ||||
| @Module({ | ||||
| 	imports: [ | ||||
| 	], | ||||
| @@ -468,6 +480,8 @@ const $flashLikesRepository: Provider = { | ||||
| 		$adsRepository, | ||||
| 		$passwordResetRequestsRepository, | ||||
| 		$retentionAggregationsRepository, | ||||
| 		$rolesRepository, | ||||
| 		$roleAssignmentsRepository, | ||||
| 		$flashsRepository, | ||||
| 		$flashLikesRepository, | ||||
| 	], | ||||
| @@ -536,6 +550,8 @@ const $flashLikesRepository: Provider = { | ||||
| 		$adsRepository, | ||||
| 		$passwordResetRequestsRepository, | ||||
| 		$retentionAggregationsRepository, | ||||
| 		$rolesRepository, | ||||
| 		$roleAssignmentsRepository, | ||||
| 		$flashsRepository, | ||||
| 		$flashLikesRepository, | ||||
| 	], | ||||
|   | ||||
| @@ -42,16 +42,6 @@ export class Meta { | ||||
| 	}) | ||||
| 	public disableRegistration: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public disableLocalTimeline: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public disableGlobalTimeline: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| @@ -227,12 +217,6 @@ export class Meta { | ||||
| 	}) | ||||
| 	public enableSensitiveMediaDetectionForVideos: boolean; | ||||
|  | ||||
| 	@Column('integer', { | ||||
| 		default: 1024, | ||||
| 		comment: 'Drive capacity of a local user (MB)', | ||||
| 	}) | ||||
| 	public localDriveCapacityMb: number; | ||||
|  | ||||
| 	@Column('integer', { | ||||
| 		default: 32, | ||||
| 		comment: 'Drive capacity of a remote user (MB)', | ||||
| @@ -476,4 +460,9 @@ export class Meta { | ||||
| 		default: true, | ||||
| 	}) | ||||
| 	public enableActiveEmailValidation: boolean; | ||||
|  | ||||
| 	@Column('jsonb', { | ||||
| 		default: { }, | ||||
| 	}) | ||||
| 	public defaultRoleOverride: Record<string, any>; | ||||
| } | ||||
|   | ||||
							
								
								
									
										66
									
								
								packages/backend/src/models/entities/Role.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										66
									
								
								packages/backend/src/models/entities/Role.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,66 @@ | ||||
| import { Entity, Index, JoinColumn, Column, PrimaryColumn, ManyToOne } from 'typeorm'; | ||||
| import { id } from '../id.js'; | ||||
|  | ||||
| @Entity() | ||||
| export class Role { | ||||
| 	@PrimaryColumn(id()) | ||||
| 	public id: string; | ||||
|  | ||||
| 	@Column('timestamp with time zone', { | ||||
| 		comment: 'The created date of the Role.', | ||||
| 	}) | ||||
| 	public createdAt: Date; | ||||
|  | ||||
| 	@Column('timestamp with time zone', { | ||||
| 		comment: 'The updated date of the Role.', | ||||
| 	}) | ||||
| 	public updatedAt: Date; | ||||
|  | ||||
| 	@Column('timestamp with time zone', { | ||||
| 		comment: 'The last used date of the Role.', | ||||
| 	}) | ||||
| 	public lastUsedAt: Date; | ||||
|  | ||||
| 	@Column('varchar', { | ||||
| 		length: 256, | ||||
| 	}) | ||||
| 	public name: string; | ||||
|  | ||||
| 	@Column('varchar', { | ||||
| 		length: 1024, | ||||
| 	}) | ||||
| 	public description: string; | ||||
|  | ||||
| 	@Column('varchar', { | ||||
| 		length: 256, nullable: true, | ||||
| 	}) | ||||
| 	public color: string | null; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public isPublic: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public isModerator: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public isAdministrator: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 	}) | ||||
| 	public canEditMembersByModerator: boolean; | ||||
|  | ||||
| 	@Column('jsonb', { | ||||
| 		default: { }, | ||||
| 	}) | ||||
| 	public options: Record<string, { | ||||
| 		useDefault: boolean; | ||||
| 		value: any; | ||||
| 	}>; | ||||
| } | ||||
							
								
								
									
										42
									
								
								packages/backend/src/models/entities/RoleAssignment.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								packages/backend/src/models/entities/RoleAssignment.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,42 @@ | ||||
| import { PrimaryColumn, Entity, Index, JoinColumn, Column, ManyToOne } from 'typeorm'; | ||||
| import { id } from '../id.js'; | ||||
| import { Role } from './Role.js'; | ||||
| import { User } from './User.js'; | ||||
|  | ||||
| @Entity() | ||||
| @Index(['userId', 'roleId'], { unique: true }) | ||||
| export class RoleAssignment { | ||||
| 	@PrimaryColumn(id()) | ||||
| 	public id: string; | ||||
|  | ||||
| 	@Column('timestamp with time zone', { | ||||
| 		comment: 'The created date of the RoleAssignment.', | ||||
| 	}) | ||||
| 	public createdAt: Date; | ||||
|  | ||||
| 	@Index() | ||||
| 	@Column({ | ||||
| 		...id(), | ||||
| 		comment: 'The user ID.', | ||||
| 	}) | ||||
| 	public userId: User['id']; | ||||
|  | ||||
| 	@ManyToOne(type => User, { | ||||
| 		onDelete: 'CASCADE', | ||||
| 	}) | ||||
| 	@JoinColumn() | ||||
| 	public user: User | null; | ||||
|  | ||||
| 	@Index() | ||||
| 	@Column({ | ||||
| 		...id(), | ||||
| 		comment: 'The role ID.', | ||||
| 	}) | ||||
| 	public roleId: Role['id']; | ||||
|  | ||||
| 	@ManyToOne(type => Role, { | ||||
| 		onDelete: 'CASCADE', | ||||
| 	}) | ||||
| 	@JoinColumn() | ||||
| 	public role: Role | null; | ||||
| } | ||||
| @@ -112,12 +112,6 @@ export class User { | ||||
| 	}) | ||||
| 	public isSuspended: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 		comment: 'Whether the User is silenced.', | ||||
| 	}) | ||||
| 	public isSilenced: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 		comment: 'Whether the User is locked.', | ||||
| @@ -138,15 +132,9 @@ export class User { | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 		comment: 'Whether the User is the admin.', | ||||
| 		comment: 'Whether the User is the root.', | ||||
| 	}) | ||||
| 	public isAdmin: boolean; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 		comment: 'Whether the User is a moderator.', | ||||
| 	}) | ||||
| 	public isModerator: boolean; | ||||
| 	public isRoot: boolean; | ||||
|  | ||||
| 	@Index() | ||||
| 	@Column('boolean', { | ||||
| @@ -218,12 +206,6 @@ export class User { | ||||
| 	}) | ||||
| 	public token: string | null; | ||||
|  | ||||
| 	@Column('integer', { | ||||
| 		nullable: true, | ||||
| 		comment: 'Overrides user drive capacity limit', | ||||
| 	}) | ||||
| 	public driveCapacityOverrideMb: number | null; | ||||
|  | ||||
| 	constructor(data: Partial<User>) { | ||||
| 		if (data == null) return; | ||||
|  | ||||
|   | ||||
| @@ -62,6 +62,8 @@ import { UserSecurityKey } from '@/models/entities/UserSecurityKey.js'; | ||||
| import { Webhook } from '@/models/entities/Webhook.js'; | ||||
| import { Channel } from '@/models/entities/Channel.js'; | ||||
| import { RetentionAggregation } from '@/models/entities/RetentionAggregation.js'; | ||||
| import { Role } from '@/models/entities/Role.js'; | ||||
| import { RoleAssignment } from '@/models/entities/RoleAssignment.js'; | ||||
| import { Flash } from '@/models/entities/Flash.js'; | ||||
| import { FlashLike } from '@/models/entities/FlashLike.js'; | ||||
| import type { Repository } from 'typeorm'; | ||||
| @@ -131,6 +133,8 @@ export { | ||||
| 	Webhook, | ||||
| 	Channel, | ||||
| 	RetentionAggregation, | ||||
| 	Role, | ||||
| 	RoleAssignment, | ||||
| 	Flash, | ||||
| 	FlashLike, | ||||
| }; | ||||
| @@ -199,5 +203,7 @@ export type UserSecurityKeysRepository = Repository<UserSecurityKey>; | ||||
| export type WebhooksRepository = Repository<Webhook>; | ||||
| export type ChannelsRepository = Repository<Channel>; | ||||
| export type RetentionAggregationsRepository = Repository<RetentionAggregation>; | ||||
| export type RolesRepository = Repository<Role>; | ||||
| export type RoleAssignmentsRepository = Repository<RoleAssignment>; | ||||
| export type FlashsRepository = Repository<Flash>; | ||||
| export type FlashLikesRepository = Repository<FlashLike>; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo