Custom providers for SilentData Rollup, compatible with ethers.js for Fireblocks integration.
- Node.js (version 18 or higher)
- npm or yarn
- Basic knowledge of Ethereum and smart contracts
- Ethers.js v6
npm install @appliedblockchain/silentdatarollup-core @appliedblockchain/silentdatarollup-ethers-provider-fireblocks ethers@6 @fireblocks/fireblocks-web3-provider
import {
ApiBaseUrl,
ChainId,
FireblocksWeb3Provider,
} from "@fireblocks/fireblocks-web3-provider";
import { BaseConfig, SilentDataRollupContract } from "@appliedblockchain/silentdatarollup-core";
import { SilentDataRollupFireblocksProvider } from "@appliedblockchain/silentdatarollup-ethers-provider-fireblocks";
const RPC_URL = "SILENT_DATA_ROLLUP_RPC_URL";
const eip1193Provider = new FireblocksWeb3Provider({
privateKey: "FIREBLOCKS_PATH_TO_PRIVATE_KEY",
apiKey: "FIREBLOCKS_API_KEY",
vaultAccountIds: "FIREBLOCKS_VAULT_ACCOUNT_ID",
assetId: ASSETS[ChainId.SEPOLIA].assetId,
chainId: ChainId.SEPOLIA,
apiBaseUrl: ApiBaseUrl.Sandbox, // If using a sandbox workspace
rpcUrl: "SILENT_DATA_ROLLUP_RPC_URL",
});
const silentdataOptions: BaseConfig = {
authSignatureType: SignatureType.EIP712, // Optional, defaults to RAW
delegate: true // Optional, defaults to false
}
const provider = new SilentDataRollupFireblocksProvider({ ethereum: eip1193Provider, silentdataOptions });
const balance = await provider.getBalance("YOUR_ADDRESS");
console.log(balance);
const signer = await provider.getSigner();
const contractAddress = 'YOUR_CONTRACT_ADDRESS';
const abi = [/* Your contract ABI */];
const methodsToSign = ['balance']; // Contract read calls that require signing
const contract = new SilentDataRollupContract(
contractAddress,
abi,
signer,
methodsToSign,
);
const tokenBalance = await contract.balance('YOUR_ADDRESS');
console.log(tokenBalance);
Note: The SilentDataRollupFireblocksProvider adds an additional namespace on top of the Fireblocks provider for debugging purposes. This namespace is the same as the Fireblocks namespace with an additional :silentdata-interceptor
suffix. For example, if the Fireblocks namespace is fireblocks:web3-provider
, the SilentData provider's namespace would be fireblocks:web3-provider:silentdata-interceptor
.
To enable debugging for the SilentData interceptor, you can set the following environment variable:
DEBUG=fireblocks:web3-provider:silentdata-interceptor
This will output debug information specific to the SilentData interceptor, helping you troubleshoot issues related to the SilentData Rollup integration with Fireblocks.
If you encounter any issues, please check the following:
- Ensure you're using the correct RPC URL for your desired network.
- Verify that the Fireblocks configuration is correctly set up and ensure your user and API keys are valid.
- Ensure that your token is active on the SilentData AppChains dashboard.
This project is licensed under the MIT License.