# The Structure of Offers
# Making An offer
To make an offer, you use E(zoe).offer()
, which takes three arguments:
- An invitation to participate in this contract instance.
- A proposal stating your offer conditions.
- The payments escrowed for the offer, each in association with a
proposal
-specified keyword.
# Invitations
Invitations
are a special case of ERTP payments
. They are linked to a specific contract instance
, and
having one gives you the right to participate in that contract instance
, for example, by making offers in it.
There are two main ways for contract users to get an invitation
:
- If you create the contract
instance
, you get a special creatorinvitation
. - Someone (possibly you) who holds the right objects has created an
invitation
for a contractinstance
and gives it to you in some way. This could've been by sending it to you, posting it on a public online location, etc. It doesn't matter (nor does Zoe specify or have any requirements) how or why it got to you, only that you have it.
# Proposals
Proposals are records with give, want, and exit keys.
const myProposal = harden({
give: { Asset: AmountMath.make(quatloosBrand, 4n)},
want: { Price: AmountMath.make(moolaBrand, 15n) },
exit: { onDemand: null },
})
give and want use keywords defined by the contract. Keywords are unique identifiers per contract, that tie together the proposal, payments to be escrowed, and payouts to the user. In the example above, Asset and Price are the keywords. However, in an auction contract, the keywords might be Asset and Bid.
The AmountMath.make(quatloosBrand, 4n)
is just making an ERTP amount
, or description of digital assets.
In this case, 4 of our imaginary Quatloos currency. AmountMath.make(moolaBrand, 15n)
is making
an amount
of 15 of our imaginary Moola currency. (The appended "n" indicates that the numbers are
represented as BigInts
rather than Numbers
)
Note: It's important to understand that amounts
are just descriptions of assets with no
intrinsic value. payments
hold actual digital assets.
exit
determines how an offer can be can cancelled:
onDemand: null
: (Default) The offering party can cancel on demand.waived: null
: The offering party can't cancel and relies entirely on the smart contract to promptly finish their offer.afterDeadline: {…}
: The offer is automatically cancelled after a deadline, as determined by itstimer
anddeadline
properties. See Proposals and payments.
# Escrowed Payments
Using the same keywords as your proposal
, you must specify a PaymentKeywordRecord
.
This is a record with the keywords as keys, and payments
containing digital assets as
values. Zoe escrows these payments
on behalf of this offer until the offer is completed
or rejected or the assets are reassigned to another offer.
const paymentKeywordRecord = {
'Asset' : quatloosPayment,
'Price' : moolaPayment
};
# Returned Value
offer()
returns a UserSeat
object. Its name comes from the concept of "having a seat at the table"
for the contract's execution.