Treasury Factory Contract
Blueprint for Financial Expansion
The Treasury Factory Contract on Maven Finance holds the blueprint for creating new Treasury Contract instances within the ecosystem. This contract provides a standardized yet flexible way to deploy new treasuries, promoting scalable growth while maintaining the overall integrity of the platform.
As Maven Finance continues to innovate and introduce new DeFi products, the Treasury Factory Contract paves the way for efficient treasury deployment, thereby enabling the efficient allocation and management of resources across the platform.
Treasury Factory Entrypoints
createTreasury
function createTreasury(option(key_hash) baker, string treasuryName, bool addToGeneralContracts, bytes metadata)
Creates a new standard treasury contract
baker
option(key_hash)
Key hash of the baker
treasuryName
string
The reference name of the new treasury to be created
addToGeneralContracts
bool
If set to true, the new treasury contract will be added to the General Contracts map on the Governance Contract
metadata
bytes
The hash of the tresaury metadata
trackTreasury
function trackTreasury(address treasuryAddress)
Tracks a treasury contract and adds it to the trackedTreasuries set on the Treasury Factory Contract
treasuryAddress
address
The contract address of the treasury to be tracked
untrackTreasury
function untrackTreasury(address treasuryAddress)
Untracks a treasury contract and removes it from the trackedTreasuries set on the Treasury Factory Contract
treasuryAddress
address
The contract address of the treasury to be untracked
Housekeeping Entrypoints
setAdmin
function setAdmin(address newAdminAddress)
Sets a new admin address for the contract
newAdminAddress
address
The address of the new admin
setGovernance
function setGovernance(address newGovernanceAddress)
Sets a new governance contract address
newGovernanceAddress
address
The address of the new governance contract
updateMetadata
function updateMetadata(string key, bytes hash)
Replace the hash of the contract metadata based on the provided key
key
string
The key in the metadata bigmap to be updated
hash
bytes
The hash of the metadata key
updateConfig
function updateConfig(nat newConfigValue, treasuryFactoryConfigActionType treasuryFactoryConfigAction)
Updates the config variables on the Treasury Factory Contract
newConfigValue
nat
The new value of the config parameter
treasuryFactoryConfigAction
treasuryFactoryConfigActionType: | unit ConfigTreasuryNameMaxLength | unit Empty
The variant config variable to be updated
updateWhitelistContracts
function updateWhitelistContracts(address whitelistContractAddress, updateType update)
Add, update or remove a whitelist contract in the whitelistContracts map in the storage
whitelistContractAddress
address
The contract address to be updated in the whitelist contracts bigmap
updateType
updateType: | unit Update | unit Remove
Specifies whether the whitelistContractAddress should be updated or removed from the whitelist contracts bigmap
updateGeneralContracts
function updateGeneralContracts(string generalContractName, address generalContractAddress, updateType update)
Add, update or remove a general contract in the generalContracts map in the storage
generalContractName
string
The identifier key to be set in the general contracts bigmap which will be the general contract name in camelcase
generalContractAddress
address
The contract address to be updated in the general contracts bigmap
updateType
updateType: | unit Update | unit Remove
Specifies whether the generalContractAddress should be updated or removed from the general contracts bigmap
mistakenTransfer
function mistakenTransfer(transferActionType transferList)
Transfers any mav or token that may have mistakenly been sent to this contract
transferList
transferActionType:
list(address to_, nat tokenAmount, token tokenType)
A list of transfers of tokens to recipients
to_
address
The recipient of the mistaken transfer
tokenAmount
nat
The amount of tokens to be transferred
token
tokenType: | unit Mav | (address tokenContractAddress) Fa12 | (address tokenContractAddress, nat tokenId) MRC-20
The token type of the token to be transferred, corresponding to either Mav, MRC-10 OR MRC-20
setLambda
function setLambda(string lambdaName, bytes func_bytes)
Sets a lambda in the Treasury contract with the given bytes and name
lambdaName
string
The name of the lambda to be set
func_bytes
bytes
The data of the lambda in Michelson bytes format
setProductLambda
function setProductLambda(string lambdaName, bytes func_bytes)
Sets a lambda in the treasury lambda ledger with the given bytes and name
lambdaName
string
The name of the lambda to be set
func_bytes
bytes
The data of the lambda in Michelson bytes format
BreakGlass Entrypoints
pauseAll
function pauseAll()
Pauses all entrypoints in the treasury factory contract, and also calls the pauseAll entrypoint in each tracked treasury contract
unpauseAll
function unpauseAll()
Unpauses all entrypoints in the treasury factory contract, and also calls the unpauseAll entrypoint in each tracked treasury contract
togglePauseEntrypoint
function togglePauseEntrypoint(treasuryFactoryPausableEntrypointType targetEntrypoint, unit empty)
Toggles the pausing of a specific entrypoint in the contract
targetEntrypoint
treasuryFactoryPausableEntrypointType: | bool CreateTreasury | bool UntrackTreasury | bool TrackTreasury
The target entrypoint to be paused, and its corresponding pause boolean. If the boolean is set to True, the entrypoint will be paused.
empty
unit
A null param used to prettify interactions with this entrypoint on blockchain explorers such as better-call-dev
View Methods
getAdmin
function getAdmin()
Returns the contract admin
getGovernanceAddress
function getGovernanceAddress()
Returns the contract governance address
getConfig
function getConfig()
Returns the contract configuration parameters
getBreakGlassConfig
function getBreakGlassConfig()
Returns the contract configuration parameters
getWhitelistContractOpt
function getWhitelistContractOpt(address contractAddress)
Returns unit if contract address is whitelisted, else returns none
checkTreasuryExists
function checkTreasuryExists(address treasuryContractAddress)
Returns True if the treasury contract address is found in the trackedTreasuries set
getTrackedTreasuries
function getTrackedTreasuries()
Returns the trackedTreasuries set
getLambdaOpt
function getLambdaOpt(string lambdaName)
Returns a lambda in the contract for the given lambda name, else returns none
getTreasuryLambdaOpt
function getTreasuryLambdaOpt(string lambdaName)
Returns a lambda in the treasury lambda ledger for the given lambda name, else returns none
Last updated