Connecting to a Block Explorer or External Node
Any implementation of the Mesh APIs must connect exclusively to a running blockchain node in the same Dockerfile. It is not ok to connect to some external service that preprocesses blockchain data or to a blockchain node running elsewhere.Populating Operation.Amount with Balance instead of Balance Changes
Some blockchains prefer to surface balance changes by returning the balance of an account after an operation is applied instead of returning how much an operation changes an account’s balance. In Mesh, theOperation.Amount.Value field should always be populated with the balance change (or “delta”), not the new balance of an account after an operation is applied (sometimes called “state streaming”).
If you would still like to surface the balance of an account after an operation is applied because it is expected by users of the blockchain you are implementing, you should add it to the Operation.Metadata field (along with any other useful metadata you want to return). It is not required to surface the balance of an account after an operation is applied.
Incorrect Example: Operation Amount is New Balance
In the following example, account A and account B each have 100 CURR prior to the transaction. In the transaction, A transfers 50 CURR to B.Operation.Amount.Value is populated with the new balance of each account instead of the balance change that occurs in the transaction.
Correct Example: Operation Amount is Balance Change
In the following example, account A and account B each have 100 CURR prior to the transaction. In the transaction, A transfers 50 CURR to B. In this example,Operation.Amount.Value is populated with the balance change of each account involved in the transaction instead of the new balance of each account involved in the transaction. The new balance of each account involved in the transaction is added to Operation.Metadata (optional).
Using Swagger/OpenAPI 2 Tooling
In 2017, the OpenAPI Initiative published the OpenAPI 3.0 standard as a successor to the Swagger Specification. The Swagger Specification was then renamed to OpenAPI 2.0. Not all tools developed for Swagger/OpenAPI 2.0 are compatible with this OpenAPI 3.0 format. Be sure to double check that any code you utilize to power your implementation is compatible. OpenAPI 3.0 Mesh API SpecMalformed Genesis Block
When populating the genesis block, it may be unclear which index and hash to use in the ParentBlockIdentifier. It is recommended to use the genesis BlockIdentifier for both block_identifier and parent_block_identifier.Incorrect Example: Negative Block Index
Incorrect Example: No ParentBlockIdentifier
Correct Example
Return Empty Value or Null for Optional Fields
When a field is optional and not populated, it should not be in the returned object. Otherwise, clients could attempt to interpret the returned value.Incorrect Example: SubAccountIdentifier Empty Address
Correct Example
Return Transactions to Fetch in Block Transactions
If transactions must be retrieved using the /block/transaction endpoint, they must be returned in other_transactions. Recall, this endpoint is used when the /block endpoint does not populate all transactions (it is optional).Incorrect Example: Populate Transactions
Correct Example
Incorrect Transaction Submission Response
Incorrect Status
The /construction/submit endpoint must only return a 200 status if the submitted transaction could be included in the mempool. If a submission could not be included (ex: invalid signature), it must return an error.Blocking on Submission
Any request to the /construction/submit endpoint must not block on the transaction being included in a block. It must return immediately with an indication of whether or not the transaction was included in the mempool. Handling transaction rebroadcast is a requirement placed on the client.Unretrievable AccountIdentifier
Any AccountIdentifier returned in a block could be used as an input to an /account/balance request. Ensure your Mesh Server can gracefully handle any request containing an AccountIdentifier found in a block.Populating Amount without Populating Account in an Operation
In Mesh, all operations that contain an amount must also contain a populated account (that can be retrieved using the/account/balance endpoint). “Dangling” balance changes (unattributable balance changes) can create insurmountable data or auditing challenges for some institutional blockchain users, which could prevent them from integrating with your implementation.
It is important to note that this does not mean that every operation with a populated account must have an amount. In fact, this is allowed and is a popular pattern to represent on-chain activity that does not involve a balance change (where operation metadata is populated with on-chain data).