mirror of
				https://codeberg.org/yeentown/barkey.git
				synced 2025-10-26 19:14:12 +00:00 
			
		
		
		
	Fix: Duplicate system users are created (#7141)
This commit is contained in:
		
							parent
							
								
									9dd1a8fb2e
								
							
						
					
					
						commit
						3be7eafa6b
					
				
					 1 changed files with 15 additions and 8 deletions
				
			
		|  | @ -25,7 +25,14 @@ export async function createSystemUser(username: string) { | |||
| 
 | ||||
| 	// Start transaction
 | ||||
| 	await getConnection().transaction(async transactionalEntityManager => { | ||||
| 		account = await transactionalEntityManager.save(new User({ | ||||
| 		const exist = await transactionalEntityManager.findOne(User, { | ||||
| 			usernameLower: username.toLowerCase(), | ||||
| 			host: null | ||||
| 		}); | ||||
| 
 | ||||
| 		if (exist) throw new Error('the user is already exists'); | ||||
| 
 | ||||
| 		account = await transactionalEntityManager.insert(User, { | ||||
| 			id: genId(), | ||||
| 			createdAt: new Date(), | ||||
| 			username: username, | ||||
|  | @ -36,24 +43,24 @@ export async function createSystemUser(username: string) { | |||
| 			isLocked: true, | ||||
| 			isExplorable: false, | ||||
| 			isBot: true, | ||||
| 		})); | ||||
| 		}).then(x => transactionalEntityManager.findOneOrFail(User, x.identifiers[0])); | ||||
| 
 | ||||
| 		await transactionalEntityManager.save(new UserKeypair({ | ||||
| 		await transactionalEntityManager.insert(UserKeypair, { | ||||
| 			publicKey: keyPair.publicKey, | ||||
| 			privateKey: keyPair.privateKey, | ||||
| 			userId: account.id | ||||
| 		})); | ||||
| 		}); | ||||
| 
 | ||||
| 		await transactionalEntityManager.save(new UserProfile({ | ||||
| 		await transactionalEntityManager.insert(UserProfile, { | ||||
| 			userId: account.id, | ||||
| 			autoAcceptFollowed: false, | ||||
| 			password: hash, | ||||
| 		})); | ||||
| 		}); | ||||
| 
 | ||||
| 		await transactionalEntityManager.save(new UsedUsername({ | ||||
| 		await transactionalEntityManager.insert(UsedUsername, { | ||||
| 			createdAt: new Date(), | ||||
| 			username: username.toLowerCase(), | ||||
| 		})); | ||||
| 		}); | ||||
| 	}); | ||||
| 
 | ||||
| 	return account; | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue