Skip to main content

contracts/handlers/puf-locker-handler

Classes

PufLockerHandler

Handler for the PufLocker contract exposing methods to interact with the contract.

Constructors

new PufLockerHandler()

new PufLockerHandler(chain, walletClient, publicClient): PufLockerHandler

Create the handler for the PufLocker contract exposing methods to interact with the contract.

Parameters
ParameterTypeDescription
chainChainChain to use for the client.
walletClientobjectThe wallet client to use for wallet interactions.
publicClientobjectThe public client to use for public interactions.
Returns

PufLockerHandler

Source

lib/contracts/handlers/puf-locker-handler.ts:42

Properties

PropertyModifierTypeDescription
chainprivateChainChain to use for the client.
erc20PermitHandlerprivateERC20PermitHandler-
publicClientprivateobjectThe public client to use for public interactions.
viemChainprivateChain-
walletClientprivateobjectThe wallet client to use for wallet interactions.

Methods

deposit()

deposit(depositParams): Promise<object>

Deposit the given PufToken into the locker. This doesn't make the transaction but returns two methods namely transact and estimate.

Parameters
ParameterType
depositParamsLockerDepositParams
Returns

Promise<object>

transact: () => Promise<Address> - Used to make the transaction.

estimate: () => Promise<bigint> - Gas estimate of the transaction.

estimate()

estimate: () => Promise<bigint>

Returns

Promise<bigint>

transact()

transact: () => Promise<`0x${string}`>

Returns

Promise<`0x${string}`>

Source

lib/contracts/handlers/puf-locker-handler.ts:139

getAllDeposits()

getAllDeposits(pufToken, walletAddress): Promise<readonly object[]>

Get all deposits of the given account address.

Parameters
ParameterTypeDescription
pufTokenUnifiTokenThe PufToken to get the deposits for.
walletAddress`0x${string}`The wallet address to get the deposits for.
Returns

Promise<readonly object[]>

The amount and deposits of the given account address.

Source

lib/contracts/handlers/puf-locker-handler.ts:80

getContract()

getContract(): object

Get the contract. This is a method because the typings are complex and lost when trying to make it a member.

Returns

object

The viem contract.

Source

lib/contracts/handlers/puf-locker-handler.ts:61

getDeposits()

getDeposits(pufToken, userAddress, start, limit): Promise<readonly object[]>

Get the user's deposits for the given token and deposit index.

Parameters
ParameterTypeDescription
pufTokenUnifiTokenPufToken to get the deposits of.
userAddress`0x${string}`User address to get the deposits for.
startbigintThe starting index of the deposits.
limitbigintThe maximum number of deposits to retrieve.
Returns

Promise<readonly object[]>

The amount and release time of the deposits.

Source

lib/contracts/handlers/puf-locker-handler.ts:96

getLockPeriods()

getLockPeriods(): Promise<readonly [bigint, bigint]>

Get the minimum and maximum lock periods allowed for deposits.

Returns

Promise<readonly [bigint, bigint]>

The minimum and maximum lock period in seconds. ([minLock, maxLock])

Source

lib/contracts/handlers/puf-locker-handler.ts:116

withdraw()

withdraw(pufToken, walletAddress, recipient, depositIndexes): object

Withdraw the deposits identified by the deposit indexes from the locker.

Parameters
ParameterTypeDescription
pufTokenUnifiTokenPufToken to withdraw.
walletAddress`0x${string}`Address of the account making the transaction.
recipient`0x${string}`Recipient of the withdrawal.
depositIndexesbigint[]Deposit indexes to withdraw.
Returns

object

Hash of the withdrawal transaction.

estimate()

estimate: () => Promise<bigint>

Returns

Promise<bigint>

transact()

transact: () => Promise<`0x${string}`>

Returns

Promise<`0x${string}`>

Source

lib/contracts/handlers/puf-locker-handler.ts:207

Type Aliases

LockerDepositParams

LockerDepositParams: object

Type declaration

account

account: Address

isPreapproved?

optional isPreapproved: boolean

lockPeriod

lockPeriod: bigint

recipient

recipient: Address

token

token: UnifiToken

value

value: bigint

Source

lib/contracts/handlers/puf-locker-handler.ts:15