mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-15 01:31:14 +09:00
refactor public keys add
This commit is contained in:
parent
83f635835e
commit
25cc9e0bf1
@ -50,7 +50,7 @@ import type { ApResolverService, Resolver } from '../ApResolverService.js';
|
|||||||
import type { ApLoggerService } from '../ApLoggerService.js';
|
import type { ApLoggerService } from '../ApLoggerService.js';
|
||||||
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
||||||
import type { ApImageService } from './ApImageService.js';
|
import type { ApImageService } from './ApImageService.js';
|
||||||
import type { IActor, IObject } from '../type.js';
|
import type { IActor, IKey, IObject } from '../type.js';
|
||||||
|
|
||||||
const nameLength = 128;
|
const nameLength = 128;
|
||||||
const summaryLength = 2048;
|
const summaryLength = 2048;
|
||||||
@ -396,14 +396,12 @@ export class ApPersonService implements OnModuleInit {
|
|||||||
}));
|
}));
|
||||||
|
|
||||||
if (person.publicKey) {
|
if (person.publicKey) {
|
||||||
await transactionalEntityManager.save(new MiUserPublickey({
|
const keys = new Map<string, IKey>([
|
||||||
keyId: person.publicKey.id,
|
...(person.additionalPublicKeys ? person.additionalPublicKeys.map(key => [key.id, key] as const) : []),
|
||||||
userId: user.id,
|
[person.publicKey.id, person.publicKey],
|
||||||
keyPem: person.publicKey.publicKeyPem,
|
]);
|
||||||
}));
|
|
||||||
|
|
||||||
if (person.additionalPublicKeys) {
|
for (const key of keys.values()) {
|
||||||
for (const key of person.additionalPublicKeys) {
|
|
||||||
await transactionalEntityManager.save(new MiUserPublickey({
|
await transactionalEntityManager.save(new MiUserPublickey({
|
||||||
keyId: key.id,
|
keyId: key.id,
|
||||||
userId: user.id,
|
userId: user.id,
|
||||||
@ -411,7 +409,6 @@ export class ApPersonService implements OnModuleInit {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
});
|
});
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
// duplicate key error
|
// duplicate key error
|
||||||
@ -556,27 +553,21 @@ export class ApPersonService implements OnModuleInit {
|
|||||||
// Update user
|
// Update user
|
||||||
await this.usersRepository.update(exist.id, updates);
|
await this.usersRepository.update(exist.id, updates);
|
||||||
|
|
||||||
const availablePublicKeys = new Set<string>();
|
const publicKeys = new Map<string, IKey>();
|
||||||
if (person.publicKey) {
|
if (person.publicKey) {
|
||||||
await this.userPublickeysRepository.update({ keyId: person.publicKey.id }, {
|
(person.additionalPublicKeys ?? []).forEach(key => publicKeys.set(key.id, key));
|
||||||
userId: exist.id,
|
publicKeys.set(person.publicKey.id, person.publicKey);
|
||||||
keyPem: person.publicKey.publicKeyPem,
|
|
||||||
});
|
|
||||||
availablePublicKeys.add(person.publicKey.id);
|
|
||||||
|
|
||||||
if (person.additionalPublicKeys) {
|
for (const key of publicKeys.values()) {
|
||||||
for (const key of person.additionalPublicKeys) {
|
|
||||||
await this.userPublickeysRepository.update({ keyId: key.id }, {
|
await this.userPublickeysRepository.update({ keyId: key.id }, {
|
||||||
userId: exist.id,
|
userId: exist.id,
|
||||||
keyPem: key.publicKeyPem,
|
keyPem: key.publicKeyPem,
|
||||||
});
|
});
|
||||||
availablePublicKeys.add(key.id);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.userPublickeysRepository.delete({
|
this.userPublickeysRepository.delete({
|
||||||
keyId: Not(In(Array.from(availablePublicKeys))),
|
keyId: Not(In(Array.from(publicKeys.keys()))),
|
||||||
userId: exist.id,
|
userId: exist.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user