Go to file
Jae Kwon 5d994944c6 Refactor Application to Application & AppContext 2015-11-29 14:22:30 -08:00
cmd Refactor Application to Application & AppContext 2015-11-29 14:22:30 -08:00
example Refactor Application to Application & AppContext 2015-11-29 14:22:30 -08:00
server Refactor Application to Application & AppContext 2015-11-29 14:22:30 -08:00
types Refactor Application to Application & AppContext 2015-11-29 14:22:30 -08:00
.gitignore Add .gitignore file 2015-11-27 09:57:08 -08:00
LICENSE.md Add Apache2.0 license 2015-11-27 08:51:49 -08:00
README.md Replace SetEventsMode with SetOption 2015-11-27 10:14:46 -08:00

README.md

Tendermint Streaming Protocol (TMSP)

TMSP is a socket protocol, which means applications can be written in any programming language. TMSP is an asynchronous streaming protocol: message responses are written back asynchronously to the platform.

Applications must be deterministic.

Message types

AppendTx

  • Arguments:
    • TxBytes ([]byte)
  • Returns:
    • RetCode (int8)
  • Usage:
    Append and run a transaction. The transaction may or may not be final.

GetHash

  • Returns:
    • RetCode (int8)
    • Hash ([]byte)
  • Usage:
    Return a Merkle root hash of the application state

Commit

  • Returns:
    • RetCode (int8)
  • Usage:
    Finalize all appended transactions

Rollback

  • Returns:
    • RetCode (int8)
  • Usage:
    Roll back to the last commit

AddListener

  • Arguments:
    • EventKey (string)
  • Returns:
    • RetCode (int8)
  • Usage:
    Add event listener callback for events with given key.

RemoveListener

  • Arguments:
    • EventKey (string)
  • Returns:
    • RetCode (int8)
  • Usage:
    Remove event listener callback for events with given key.

Flush

  • Usage:
    Flush the response queue. Applications that implement types.Application need not implement this message -- it's handled by the project.

Info

  • Returns:
    • Data ([]string)
  • Usage:
    Return an array of strings about the application state. Application specific.

SetOption

  • Arguments:
    • Key (string)
    • Value (string)
  • Returns:
    • RetCode (int8)
  • Usage:
    Set application options. E.g. Key="mode", Value="mempool" for a mempool connection, or Key="mode", Value="consensus" for a consensus connection. Other options are application specific.