Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix SnarkyJS to be compatible with new Berkeley #1021

Merged
merged 58 commits into from
Jul 12, 2023
Merged
Show file tree
Hide file tree
Changes from 43 commits
Commits
Show all changes
58 commits
Select commit Hold shift + click to select a range
ac73fcb
fixup global slot binable / json
mitschabaude May 5, 2023
a51a84d
bindings
mitschabaude May 5, 2023
e6106e2
bindings
mitschabaude May 5, 2023
36627c5
bindings
mitschabaude May 5, 2023
147c36f
Merge pull request #893 from o1-labs/fix/use-fake-logger
mitschabaude May 7, 2023
9e06f9c
bindings
mitschabaude May 8, 2023
bc46083
Merge branch 'berkeley' into fix/global-slot-serialization
mitschabaude May 8, 2023
835c6fc
Remove duplicate user command fields
nholland94 May 1, 2023
1b5446f
Update bindings
nholland94 May 10, 2023
885e2fa
bindings
mitschabaude May 10, 2023
91eb907
bindings
mitschabaude May 10, 2023
310a89f
bindings
mitschabaude May 10, 2023
618b35a
delete uninteresting unit test which fails CI
mitschabaude May 11, 2023
80ed0c0
bindings
mitschabaude May 11, 2023
265c311
Merge pull request #884 from o1-labs/remove-duplicate-user-command-fi…
mitschabaude May 30, 2023
0a5a7a8
Merge branch 'berkeley' into fix/global-slot-serialization
mitschabaude Jun 1, 2023
4a2277b
bindings
mitschabaude Jun 1, 2023
c309fb1
bindings
mitschabaude Jun 1, 2023
6b14e2b
Merge pull request #892 from o1-labs/fix/global-slot-serialization
mitschabaude Jun 1, 2023
82485cd
Merge branch 'fix/wasm-build' into fix/wasm-build-berkeley
mitschabaude Jun 2, 2023
abe02dd
bindings
mitschabaude Jun 2, 2023
af0202f
Merge pull request #952 from o1-labs/fix/wasm-build-berkeley
mitschabaude Jun 5, 2023
0e60fa1
Merge branch 'berkeley' into make-ci-not-broken-too-2
mrmr1993 Jun 7, 2023
6914469
Merge pull request #978 from o1-labs/make-ci-not-broken-too-2
mrmr1993 Jun 7, 2023
63bd416
Merge branch 'main' into merge-main-berkeley
mitschabaude Jun 15, 2023
1b66620
bindings
mitschabaude Jun 15, 2023
0e51cfe
Merge pull request #991 from o1-labs/merge-main-berkeley-2
mitschabaude Jun 16, 2023
108cd2a
type import changes for no ts build
mitschabaude Jun 16, 2023
2e6df12
run examples without requiring ts build
mitschabaude Jun 16, 2023
f50d7e8
port inductive proofs example
mitschabaude Jun 16, 2023
fd3e197
add script to run minimal snarkyjs tests
mitschabaude Jun 20, 2023
d638b67
minor
mitschabaude Jun 20, 2023
ff69674
use smaller example in test
mitschabaude Jun 20, 2023
47a6034
add a script to copy files
mitschabaude Jun 20, 2023
4b99e4d
simplify
mitschabaude Jun 20, 2023
9179211
delete pointless file
mitschabaude Jun 22, 2023
0f95b8e
clean up some build logic
mitschabaude Jun 22, 2023
195697c
Merge pull request #996 from o1-labs/feature/revive-snarkyjs-ci-berkeley
mitschabaude Jun 23, 2023
676212b
Merge branch 'berkeley' into main
MartinMinkov Jul 10, 2023
50b05ea
feat(bindings): update bindings
MartinMinkov Jul 10, 2023
9b4805d
feat(vk_hash): update hardcoded vk hash to use new mina dummy
MartinMinkov Jul 10, 2023
1fc38c0
chore(vk_regression): update vk regression dumps
MartinMinkov Jul 10, 2023
c37c459
feat(tsconfig.mina-signer.json): fix building by enabling decorators
MartinMinkov Jul 10, 2023
a20d1f9
Revert "feat(tsconfig.mina-signer.json): fix building by enabling dec…
MartinMinkov Jul 10, 2023
b3b4cb1
feat(account_update): correctly create empty verification key hash
MartinMinkov Jul 11, 2023
6e624eb
refactor(sign-zkapp-command.ts, accountUpdate.ts): replace Pickles.du…
MartinMinkov Jul 11, 2023
5e1e10a
feat(sign-zkapp-command.unit-test.ts): use mocks for dummyVerificatio…
MartinMinkov Jul 11, 2023
4bc172d
fix(tsconfig.mina-signer.json): fix mina-signer building due to inclu…
MartinMinkov Jul 11, 2023
cf070a3
chore(bindings): update subproject commit hash to 988f7b8445a5d159730…
MartinMinkov Jul 11, 2023
eaea0d5
chore(package.json): bump version from 0.11.4 to 0.12.0 for the new r…
MartinMinkov Jul 11, 2023
8cec003
docs(CHANGELOG.md): update unreleased changes and add version 0.12.0 …
MartinMinkov Jul 11, 2023
e0af732
fix(zkapp.unit-test.ts): replace vk with with mocked version
MartinMinkov Jul 11, 2023
e157304
Revert "fix(tsconfig.mina-signer.json): fix mina-signer building due …
MartinMinkov Jul 11, 2023
38c12fb
fix(sign-zkapp-command.unit-test.ts): correct the import path for moc…
MartinMinkov Jul 11, 2023
89beca3
refactor(random.ts): replace Pickles.dummyVerificationKey() with mock…
MartinMinkov Jul 11, 2023
4a5cffa
feat(tsconfig.mina-signer.json): enable experimentalDecorators, emitD…
MartinMinkov Jul 11, 2023
bd477a7
refactor(tsconfig.mina-signer.json): remove unnecessary decorator-rel…
MartinMinkov Jul 11, 2023
97869a6
chore(bindings): update subproject commit hash to 2c4c71339073ffe1f03…
MartinMinkov Jul 11, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/bindings
68 changes: 34 additions & 34 deletions src/examples/regression_test.json

Large diffs are not rendered by default.

22 changes: 18 additions & 4 deletions src/lib/account_update.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ import { MlArray } from './ml/base.js';
import { Signature, signFieldElement } from '../mina-signer/src/signature.js';
import { MlFieldConstArray } from './ml/fields.js';
import { transactionCommitments } from '../mina-signer/src/sign-zkapp-command.js';
import { Field as Fp } from './field.js';

// external API
export { AccountUpdate, Permissions, ZkappPublicInput };
Expand Down Expand Up @@ -445,7 +446,7 @@ const Body = {
tokenId?: Field,
mayUseToken?: MayUseToken
): Body {
let { body } = Types.AccountUpdate.emptyValue();
let { body } = AccountUpdate.emptyValue();
body.publicKey = publicKey;
if (tokenId) {
body.tokenId = tokenId;
Expand All @@ -463,7 +464,7 @@ const Body = {
},

dummy(): Body {
return Types.AccountUpdate.emptyValue().body;
return AccountUpdate.emptyValue().body;
},
};

Expand Down Expand Up @@ -1288,6 +1289,12 @@ class AccountUpdate implements Types.AccountUpdate {
other
);
}
static emptyValue() {
let empty = Types.AccountUpdate.emptyValue();
empty.body.authorizationKind.verificationKeyHash =
dummyVerificationKeyHash();
return empty;
}
MartinMinkov marked this conversation as resolved.
Show resolved Hide resolved

static witness<T>(
type: FlexibleProvable<T>,
Expand Down Expand Up @@ -1802,7 +1809,8 @@ const Authorization = {
signature ??= {};
accountUpdate.body.authorizationKind.isSigned = Bool(true);
accountUpdate.body.authorizationKind.isProved = Bool(false);
accountUpdate.body.authorizationKind.verificationKeyHash = Field(0);
accountUpdate.body.authorizationKind.verificationKeyHash =
dummyVerificationKeyHash();
accountUpdate.authorization = {};
accountUpdate.lazyAuthorization = { ...signature, kind: 'lazy-signature' };
},
Expand Down Expand Up @@ -1860,7 +1868,8 @@ const Authorization = {
setLazyNone(accountUpdate: AccountUpdate) {
accountUpdate.body.authorizationKind.isSigned = Bool(false);
accountUpdate.body.authorizationKind.isProved = Bool(false);
accountUpdate.body.authorizationKind.verificationKeyHash = Field(0);
accountUpdate.body.authorizationKind.verificationKeyHash =
dummyVerificationKeyHash();
accountUpdate.authorization = {};
accountUpdate.lazyAuthorization = { kind: 'lazy-none' };
},
Expand Down Expand Up @@ -1946,6 +1955,11 @@ function dummySignature() {
return Signature.toBase58(Signature.dummy());
}

function dummyVerificationKeyHash() {
let [, , hash] = Pickles.dummyVerificationKey();
return Fp.fromBytes([...hash]);
}

/**
* The public input for zkApps consists of certain hashes of the proving
AccountUpdate (and its child accountUpdates) which is constructed during method
Expand Down
7 changes: 6 additions & 1 deletion src/lib/testing/random.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ import { Memo } from '../../mina-signer/src/memo.js';
import { ProvableExtended } from '../../bindings/lib/provable-bigint.js';
import { tokenSymbolLength } from '../../bindings/mina-transaction/derived-leaves.js';
import { stringLengthInBytes } from '../../bindings/lib/binable.js';
import { Pickles } from '../../snarky.js';

export { Random, sample, withHardCoded };

Expand Down Expand Up @@ -255,8 +256,12 @@ const accountUpdateJson = mapWithInvalid(
if (isProved && isSigned) {
a.body.authorizationKind.isProved = false;
}

if (!a.body.authorizationKind.isProved) {
a.body.authorizationKind.verificationKeyHash = '0';
let [, , hash] = Pickles.dummyVerificationKey();
a.body.authorizationKind.verificationKeyHash = Field.fromBytes([
...hash,
]).toString();
}
// ensure mayUseToken is valid
let { inheritFromParent, parentsOwnToken } = a.body.mayUseToken;
Expand Down
12 changes: 6 additions & 6 deletions src/mina-signer/MinaSigner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -198,7 +198,7 @@ class Client {
let signature = signPayment(
{
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { source: from, receiver: to, amount },
body: { receiver: to, amount },
},
privateKey,
this.network
Expand Down Expand Up @@ -226,7 +226,7 @@ class Client {
return verifyPayment(
{
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { source: from, receiver: to, amount },
body: { receiver: to, amount },
},
signature,
publicKey,
Expand Down Expand Up @@ -254,7 +254,7 @@ class Client {
let signature = signStakeDelegation(
{
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { newDelegate: to, delegator: from },
body: { newDelegate: to },
},
privateKey,
this.network
Expand All @@ -281,7 +281,7 @@ class Client {
return verifyStakeDelegation(
{
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { newDelegate: to, delegator: from },
body: { newDelegate: to },
},
signature,
publicKey,
Expand All @@ -306,7 +306,7 @@ class Client {
signature,
data: {
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { source: from, receiver: to, amount },
body: { receiver: to, amount },
},
},
options
Expand All @@ -329,7 +329,7 @@ class Client {
signature,
data: {
common: { fee, feePayer: from, nonce, validUntil, memo },
body: { newDelegate: to, delegator: from },
body: { newDelegate: to },
},
},
options
Expand Down
2 changes: 0 additions & 2 deletions src/mina-signer/src/random-transaction.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,6 @@ const common = record({
const payment = record<PaymentJson>({
common,
body: record({
source: Random.json.publicKey,
receiver: Random.json.publicKey,
amount: Random.json.uint64,
}),
Expand All @@ -36,7 +35,6 @@ const signedPayment = record<SignedLegacy<PaymentJson>>({
const delegation = record<DelegationJson>({
common,
body: record({
delegator: Random.json.publicKey,
newDelegate: Random.json.publicKey,
}),
});
Expand Down
35 changes: 25 additions & 10 deletions src/mina-signer/src/sign-legacy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,9 @@ export {
delegationFromJson,
commonFromJson,
PaymentJson,
PaymentJsonV1,
DelegationJson,
DelegationJsonV1,
CommonJson,
Tag,
UserCommand,
Expand Down Expand Up @@ -146,7 +148,7 @@ function commonToInputLegacy({
HashInputLegacy.bits(legacyTokenId),
PublicKey.toInputLegacy(feePayer),
HashInputLegacy.bits(UInt32.toBits(nonce)),
HashInputLegacy.bits(UInt32.toBits(validUntil)),
HashInputLegacy.bits(UInt32.toBits(validUntil.value)),
HashInputLegacy.bits(Memo.toBits(memo)),
].reduce(HashInputLegacy.append);
}
Expand All @@ -160,13 +162,13 @@ const legacyTokenId = [true, ...Array<boolean>(63).fill(false)];

function paymentFromJson({
common,
body: { source, receiver, amount },
body: { receiver, amount },
}: PaymentJson): UserCommand {
return {
common: commonFromJson(common),
body: {
tag: 'Payment',
source: PublicKey.fromJSON(source),
source: PublicKey.fromJSON(common.feePayer),
receiver: PublicKey.fromJSON(receiver),
amount: UInt64.fromJSON(amount),
},
Expand All @@ -175,25 +177,25 @@ function paymentFromJson({

function delegationFromJson({
common,
body: { delegator, newDelegate },
body: { newDelegate },
}: DelegationJson): UserCommand {
return {
common: commonFromJson(common),
body: {
tag: 'StakeDelegation',
source: PublicKey.fromJSON(delegator),
source: PublicKey.fromJSON(common.feePayer),
receiver: PublicKey.fromJSON(newDelegate),
amount: UInt64(0),
},
};
}

function commonFromJson(c: CommonJson) {
function commonFromJson(c: CommonJson): Common {
return {
fee: UInt64.fromJSON(c.fee),
feePayer: PublicKey.fromJSON(c.feePayer),
nonce: UInt32.fromJSON(c.nonce),
validUntil: UInt32.fromJSON(c.validUntil),
validUntil: { type: 'SinceGenesis', value: UInt32.fromJSON(c.validUntil) },
// TODO: this might need to be fromBase58
memo: Memo.fromString(c.memo),
};
Expand Down Expand Up @@ -262,17 +264,15 @@ type Common = {
fee: UInt64;
feePayer: PublicKey;
nonce: UInt32;
validUntil: UInt32;
validUntil: { type: 'SinceGenesis'; value: UInt32 };
memo: string;
};

type Payment = {
source: PublicKey;
receiver: PublicKey;
amount: UInt64;
};
type Delegation = {
delegator: PublicKey;
newDelegate: PublicKey;
};

Expand All @@ -285,6 +285,14 @@ type CommonJson = {
};

type PaymentJson = {
common: CommonJson;
body: {
receiver: Json.PublicKey;
amount: Json.UInt64;
};
};

type PaymentJsonV1 = {
common: CommonJson;
body: {
source: Json.PublicKey;
Expand All @@ -294,6 +302,13 @@ type PaymentJson = {
};

type DelegationJson = {
common: CommonJson;
body: {
newDelegate: Json.PublicKey;
};
};

type DelegationJsonV1 = {
common: CommonJson;
body: {
delegator: Json.PublicKey;
Expand Down
14 changes: 0 additions & 14 deletions src/mina-signer/src/sign-legacy.unit-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -106,13 +106,6 @@ let amountTooLarge = {
amount: (2n ** 64n).toString(),
},
};
let invalidPublicKey: PaymentJson = {
common: validPayment.common,
body: {
...validPayment.body,
source: PublicKey.toBase58({ x: 0n, isOdd: 0n }),
},
};
let signature = Signature.toJSON({ r: Field.random(), s: Scalar.random() });

expect(() => signPayment(amountTooLarge, privateKey, 'mainnet')).toThrow(
Expand All @@ -122,13 +115,6 @@ expect(verifyPayment(amountTooLarge, signature, publicKey, 'mainnet')).toEqual(
false
);

expect(() => signPayment(invalidPublicKey, privateKey, 'mainnet')).toThrow(
'not a valid group element'
);
expect(
verifyPayment(invalidPublicKey, signature, publicKey, 'mainnet')
).toEqual(false);

// negative tests with invalid signatures

let garbageSignature = { field: 'garbage', scalar: 'garbage' };
Expand Down
10 changes: 7 additions & 3 deletions src/mina-signer/src/sign-zkapp-command.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import {
signFieldElement,
verifyFieldElement,
} from './signature.js';
import { Pickles } from '../../snarky.js';
MartinMinkov marked this conversation as resolved.
Show resolved Hide resolved

// external API
export { signZkappCommand, verifyZkappCommandSignature };
Expand Down Expand Up @@ -180,6 +181,7 @@ function accountUpdateFromFeePayer({
authorization: signature,
}: FeePayer): AccountUpdate {
let { body } = AccountUpdate.emptyValue();
let [, , hash] = Pickles.dummyVerificationKey();
body.publicKey = publicKey;
body.balanceChange = { magnitude: fee, sgn: Sign(-1) };
body.incrementNonce = Bool(true);
Expand All @@ -196,7 +198,7 @@ function accountUpdateFromFeePayer({
body.authorizationKind = {
isProved: Bool(false),
isSigned: Bool(true),
verificationKeyHash: Field(0),
verificationKeyHash: Field.fromBytes([...hash]),
};
return { body, authorization: { signature } };
}
Expand All @@ -216,12 +218,14 @@ function isCallDepthValid(zkappCommand: ZkappCommand) {
function assertAuthorizationKindValid(accountUpdate: AccountUpdate) {
let { isSigned, isProved, verificationKeyHash } =
accountUpdate.body.authorizationKind;
let [, , hash] = Pickles.dummyVerificationKey();
const dummyVK = Field.fromBytes([...hash]);
if (isProved && isSigned)
throw Error(
'Invalid authorization kind: Only one of `isProved` and `isSigned` may be true.'
);
if (!isProved && verificationKeyHash !== 0n)
if (!isProved && verificationKeyHash !== dummyVK)
throw Error(
`Invalid authorization kind: If \`isProved\` is false, verification key hash must be 0, got ${verificationKeyHash}`
`Invalid authorization kind: If \`isProved\` is false, verification key hash must be ${dummyVK}, got ${verificationKeyHash}`
);
}
9 changes: 9 additions & 0 deletions src/mina-signer/src/sign-zkapp-command.unit-test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ test(Random.json.publicKey, (publicKeyBase58) => {

// empty account update
let dummy = AccountUpdate.emptyValue();
fixVerificationKeyHash(dummy);
let dummySnarky = AccountUpdateSnarky.dummy();
expect(AccountUpdate.toJSON(dummy)).toEqual(
AccountUpdateSnarky.toJSON(dummySnarky)
Expand All @@ -81,6 +82,7 @@ expect(stringify(dummyInput.packed)).toEqual(
);

test(Random.accountUpdate, (accountUpdate) => {
fixVerificationKeyHash(accountUpdate);
fixVerificationKey(accountUpdate);

// example account update
Expand Down Expand Up @@ -125,6 +127,7 @@ test(memoGenerator, (memoString) => {

// zkapp transaction - basic properties & commitment
test(RandomTransaction.zkappCommand, (zkappCommand, assert) => {
zkappCommand.accountUpdates.forEach(fixVerificationKeyHash);
zkappCommand.accountUpdates.forEach(fixVerificationKey);

assert(isCallDepthValid(zkappCommand));
Expand All @@ -151,6 +154,7 @@ test.negative(
test(
RandomTransaction.zkappCommandAndFeePayerKey,
({ feePayerKey, zkappCommand }) => {
zkappCommand.accountUpdates.forEach(fixVerificationKeyHash);
zkappCommand.accountUpdates.forEach(fixVerificationKey);

let feePayerKeyBase58 = PrivateKey.toBase58(feePayerKey);
Expand Down Expand Up @@ -280,3 +284,8 @@ function fixVerificationKey(a: AccountUpdate) {
a.body.update.verificationKey.value = { data: '', hash: Field(0) };
}
}

function fixVerificationKeyHash(a: AccountUpdate) {
let [, , hash] = Pickles.dummyVerificationKey();
a.body.authorizationKind.verificationKeyHash = Field.fromBytes([...hash]);
}
Loading