From 12473c85a073ef1a25f4f70881f77f3c08f41252 Mon Sep 17 00:00:00 2001 From: esau <152162806+sklppy88@users.noreply.github.com> Date: Thu, 12 Dec 2024 07:53:26 -0500 Subject: [PATCH] chore: fix public keys deserialization (#10647) This fixes public keys deserialization by allowing it to be a prepended hex string. --- .../circuits.js/src/types/public_keys.test.ts | 13 +++++++++++++ yarn-project/circuits.js/src/types/public_keys.ts | 4 ++-- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/yarn-project/circuits.js/src/types/public_keys.test.ts b/yarn-project/circuits.js/src/types/public_keys.test.ts index 10dac1f65f7..b4a21a9e2c0 100644 --- a/yarn-project/circuits.js/src/types/public_keys.test.ts +++ b/yarn-project/circuits.js/src/types/public_keys.test.ts @@ -4,6 +4,19 @@ import { updateInlineTestData } from '@aztec/foundation/testing'; import { PublicKeys } from './public_keys.js'; describe('PublicKeys', () => { + it('serialization and deserialization', () => { + const pk = PublicKeys.random(); + const serialized = pk.toString(); + const deserialized = PublicKeys.fromString(serialized); + + expect(pk).toEqual(deserialized); + + const serializedWithoutPrefix = serialized.slice(2); + const deserializedWithoutPrefix = PublicKeys.fromString(serializedWithoutPrefix); + + expect(pk).toEqual(deserializedWithoutPrefix); + }); + it('computes public keys hash', () => { const keys = new PublicKeys( new Point(new Fr(1n), new Fr(2n), false), diff --git a/yarn-project/circuits.js/src/types/public_keys.ts b/yarn-project/circuits.js/src/types/public_keys.ts index d426ab2f3b8..2faa0f7a488 100644 --- a/yarn-project/circuits.js/src/types/public_keys.ts +++ b/yarn-project/circuits.js/src/types/public_keys.ts @@ -2,7 +2,7 @@ import { poseidon2HashWithSeparator } from '@aztec/foundation/crypto'; import { Fr, Point } from '@aztec/foundation/fields'; import { schemas } from '@aztec/foundation/schemas'; import { BufferReader, FieldReader, serializeToBuffer } from '@aztec/foundation/serialize'; -import { bufferToHex } from '@aztec/foundation/string'; +import { bufferToHex, withoutHexPrefix } from '@aztec/foundation/string'; import { type FieldsOf } from '@aztec/foundation/types'; import { z } from 'zod'; @@ -189,6 +189,6 @@ export class PublicKeys { } static fromString(keys: string) { - return PublicKeys.fromBuffer(Buffer.from(keys, 'hex')); + return PublicKeys.fromBuffer(Buffer.from(withoutHexPrefix(keys), 'hex')); } }