UNPKG

iustosed

Version:
125 lines (111 loc) 3.9 kB
const Web3 = require("web3"); const EthereumTx = require("ethereumjs-tx").Transaction; const Web3Quorum = require("../src"); const web3 = new Web3Quorum( new Web3("http://localhost:22000"), { privateUrl: "http://localhost:9081", }, true ); const accAddress = "ed9d02e382b34818e88b88a309c7fe71e65f419d"; const signAcct = web3.eth.accounts.decrypt( { address: accAddress, crypto: { cipher: "aes-128-ctr", ciphertext: "4e77046ba3f699e744acb4a89c36a3ea1158a1bd90a076d36675f4c883864377", cipherparams: { iv: "a8932af2a3c0225ee8e872bc0e462c11" }, kdf: "scrypt", kdfparams: { dklen: 32, n: 262144, p: 1, r: 8, salt: "8ca49552b3e92f79c51f2cd3d38dfc723412c212e702bd337a3724e8937aff0f", }, mac: "6d1354fef5aa0418389b1a5d1f5ee0050d7273292a1171c51fd02f9ecff55264", }, id: "a65d1ac3-db7e-445d-a1cc-b6c5eeaa05e0", version: 3, }, "" ); const abi = [ { constant: true, inputs: [], name: "storedData", outputs: [{ name: "", type: "uint256" }], payable: false, type: "function", }, { constant: false, inputs: [{ name: "x", type: "uint256" }], name: "set", outputs: [], payable: false, type: "function", }, { constant: true, inputs: [], name: "get", outputs: [{ name: "retVal", type: "uint256" }], payable: false, type: "function", }, { inputs: [{ name: "initVal", type: "uint256" }], payable: false, type: "constructor", }, ]; const bytecode = "0x6060604052341561000f57600080fd5b604051602080610149833981016040528080519060200190919050505b806000819055505b505b610104806100456000396000f30060606040526000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff1680632a1afcd914605157806360fe47b11460775780636d4ce63c146097575b600080fd5b3415605b57600080fd5b606160bd565b6040518082815260200191505060405180910390f35b3415608157600080fd5b6095600480803590602001909190505060c3565b005b341560a157600080fd5b60a760ce565b6040518082815260200191505060405180910390f35b60005481565b806000819055505b50565b6000805490505b905600a165627a7a72305820d5851baab720bba574474de3d09dbeaabc674a15f4dd93b974908476542c23f00029"; const simpleContract = new web3.eth.Contract(abi); const bytecodeWithInitParam = simpleContract .deploy({ data: bytecode, arguments: [42] }) .encodeABI(); (async () => { try { const txHash = await web3.ptm.storeRaw({ data: bytecodeWithInitParam, privateFrom: "BULeR8JyUWhiuuCMU/HLA0Q5pzkYT+cHII3ZKBey3Bo=", }); // BEGIN EXTERNAL SIGNING // REPLACE this with your preferred method for signing // Keep in mind that for signing *private* transactions you need to use the *Homestead/Frontier* signer. const nonce = await web3.eth.getTransactionCount(accAddress); const rawTransaction = { nonce: `0x${nonce.toString(16)}`, from: accAddress, value: `0x${(0).toString(16)}`, gasLimit: `0x${(4300000).toString(16)}`, gasPrice: `0x${(0).toString(16)}`, data: `0x${txHash}`, }; const tx = new EthereumTx(rawTransaction, { chain: "mainnet", hardfork: "homestead", }); tx.sign(Buffer.from(signAcct.privateKey.substring(2), "hex")); const serializedTx = tx.serialize(); const serializedTxHex = `0x${serializedTx.toString("hex")}`; // END EXTERNAL SIGNING const privateTx = web3.utils.setPrivate(serializedTxHex); const privateTxHex = `0x${privateTx.toString("hex")}`; const hash = await web3.eth.sendRawPrivateTransaction(privateTxHex, { privateFor: ["QfeDAys9MPDs2XHExtc84jKGHxZg/aj52DTh0vtA3Xc="], }); const receipt = await web3.priv.waitForTransactionReceipt(hash); console.log("receipt :>> ", receipt); return receipt; } catch (error) { console.error("error :>> ", error); return error; } })();