Skip to content

Latest commit

 

History

History
111 lines (86 loc) · 8.56 KB

ovip-0006.md

File metadata and controls

111 lines (86 loc) · 8.56 KB
OVIP: 6
Title: Protocol messages cleanup
Author: Nika Gamkrelidze <nikoloz.gamkrelidze@lykke-business.ch>
Discussions-To: https://community.openvasp.org/#narrow/stream/11-protocol-.2F.20messages/topic/data.20duplicates
Status: Superseded
Type: Standard
Created: 2020-14-05
Superseded-By: ovip-0014

Abstract

The current specification of message protocol is designed to make each message of the session self-sufficient with regards to the details of the transaction. Each time new piece of data is gathered, it migrates to the next logical message. This has some advantages, however there are several reasons to remove all data duplicates, some of the most important being:

  • Simplify the messages and define specific notificational function for each of them.
  • Simplify development as it is not a good practice to duplicate data in this manner as it could lead to misunderstandings in case data turns out to be different from message to message. It also promotes good style.
  • Increase transport layer bandwidth since PoW resources are in direct proportion to the size of the message.

This OVIP is designed to address those issues.

Specification

General Description

I propose to remove all data duplicates, meaning that once the piece of data that isn't supposed to be changed during the session is sent and recieved by counterparty, it isn't included in any following messages. For example, once OV (originator VASP) provides the Originator full name and VAAN through the Transfer Request to the BV (beneficiary VASP), they won't be included in Transfer Reply, Transfer Dispatch or Transfer Confirmation messages. The proposed messages structure is described in the following paragraph (leaving Session Request and Session Reply as they are).

Proposed messages structure

Please note that Signature is deliberately removed from the tables as it is not a part of the protocol messages.

Public Key Format

The Secp256k1 public keys usage remains as specified in the original Whitepaper. However the Whitepaper does not specify the exact format. The public keys must be send in compressed form. That is it must be represented with exactly 33 bytes (66 characters) and is prefixed with '02' or '03'.

Transfer Request

Level 1 Level 2 Name Type Mult. Comment
Message msg 1..1
Message type type String 1..1 Fixed value '210'
Message identifier msgid Hex(128-bit) 1..1 Randomly set
Session identifier session Hex(128-bit) 1..1 As set in message 110
Message code code String 1..1 Currently not used, fixed value '1'
Originator see 7.11 for elements originator 1..1 Originator information
Beneficiary see 7.12 for elements beneficiary 1..1 Beneficiary information
Transfer transfer 1..1
Virtual asset type va String 1..1 See 7.5.3
Transfer type ttype Number 1..1 See 7.5.4
Amount amount Decimal 1..1 18 digits
Comment comment String 0..1

Transfer Reply

Level 1 Level 2 Name Type Mult. Comment
Message msg 1..1
Message type type String 1..1 Fixed value '250'
Message identifier msgid Hex(128-bit) 1..1 Randomly set
Session identifier session Hex(128-bit) 1..1 As set in message 110
Message code code String 1..1 See 7.6.3
Destinatoin destinationAddr String 1..1 Destination address
Comment comment String 0..1

Transfer Dispatch

Level 1 Level 2 Name Type Mult. Comment
Message msg 1..1
Message type type String 1..1 Fixed value '310'
Message identifier msgid Hex(128-bit) 1..1 Randomly set
Session identifier session Hex(128-bit) 1..1 As set in message 110
Message code code String 1..1 Currently not used, fixed value '1'
Transaction tx 1..1
Transaction identifier txid String 0..1 Format specific to virtual asset / transfer type
Transaction datetime datetime String 1..1 ISO 8601 (YYYY-MM-DDThh:mm:ssZ)
Sending address sendingadr String 0..1 Blockchain-specific format, sending address used for transactino (non-UTXO systems)
Comment comment String 0..1

Transfer Confirmation

Level 1 Level 2 Name Type Mult. Comment
Message msg 1..1
Message type type String 1..1 Fixed value '350'
Message identifier msgid Hex(128-bit) 1..1 Randomly set
Session identifier session Hex(128-bit) 1..1 As set in message 110
Message code code String 1..1 See 7.8.3
Comment comment String 0..1

Termination

Level 1 Level 2 Name Type Mult. Comment
Message msg 1..1
Message type type String 1..1 Fixed value '350'
Message identifier msgid Hex(128-bit) 1..1 Randomly set
Session identifier session Hex(128-bit) 1..1 As set in message 110
Message code code String 1..1 See 7.8.3
Comment comment String 0..1

Motivation

Simplicity - simplify the messages and define specific notificational function for each of them. Design - it is not a good practice to duplicate data in this manner as it could lead to misunderstandings in case data turns out to be different from message to message. Efficienty - reduced message size means reduced PoW resources.

Rationale

This is a simple and a straightforward solution that fixes all listed issues.