loam-sdk
Build composable, upgradeable, secure Smart Contracts.
-
Composable: With Loam SDK, you compose your smart contract from many sub contracts. Subcontracts are like lego blocks that you can either use off-the-shelf from the open source ecosystem or that you can build yourself. A single Loam smart contract is composed of one or more subcontracts.
-
Upgradeable: The one subcontract that all Loam smart contracts must include (loam-subcontract-core) adds an important method to the smart contract:
redeploy. You can call this method to switch thewasmhash—the behavior/brains of the contract—to a new one, while keeping the same contract ID. The storage accessed by each particular subcontract is loaded lazily, so upgrading one subcontract does not require migrating the data of another; each subcontract within your smart contract can be considered and upgraded independently. -
Secure: The core subcontract also adds
admin_setandadmin_getto your contract, to make sure that only your trusted admin account can callredeploy. Our full loam architecture, beyond Loam SDK, also includes a universal factory contract, which makes it possible to deploy your contract and calladmin_setin a single transaction, helping avoid front-running.
Subcontracts
A subcontract is a type that implements the IntoKey trait, which is used for lazily loading and storing the type.
Creating Subcontracts
Here's an example of how to create a subcontract:
;
This generates the following implementation:
External API
You can also create and implement external APIs for contract subcontracts:
Core Subcontract
The Core trait provides the minimum logic needed for a contract to be redeployable. A contract should be able to be redeployed to another contract that can also be redeployed. Redeployment requires admin status, as it would be undesirable for an account to redeploy the contract without permission.
Using Core
To use the core subcontract, create a Contract struct and implement Core for it. This makes Contract redeployable by the Admin of the contract and will continue to be redeployable if the new contract also implements Core. After Core other Subcontracts can be added as needed.
use ;
use ;
;
soroban_contract!;
This code generates the following implementation:
;
By specifying the associated Impl type for Core, you enable the default Admin methods to be used (admin_set, admin_get, redeploy). However, you can also provide a different implementation if needed by replacing Admin with a different struct/enum that also implements IsCore.
Notice that the generated code calls Contract::redeploy and other methods. This ensures that the Contract type is redeployable, while also allowing for extensions, as Contract can overwrite the default methods.