Homepage | Docs | Developers
Name | Package | Meaning |
---|---|---|
OmniPoint |
@layerzerolabs/devtools |
Location of a contract/program in omnichain environment. Consists of an address and EndpointId |
OmniVector |
@layerzerolabs/devtools |
Directional connection between two OmniPoint s. Consists of from and to OmniPoint s |
OmniNode |
@layerzerolabs/devtools |
Combination of an OmniPoint and an arbitrary configuration attached to it. Consists of a point and config |
OmniEdge |
@layerzerolabs/devtools |
Combination of an OmniVector and an arbitrary configuration attached to it. Consists of a vector and config |
OmniGraph |
@layerzerolabs/devtools |
Collection of OmniNode s and OmniEdge s that together represent a state of an omnichain application. Consists of contracts and connections |
OmniError |
@layerzerolabs/devtools |
Wraps an arbitrary error object to add information about where that error happened. Consists of error and point |
OmniContract |
@layerzerolabs/devtools-evm |
Wraps an ethers Contract instance to add information about the endpoint. Consists of eid and contract |
OmniPointHardhat |
@layerzerolabs/devtools-evm-hardhat |
Hardhat-specific variation of OmniPoint . Since in hardhat we can get a contract address by its name (from deployments ), this version of OmniPoint allows us to use contractName instead of address |
The packages are laid out according to the principle of least knowledge. Their domain of action is also reflected in their name that follows the convention [DOMAIN-]<ELEMENT>[-MODIFIER]
, for example:
@layerzerolabs/devtools
package is the most generic package and it itself does not know and cannot use any implementation details of any more specific packages, nor is it specific to any domain@layerzerolabs/devtools-evm
package is specific to theEVM
implementation but it is not specific to any domain@layerzerolabs/ua-devtools-evm
package is specific to theEVM
implementation and specific to theua
(user application) domain@layerzerolabs/ua-devtools-evm-hardhat
package is specific to theEVM
implementation usinghardhat
and specific to theua
(user application) domain
The only exceptions to this rule are packages that need to follow an existing naming convention (create-lz-oapp
) or packages for which the name needs to appeal or be intuitive/familiar to the user (toolbox-hardhat
)
These packages augment the hardhat
types and introduce a new property on the network
configuration: eid
. This property links the user-defined network names to LayerZero endpoint IDs:
// hardhat.config.ts
const config: HardhatUserConfig = {
networks: {
"ethereum-mainnet": {
eid: EndpointId.ETHEREUM_MAINNET,
// ...
},
},
};
This property is required for a lot of the tooling to work - the link between network names and endpoints needs to be specified in order to wire OApps successfully.
// By network name (as specified in hardhat config)
import { getHreByNetworkName } from "@layerzerolabs/devtools-evm-hardhat";
const environment = await getHreByNetworkName("avalanche-testnet");
// By endpoint ID (as specified in hardhat config, using the eid property of a network)
import { createGetHreByEid } from "@layerzerolabs/devtools-evm-hardhat";
// In this case we need to instantiate an environment factory
const getEnvironment = createGetHreByEid();
const eid = EndpointId.AVALANCHE_TESTNET;
const environment = await getNetworkRuntimeEnvironmentByEid(eid);
// By OmniPointHardhat
import { createContractFactory } from "@layerzerolabs/devtools-evm-hardhat";
// In this case we need to instantiate a contract factory
const createContract = createContractFactory();
const eid = EndpointId.BST_MAINNET;
// We can ask for the contract by its name and eid
const contract = await createContract({ eid: address: '0x' })
// Or its name
const contract = await createContract({ eid: contractName: 'MyOApp' })
// By OmniPointHardhat
import { createConnectedContractFactory } from "@layerzerolabs/devtools-evm-hardhat";
// In this case we need to instantiate a contract factory
const createContract = createConnectedContractFactory();
const eid = EndpointId.BST_MAINNET;
// We can ask for the contract by its address and eid
const contract = await createContract({ eid, address: "0x" });
// Or its name and eid
const contract = await createContract({ eid, contractName: "MyOApp" });