Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
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
5 changes: 5 additions & 0 deletions build-sdk.sh
Original file line number Diff line number Diff line change
Expand Up @@ -20,3 +20,8 @@ pushd mock-app-verifier
rm -rf node_modules
yarn
popd

pushd relayer
rm -rf node_modules
yarn
popd
5 changes: 5 additions & 0 deletions build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -15,3 +15,8 @@ popd
pushd light-circuits
yarn install
popd

pushd relayer
yarn install
yarn run build
popd
4 changes: 2 additions & 2 deletions light-sdk-ts/src/errors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -71,13 +71,13 @@ export enum ProviderErrorCode {
SOL_MERKLE_TREE_UNDEFINED = "SOL_MERKLE_TREE_UNDEFINED",
ANCHOR_PROVIDER_UNDEFINED = "ANCHOR_PROVIDER_UNDEFINED",
PROVIDER_UNDEFINED = "PROVIDER_UNDEFINED",
NODE_WALLET_AND_BROWSER_WALLET_UNDEFINED = "NODE_WALLET_AND_BROWSER_WALLET_UNDEFINED",
WALLET_UNDEFINED = "WALLET_UNDEFINED",
NODE_WALLET_UNDEFINED = "NODE_WALLET_UNDEFINED",
URL_UNDEFINED = "URL_UNDEFINED",
CONNECTION_UNDEFINED = "CONNECTION_UNDEFINED",
CONNECTION_DEFINED = "CONNECTION_DEFINED",
KEYPAIR_UNDEFINED = "KEYPAIR_UNDEFINED",
NODE_WALLET_AND_BROWSER_WALLET_DEFINED = "NODE_WALLET_AND_BROWSER_WALLET_DEFINED",
WALLET_DEFINED = "WALLET_DEFINED",
MERKLE_TREE_NOT_INITIALIZED = "MERKLE_TREE_NOT_INITIALIZED",
}

Expand Down
7 changes: 2 additions & 5 deletions light-sdk-ts/src/merkleTree/solMerkleTree.ts
Original file line number Diff line number Diff line change
Expand Up @@ -67,15 +67,12 @@ export class SolMerkleTree {

const mtFetched = await merkleTreeProgram.account.merkleTree.fetch(
merkleTreePubkey,
"confirmed",
);

const merkleTreeIndex = mtFetched.nextIndex;
// console.log(
// "getCompressedLeaves merkleTreeIndex",
// merkleTreeIndex.toNumber(),
// );

merkleTreeProgram.account.twoLeavesBytesPda.all();
// merkleTreeProgram.account.twoLeavesBytesPda

let leavesAccounts: Array<{
account: QueuedLeavesPda;
Expand Down
4 changes: 2 additions & 2 deletions light-sdk-ts/src/test-utils/createAccounts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -288,8 +288,8 @@ export async function createTestAccounts(
);
}

let balanceUserToken = null;
let userSplAccount = null;
let balanceUserToken: null | any = null;
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please make the type explicit

let userSplAccount: PublicKey | null = null;
try {
let tokenCtx = TOKEN_REGISTRY.find((t) => t.symbol === "USDC");
if (userTokenAccount) {
Expand Down
2 changes: 1 addition & 1 deletion light-sdk-ts/src/test-utils/functionalCircuit.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ export async function functionalCircuitTest(
outputUtxos: [deposit_utxo1],
merkleTreePubkey: mockPubkey,
sender: mockPubkey,
senderFee: lightProvider.nodeWallet!.publicKey,
senderFee: lightProvider.wallet!.publicKey,
verifier: verifier,
lookUpTable: mockPubkey,
action: Action.SHIELD,
Expand Down
3 changes: 2 additions & 1 deletion light-sdk-ts/src/test-utils/initLookUpTable.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import {
SystemProgram,
sendAndConfirmTransaction,
Transaction,
AccountInfo,
} from "@solana/web3.js";
import * as anchor from "@coral-xyz/anchor";
import { TOKEN_PROGRAM_ID } from "@solana/spl-token";
Expand Down Expand Up @@ -80,7 +81,7 @@ export async function initLookUpTable(
recentSlot: number,
extraAccounts?: Array<PublicKey>,
): Promise<PublicKey> {
var lookUpTableInfoInit = null;
var lookUpTableInfoInit: AccountInfo<Buffer> | null = null;
if (lookupTableAddress != undefined) {
lookUpTableInfoInit = await provider.connection.getAccountInfo(
lookupTableAddress,
Expand Down
2 changes: 2 additions & 0 deletions light-sdk-ts/src/test-utils/testChecks.ts
Original file line number Diff line number Diff line change
Expand Up @@ -126,6 +126,7 @@ export async function checkMerkleTreeBatchUpdateSuccess({
}) {
var merkleTreeTmpStateAccount = await connection.getAccountInfo(
merkleTreeUpdateState,
"confirmed",
);

assert.equal(
Expand All @@ -136,6 +137,7 @@ export async function checkMerkleTreeBatchUpdateSuccess({

var merkleTreeAccount = await merkleTreeProgram.account.merkleTree.fetch(
merkle_tree_pubkey,
"confirmed",
);
// Merkle tree is locked by merkleTreeUpdateState
assert.equal(
Expand Down
86 changes: 45 additions & 41 deletions light-sdk-ts/src/transaction.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import {
VersionedTransaction,
TransactionSignature,
TransactionInstruction,
Transaction as SolanaTransaction,
} from "@solana/web3.js";
import * as anchor from "@coral-xyz/anchor";
import { TOKEN_PROGRAM_ID, getAccount } from "@solana/spl-token";
Expand All @@ -30,6 +31,7 @@ import {
initLookUpTable,
TransactionParametersErrorCode,
Provider,
ADMIN_AUTH_KEYPAIR,
} from "./index";
import { IDL_MERKLE_TREE_PROGRAM } from "./idls/index";
const snarkjs = require("snarkjs");
Expand Down Expand Up @@ -808,7 +810,7 @@ export class Transaction {
"constructor",
"Merkle tree not set in provider",
);
if (!provider.browserWallet && !provider.nodeWallet)
if (!provider.wallet)
throw new TransactionError(
TransactionErrorCode.WALLET_UNDEFINED,
"constructor",
Expand All @@ -829,10 +831,7 @@ export class Transaction {

//TODO: change to check whether browser/node wallet are the same as signing address
if (params.action === Action.SHIELD) {
let wallet =
this.provider.browserWallet !== undefined
? this.provider.browserWallet
: this.provider.nodeWallet;
let wallet = this.provider.wallet;
if (
wallet?.publicKey.toBase58() !==
params.relayer.accounts.relayerPubkey.toBase58() &&
Expand Down Expand Up @@ -1103,7 +1102,7 @@ export class Transaction {
IDL_MERKLE_TREE_PROGRAM,
merkleTreeProgramId,
// @ts-ignore
this.provider.browserWallet && this.provider,
this.provider.provider,
);
let root = Uint8Array.from(
leInt2Buff(
Expand All @@ -1114,6 +1113,7 @@ export class Transaction {
let merkle_tree_account_data =
await this.merkleTreeProgram.account.merkleTree.fetch(
this.provider.solMerkleTree.pubkey,
"confirmed",
);
// @ts-ignore: unknown type error
merkle_tree_account_data.roots.map((x: any, index: any) => {
Expand Down Expand Up @@ -1509,7 +1509,7 @@ export class Transaction {

async sendTransaction(ix: any): Promise<TransactionSignature | undefined> {
if (false) {
// TODO: replace this with (this.provider.browserWallet.pubkey != new relayer... this.relayer
// TODO: replace this with (this.provider.wallet.pubkey != new relayer... this.relayer
// then we know that an actual relayer was passed in and that it's supposed to be sent to one.
// we cant do that tho as we'd want to add the default relayer to the provider itself.
// so just pass in a flag here "shield, unshield, transfer" -> so devs don't have to know that it goes to a relayer.
Expand Down Expand Up @@ -1592,18 +1592,7 @@ export class Transaction {
let retries = 3;
let res;
while (retries > 0) {
if (this.provider.browserWallet) {
// TODO: versiontx??
console.error("versioned tx might throw here");
tx = await this.provider.browserWallet.signTransaction(tx);
// throw new Error(
// "versioned transaction in browser not implemented yet",
// );
} else {
/** Just need to define relayer pubkey as signer a creation */
tx.sign([this.provider.nodeWallet!]);
}

tx = await this.provider.wallet.signTransaction(tx);
try {
let serializedTx = tx.serialize();

Expand Down Expand Up @@ -1642,11 +1631,11 @@ export class Transaction {
"",
);

if (!this.provider.nodeWallet && !this.provider.browserWallet)
if (!this.provider.wallet)
throw new TransactionError(
TransactionErrorCode.WALLET_UNDEFINED,
"sendAndConfirmTransaction",
"Cannot use sendAndConfirmTransaction without payer or browserWallet",
"Cannot use sendAndConfirmTransaction without wallet",
);

await this.getRootIndex();
Expand Down Expand Up @@ -1692,11 +1681,11 @@ export class Transaction {
// TODO: deal with this: set own payer just for that? where is this used?
// This is used by applications not the relayer
async closeVerifierState(): Promise<TransactionSignature> {
if (!this.provider.nodeWallet && !this.provider.browserWallet)
if (!this.provider.wallet)
throw new TransactionError(
TransactionErrorCode.WALLET_UNDEFINED,
"closeVerifierState",
"Cannot use closeVerifierState without payer or browserWallet",
"Cannot use closeVerifierState without wallet",
);
if (!this.params)
throw new TransactionError(
Expand All @@ -1711,21 +1700,27 @@ export class Transaction {
"",
);
if (this.appParams) {
return await this.appParams?.verifier.verifierProgram.methods
.closeVerifierState()
.accounts({
...this.params.accounts,
})
.signers([this.provider.nodeWallet!]) // TODO: browserwallet? or only ever used by relayer?
.rpc(confirmConfig);
const transaction = new SolanaTransaction().add(
await this.appParams?.verifier.verifierProgram.methods
.closeVerifierState()
.accounts({
...this.params.accounts,
})
.instruction(),
);

return await this.provider.wallet!.sendAndConfirmTransaction(transaction);
} else {
return await this.params?.verifier.verifierProgram.methods
.closeVerifierState()
.accounts({
...this.params.accounts,
})
.signers([this.provider.nodeWallet!]) // TODO: browserwallet? or only ever used by relayer?
.rpc(confirmConfig);
const transaction = new SolanaTransaction().add(
await this.params?.verifier.verifierProgram.methods
.closeVerifierState()
.accounts({
...this.params.accounts,
})
.instruction(),
);

return await this.provider.wallet!.sendAndConfirmTransaction(transaction);
}
}

Expand Down Expand Up @@ -1913,14 +1908,12 @@ export class Transaction {
"test values relayerRecipientAccountBalancePriorLastTx undefined",
);
}

// Checking that nullifiers were inserted
if (new BN(this.proofInput.publicAmount).toString() === "0") {
this.testValues.is_token = false;
} else {
this.testValues.is_token = true;
}

for (
var i = 0;
i < this.remainingAccounts.nullifierPdaPubkeys?.length;
Expand All @@ -1946,6 +1939,7 @@ export class Transaction {
leavesAccountData =
await this.merkleTreeProgram.account.twoLeavesBytesPda.fetch(
this.remainingAccounts.leavesPdaPubkeys[i].pubkey,
"confirmed",
);

assert(
Expand All @@ -1963,7 +1957,6 @@ export class Transaction {
this.provider.solMerkleTree.pubkey.toBase58(),
"merkleTreePubkey not inserted correctly",
);

for (var j = 0; j < this.params.encryptedUtxos.length / 256; j++) {
// console.log(j);

Expand Down Expand Up @@ -2035,14 +2028,18 @@ export class Transaction {

try {
const merkleTreeAfterUpdate =
await this.merkleTreeProgram.account.merkleTree.fetch(MERKLE_TREE_KEY);
await this.merkleTreeProgram.account.merkleTree.fetch(
MERKLE_TREE_KEY,
"confirmed",
);
console.log(
"Number(merkleTreeAfterUpdate.nextQueuedIndex) ",
Number(merkleTreeAfterUpdate.nextQueuedIndex),
);
leavesAccountData =
await this.merkleTreeProgram.account.twoLeavesBytesPda.fetch(
this.remainingAccounts.leavesPdaPubkeys[0].pubkey,
"confirmed",
);
console.log(
`${Number(leavesAccountData.leftLeafIndex)} + ${
Expand Down Expand Up @@ -2072,6 +2069,7 @@ export class Transaction {
var recipientFeeAccountBalance =
await this.provider.provider.connection.getBalance(
this.params.accounts.recipientFee,
"confirmed",
);
console.log(
"testValues.recipientFeeBalancePriorTx: ",
Expand All @@ -2081,6 +2079,7 @@ export class Transaction {
var senderFeeAccountBalance =
await this.provider.provider.connection.getBalance(
this.params.relayer.accounts.relayerPubkey,
"confirmed",
);
assert(
recipientFeeAccountBalance ==
Expand Down Expand Up @@ -2157,6 +2156,7 @@ export class Transaction {
var senderFeeAccountBalance =
await this.provider.provider.connection.getBalance(
this.params.accounts.senderFee,
"confirmed",
);

assert(
Expand All @@ -2182,11 +2182,13 @@ export class Transaction {
) {
var relayerAccount = await this.provider.provider.connection.getBalance(
this.params.relayer.accounts.relayerRecipient,
"confirmed",
);

var recipientFeeAccount =
await this.provider.provider.connection.getBalance(
this.params.accounts.recipientFee,
"confirmed",
);

// console.log("relayerAccount ", relayerAccount);
Expand Down Expand Up @@ -2269,11 +2271,13 @@ export class Transaction {

var relayerAccount = await this.provider.provider.connection.getBalance(
this.params.relayer.accounts.relayerRecipient,
"confirmed",
);

var recipientFeeAccount =
await this.provider.provider.connection.getBalance(
this.params.accounts.recipientFee,
"confirmed",
);

// console.log("relayerAccount ", relayerAccount);
Expand Down
7 changes: 2 additions & 5 deletions light-sdk-ts/src/verifiers/verifierOne.ts
Original file line number Diff line number Diff line change
Expand Up @@ -111,14 +111,11 @@ export class VerifierOne implements Verifier {
"getInstructions",
"verifier one: params.encryptedUtxos undefined",
);
if (
!transaction.provider.browserWallet &&
!transaction.provider.nodeWallet
) {
if (!transaction.provider.wallet) {
throw new VerifierError(
TransactionErrorCode.WALLET_UNDEFINED,
"getInstructions",
"verifier one: Payer(browserwallet, nodewallet) not defined",
"verifier one: Payer(wallet) not defined",
);
}
if (!this.verifierProgram)
Expand Down
7 changes: 2 additions & 5 deletions light-sdk-ts/src/verifiers/verifierZero.ts
Original file line number Diff line number Diff line change
Expand Up @@ -114,14 +114,11 @@ export class VerifierZero implements Verifier {
"getInstructions",
"verifier zero: params.encryptedUtxos undefined",
);
if (
!transaction.provider.browserWallet &&
!transaction.provider.nodeWallet
) {
if (!transaction.provider.wallet) {
throw new VerifierError(
TransactionErrorCode.WALLET_UNDEFINED,
"getInstructions",
"verifier zero: Payer(browserwallet, nodewallet) not defined",
"verifier zero: Payer(wallet) not defined",
);
}
if (!this.verifierProgram)
Expand Down
Loading