mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-11-03 23:14:13 +00:00 
			
		
		
		
	Merge branch 'develop' of https://github.com/misskey-dev/misskey into develop
This commit is contained in:
		
						commit
						873a93fea3
					
				
					 4 changed files with 33 additions and 1 deletions
				
			
		| 
						 | 
				
			
			@ -4,7 +4,9 @@
 | 
			
		|||
	"service": "app",
 | 
			
		||||
	"workspaceFolder": "/workspace",
 | 
			
		||||
	"features": {
 | 
			
		||||
		"ghcr.io/devcontainers-contrib/features/pnpm:2": {},
 | 
			
		||||
		"ghcr.io/devcontainers-contrib/features/pnpm:2": {
 | 
			
		||||
			"version": "8.8.0"
 | 
			
		||||
		},
 | 
			
		||||
		"ghcr.io/devcontainers/features/node:1": {
 | 
			
		||||
			"version": "20.5.1"
 | 
			
		||||
		}
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -379,6 +379,20 @@ export class CustomEmojiService implements OnApplicationShutdown {
 | 
			
		|||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/**
 | 
			
		||||
	 * ローカル内の絵文字に重複がないかチェックします
 | 
			
		||||
	 * @param name 絵文字名
 | 
			
		||||
	 */
 | 
			
		||||
	@bindThis
 | 
			
		||||
	public checkDuplicate(name: string): Promise<boolean> {
 | 
			
		||||
		return this.emojisRepository.exist({ where: { name, host: IsNull() } });
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	@bindThis
 | 
			
		||||
	public getEmojiById(id: string): Promise<MiEmoji | null> {
 | 
			
		||||
		return this.emojisRepository.findOneBy({ id });
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	@bindThis
 | 
			
		||||
	public dispose(): void {
 | 
			
		||||
		this.cache.dispose();
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -23,6 +23,11 @@ export const meta = {
 | 
			
		|||
			code: 'NO_SUCH_FILE',
 | 
			
		||||
			id: 'fc46b5a4-6b92-4c33-ac66-b806659bb5cf',
 | 
			
		||||
		},
 | 
			
		||||
		duplicateName: {
 | 
			
		||||
			message: 'Duplicate name.',
 | 
			
		||||
			code: 'DUPLICATE_NAME',
 | 
			
		||||
			id: 'f7a3462c-4e6e-4069-8421-b9bd4f4c3975',
 | 
			
		||||
		},
 | 
			
		||||
	},
 | 
			
		||||
} as const;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -64,6 +69,8 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
 | 
			
		|||
		super(meta, paramDef, async (ps, me) => {
 | 
			
		||||
			const driveFile = await this.driveFilesRepository.findOneBy({ id: ps.fileId });
 | 
			
		||||
			if (driveFile == null) throw new ApiError(meta.errors.noSuchFile);
 | 
			
		||||
			const isDuplicate = await this.customEmojiService.checkDuplicate(ps.name);
 | 
			
		||||
			if (isDuplicate) throw new ApiError(meta.errors.duplicateName);
 | 
			
		||||
 | 
			
		||||
			const emoji = await this.customEmojiService.add({
 | 
			
		||||
				driveFile,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -74,6 +74,15 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-
 | 
			
		|||
				driveFile = await this.driveFilesRepository.findOneBy({ id: ps.fileId });
 | 
			
		||||
				if (driveFile == null) throw new ApiError(meta.errors.noSuchFile);
 | 
			
		||||
			}
 | 
			
		||||
			const emoji = await this.customEmojiService.getEmojiById(ps.id);
 | 
			
		||||
			if (emoji != null) {
 | 
			
		||||
				if (ps.name !== emoji.name) {
 | 
			
		||||
					const isDuplicate = await this.customEmojiService.checkDuplicate(ps.name);
 | 
			
		||||
					if (isDuplicate) throw new ApiError(meta.errors.sameNameEmojiExists);
 | 
			
		||||
				}
 | 
			
		||||
			} else {
 | 
			
		||||
				throw new ApiError(meta.errors.noSuchEmoji);
 | 
			
		||||
			}
 | 
			
		||||
 | 
			
		||||
			await this.customEmojiService.update(ps.id, {
 | 
			
		||||
				driveFile,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue