In Sway, the B512 type is commonly used to handle public keys and signatures. This guide will explain how the B512 type is defined in Sway, how to visualize a B512 value using the SDK, and how to interact with a contract function that accepts a B512 parameter.
The B512 type in Sway is a wrapper around two B256 types, allowing for the representation of 64-byte values. It is defined as a struct:
pub struct B512 {
/// The two `B256`s that make up the `B512`.
bits: [b256; 2],
}B512 in the SDK In the SDK, you can visualize a B512 value by examining a wallet's public key:
import { Provider, Wallet } from 'fuels';
import { LOCAL_NETWORK_URL } from '../../../../env';
const provider = new Provider(LOCAL_NETWORK_URL);
const wallet = Wallet.generate({ provider });
console.log('public key', wallet.publicKey);
// 0x97e3a666e4cd34b6b3cf778ef5ec617de4439b68f7a629245442a1fece7713094a1cb0aa7ad0ac253ca1ea47d4618f9090b2a881e829e091fb2c426763e94ccaB512 Value in a Contract Function Let's consider a contract function that accepts a B512 parameter and returns the same value:
fn echo_b512(input: B512) -> B512 {
input
}To call this function and validate the returned value, follow these steps:
const b512 = wallet.publicKey;
const { value } = await contract.functions.echo_b512(b512).get(); In this example, we generate a wallet, use its public key as the B512 input, call the echo_b512 contract function, and expect the returned value to match the original input.