- RFC: 03-013
- Authors: Venkatraman Ramakrishna, Krishnasuri Narayanam, Sandeep Nishad, Dhinakaran Vinayagamurthy
- Status: Proposed
- Since: 02-Apr-2022
This document specifies the data formats used in the cross-network asset exchange protocol. We envision supporting several distinct kinds of asset locking mechanisms for asset exchanges in Weaver, which are listed in and can be selected from an enumeration as follows:
enum LockMechanism {
HTLC = 0;
}
Currently, only the HTLC protocol is supported, as indicated above.
To communicate locking instructions between the application layer or a contract and the interoperation module or across networks, we need common DLT-neutral structures. The general structure to lock assets (both fungible and non-fungible) is as follows:
message AssetLock {
LockMechanism lockMechanism = 1;
bytes lockInfo = 2;
}
The lockMechanism
field can assume any of the values in the LockMechanism
enumeration specified earlier. The lockInfo
field is a serialized lock structure containing specific information about the lock. For the HTLC
locking mechanism, the lock structure is as follows:
message AssetLockHTLC {
HashMechanism hashMechanism = 1;
bytes hashBase64 = 2;
uint64 expiryTimeSecs = 3;
enum TimeSpec {
EPOCH = 0;
DURATION = 1;
}
TimeSpec timeSpec = 4;
}
hashMechanism
is the algorithm used for the generation of the hash value captured byhashBase64
. It can be selected from an enumerationHashMechanism
as follows:SHA256
represents the cryptographic hash function (secure hash algorithm) that produces 256-bit hash valueSHA512
represents the cryptographic hash function (secure hash algorithm) that produces 512-bit hash value
enum HashMechanism {
SHA256 = 0;
SHA512 = 1;
}
hashBase64
is the hash lock, or the hash value with which an asset is locked, pending revelation of the secret preimage of this hash- It is encoded in Base64 for communication safety and portability
expiryTimeSecs
is the time lock, which can either indicate an expiration time period for the lock or the time instant at which the lock ceases to be active- The nature of this field is set using the
timeSpec
field, which can beEPOCH
(representing a time instant) orDURATION
(representing a time period), as listed in theTimeSpec
enumeration
- The nature of this field is set using the
To communicate claiming instructions between the application layer or a contract and the interoperation module or across networks, we need common DLT-neutral structures. The general structure to claim assets (both fungible and non-fungible) is as follows:
message AssetClaim {
LockMechanism lockMechanism = 1;
bytes claimInfo = 2;
}
Since every claim is associated with a lock, the above structure needs a lockMechanism
field just like the AssetLock
structure does, with identical semantics. The claimInfo
field is a serialized claim structure containing specific information about the claim. For the HTLC
locking mechanism, the claim structure is as follows:
message AssetClaimHTLC {
HashMechanism hashMechanism = 1;
bytes hashPreimageBase64 = 2;
}
An HTLC claim simply needs to specify the secret preimage (hashPreimageBase64
) of the hash in the corresponding HTLC lock. It is encoded in Base64 for communication safety and portability. The hashMechanism
field assumes a value from the HashMechanism
enumeration specified earlier, and must match the hashMechanism
value in the AssetLockHTLC
object corresponding to this claim.
To allow interoperation modules to manage locked assets, the exchange that the counterparties have agreed on must be specified in a DLT-neutral structure for communication between application or contract and the interoperation module or across networks. Weaver supports atomic asset exchanges between two parties, so an agreement consists of two asset transfer commitments in opposite directions. Both commitments can take similar forms, which can be specified in a standard format. (Note: Weaver currently supports two-party two-asset exchanges. The structures described in this document can be generalized in the future when Weaver supports multi-party multi-asset exchanges.)
For a generic non-fungible asset, a commitment is specified in the following format.
message AssetExchangeAgreement {
string type = 1;
string id = 2;
string locker = 3;
string recipient = 4;
}
type
represents a category to which the non-fungible asset belongs, and which is well-known to the application that is managing the assetid
represents a unique ID of an asset instance of the type specified using thetype
fieldlocker
represents the present owner of the asset who is committing to giving this asset (and locking it for that purpose) in exchange for something elserecipient
represents the future owner of the asset to whomlocker
is making the commitment (and in whose favor the asset is being locked)
For a generic fungible asset, a commitment is specified in the following format.
message FungibleAssetExchangeAgreement {
string type = 1;
uint64 numUnits = 2;
string locker = 3;
string recipient = 4;
}
This is identical to the AssetExchangeAgreement
structure except that the numUnits
field replaces id
, because a fungible asset instance of a given type
is indistinguishable from another instance of the same type for the purpose of exchanges. Hence, the number of units of the fungible asset is what one party can commit to locking in another's favor as part of an atomic exchange agreement.
The portion of the HTLC contract that corresponds to a commitment described in the previous section needs to be represented in a DLT-neutral manner for event communication from interoperation modules to applications and across networks. This structure links a commitment to an action, namely a lock or a claim or an unlock.
The structure for a non-fungible asset exchanged in an HTLC is as follows.
message AssetContractHTLC {
string contractId = 1;
AssetExchangeAgreement agreement = 2;
AssetLockHTLC lock = 3;
AssetClaimHTLC claim = 4;
}
contractId
represents a unique ID on the ledger created by the interoperation module for this particular asset that is involved in an exchange, and agreement
is simply an instance of the structure described in the previous section. The other fields are populated depending on the nature of the action being communicated through this structure:
- Locking of an asset:
lock
field is populated andclaim
field is empty - Claiming of an asset:
lock
field is empty andclaim
field is populated - Unlocking of an asset: both
lock
andclaim
fields are empty
The structure for a fungible asset exchanged in an HTLC is as follows.
message FungibleAssetContractHTLC {
string contractId = 1;
FungibleAssetExchangeAgreement agreement = 2;
AssetLockHTLC lock = 3;
AssetClaimHTLC claim = 4;
}
The semantics are identical to those described above for AssetContractHTLC
except that the agreement
field is of type FungibleAssetExchangeAgreement
instead of AssetExchangeAgreement
.