Dutch auction sale contract
This section provides reference information for writing a smart contract to conduct a dutch auction using Marmalade on the Kadena network. The reference information includes the capabilities, schemas, tables, functions, and constants defined for a dutch auction.
Source code: dutch-auction.pact
Capabilities
The dutch auction smart contract defines the following capabilities to manage permissions:
GOVERNANCE
: Defines governance for the contract and is controlled by the keyset defined under theADMIN-KS
constant.AUCTION_CREATED
: Specifies the event emitted after the auction is created by the seller.PRICE_ACCEPTED
: Specifies the event emitted after the buyer successfully executes themarmalade.buy
function in a sales contract.DUMMY
: Acts as a placeholder capability for thebuyer-guard
field.
Schema and table
The auctions-schema
describes the following information for a dutch auction:
token-id
start-date
end-date
start-price
reserve-price
sell-price
price-interval-seconds
buyer
buyer-guard
The dutch auction contract stores auction information in the auctions
table.
Functions
The dutch auction contract defines the following functions to manage token sales using the dutch auction format:
enforce-quote-update
: Enforces a quote update when required for sale contracts. This function is called by thepolicy-manager.enforce-buy
function to validate that the buyer has transferred the fungible amount equal tocurrent-price
set by the dutch auction. The function updates theauctions
table with the winner information.enforce-withdrawal
: Enforces a withdrawal when required for sale contracts. This function is called by thepolicy-manager.enforce-withdraw
function to validate that the auction has expired, or that the bid has already been placed.validate-auction
: Validates that the auction information adheres to contract logic in thecreate-auction
andupdate-auction
functions.create-auction
: Allows sellers to create the dutch auction for their token after providing auction information.update-auction
: Allows sellers to update auction information before the auction start time.retrieve-auction
: Retrieves auction information from theauctions
table.get-current-price
: Calculates the current auction price by starting with thestart-price
and gradually reducing the price perprice-interval-seconds
, always ending with the last time interval at thereserve-price
.
Constants
The dutch auction contract defines the following constants:
-
ADMIN-KS
: Sets themarmalade-sale.marmalade-contract-admin
for theGOVERNANCE
capability. -
DUMMY_GUARD
: Acts as a placeholder guard constant for thebuyer-guard
field.