Skip to content

Commit

Permalink
Merge pull request #9 from greymass/sanitizing-transaction-data
Browse files Browse the repository at this point in the history
GRY-01-002 WP1: sanitizing transaction data
  • Loading branch information
dafuga authored Oct 22, 2024
2 parents adc1c64 + 0db163a commit 8c6c780
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 2 deletions.
2 changes: 1 addition & 1 deletion packages/snap/snap.manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
"url": "https://github.com/@greymass/antelope-snap.git"
},
"source": {
"shasum": "3nwqbCR7ZCi4amohJ2Ht6VQKUIuAeU+A8+vfOYRnsXI=",
"shasum": "iEJ7CemKEeAOmtZ498XwcHFmbbvt03stmFemnlNXPe0=",
"location": {
"npm": {
"filePath": "dist/bundle.js",
Expand Down
24 changes: 23 additions & 1 deletion packages/snap/src/rpc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,36 @@ export async function getPublicKey(request: AntelopeRequest): Promise<string> {
return String(await derivePublicKey(chain));
}

const MAX_TRANSACTION_LENGTH = 100_000;

export async function signTransaction(
request: AntelopeSignatureRequest,
): Promise<Signature | undefined> {
// Process incoming transaction
if (!request.params?.transaction) {
throw new Error('Missing transaction in request params');
}
const transaction = Transaction.from(JSON.parse(request.params.transaction));

// Check the length of the transaction string
if (request.params.transaction.length > MAX_TRANSACTION_LENGTH) {
throw new Error('Transaction data is too large');
}

let transactionData;
try {
// Attempt to parse the transaction data
transactionData = JSON.parse(request.params.transaction);
} catch (error) {
throw new Error(`Invalid JSON transaction data: ${(error as Error).stack}`);
}

let transaction;
try {
// Attempt to create a Transaction object from the parsed data
transaction = Transaction.from(transactionData);
} catch (error) {
throw new Error(`Invalid transaction format: ${(error as Error).stack}`);
}

// Load the appropriate chain definition
if (!request.params?.chainId) {
Expand Down

0 comments on commit 8c6c780

Please sign in to comment.