Why Go Full Ricardian - the digital contract

in #ricardian7 years ago (edited)

In the last post I outlined what it took to create a document that was both human readable and machine readable, good enough for a legal contract, and also good enough to support an accounting model like cryptocurrency. Now that we have that contract that both the computer and the human can read, and agree upon, it remains to communicate it.

The Ricardian Contract - Bow Tie model

Most prose contracts are written, emailed, argued about & redlined & mangled, eventually to be signed and then confined to the bottom of a drawer. To be forgotten, which is perhaps an odd way to treat something so central to the nature of business and agreement.

Not so a digital contract! As we have injected into the contract the key parameters that make this contract special, we can now actually use the contract in a transactional way: to communicate what a payment, trade or other transaction is.

To do this we have to use a hashing trick from cryptography. We take the hash (“cryptographic message digest”) of the above document and embed it in all the transactions that refer to that contract. This means that the transactions ‘know’ about the contract in some sense.

For example, if the transaction were a payment from Alice to Bob of say dollars, then the contract would describe the dollars. To see how this works, consider this payment where Alice pays Bob:

{Alice, Bob, 100, dollars}

This record might maybe describe a transaction in some contexts, but it isn’t really good enough in a complicated, global world - I might send you Hong Kong dollars, and you might be expecting Singapore dollars. Oops! Also, that number that’s in the record - is that 100 referring to 100 dollars or 1.00 dollars being 100 cents or a 100 satoshi-dollars which might be about 0.000001 dollars each?

The computer can’t really tell, and if the computer, as your digital angel, can’t know then you can’t know. Oh, yes, databases and all that but they are just honeytraps for insider frauds and viruses and other horrors. If databases could do payments for everyone, blockchain wouldn’t have been invented.

Let’s now see how we do this in a Ricardian fashion. I pay you:

{Alice, Bob, 10000, ABC1234IANG66DOLLAR911911HASH}

is actually less intelligible than the above. Which is an advantage because now your client software has to fix its and your information misery.

What happens is this. Your client software, your digital angel, has to take that horrible hash thing ABC1234IANG66DOLLAR911911HASH and go look up a document that matches the hash.

Because it’s a hash, there is only one document, and that document self-proves itself as being the document of the hash - take that, you insider scummers! And, assuming that the document is a contract as described in the last post, then we have some simple parameters that can be extracted out of it. With these parameters being easily recoverable using our above markup and parameter techniques, your digital angel can now tell you:

Bob, you’ve been paid $100.00 in IangBux by Alice. We know this currency and we liked it before. This takes your balance to $120.00 and your savings plan is on track!

All the context of the contract is now at the hands of the client software, instantly and without confusion.

Why the contract needs to be digitised

This becomes much clearer in any large scale world. An ISDA Swaps contract can run to 300 pages long, and can fill drawers and consume hours of time - digitisation allows those drawers to be emptied, but also gives us instant and permanent access to everything in the contract of repetitive value! Permanency is a big win too - if you know anyone who is older than 70, ask them what the contract of their favourite currency was - chances are they will talk wistfully about the gold window and how the bank promised to pay the bearer 1 pound of sterling silver and other such other stories. Unfortunately for the Bank of England and the Federal Reserve, they didn’t have cryptography available to them in those days, and couldn’t lock their contracts down with hashes. Inevitably, without such discipline, the contract slipped away, and we’re left with legend.

What is the contract today for the US dollar? If it was in Ricardian form, you would know, precisely. As it is not, the “contract” is little more than a marketing slogan that is changed as and when the Federal Reserve needs another brand makeover.

Brands are useful, and the state can get away with just the one brand. But in the open contractual space of blockchain, we need contractual certainty for digital issuances, not least because there are so many issuances - ERC-20s! ICOs! and those are the polite terms - that these days it is hard to tell what any of them mean. And by using the approach mentioned earlier we gain some much-appreciated precision: prose for legals, parameters for variability, and hashes to lock the precision into an accounting system.

prose,params,code

(Soft note - this concept of {prose, params and code} is further explored in Sum of all Chains but it's too much for one post.)

The Ricardian Constitution

If the contract were a constitution for a chain, this would bring the benefit that the blockchain’s code could extract the parameters directly. A chain could follow its inflation rate, simply by reading what the users had agreed in the constitution. Then the code would follow suit by looking up the constitution and extracting out the number directly - no more hard coding, no more duplication, no more cumbersome alignment of code with prose.

The hash of the Constitution could also appear in key instructions and would therefore signify - by custom - that the initiator of that transaction is agreeing to the constitution. For example, if the CREATE-NEW-ACCOUNT instruction included the hash, this enters that account to the Constitution, which in turn defines the Community: all who have accounts are all under the same Constitution and are all in the Community.

In sum, using the Ricardian form brings specific advantages to a community blockchain:

  1. The hash mechanism means it is impossible to be uncertain about which document we are talking about, which removes large areas of confusion:
    • In selecting its constitution, the community votes over a hash of that constitution, which points to the precise document
    • The transactions on the blockchain lock into a hash, so they are bound to the correct and useful document
  2. The prose of the contract means that we can use all the fine tradition of law to express our desired agreement, and to explain and interpret it when needed - which removes a lot of uncertainties and makes our business that much clearer.
    • Note that this doesn’t change the way the document is created - you can use lawyers to draft your contract, or you can write it yourself.
    • Plain writing is preferred however it is done!.
  3. The parameters mean we can not only demarcate key points for the reader, we can communicate them to the computer too.
    • The name, initial quantity & inflation are now parameters within our contract, which makes it easy to colour them for effect for the human reader, and feed them into the program for the computer ‘reader’.
    • The display parameters allow the program to handle symbols and decimals of all forms.
  4. It is now relatively easy for alternative chains to build a different business proposition. The parameters signpost what they have to change when starting up their chain.
  5. There’s only one document which is the source of truth
    • No more separate parameter files, no more discoordination
    • No more hard coding!
Sort:  

I'm three weeks late to this post, but after reading it I'm just dying to see an example EOS Constitution proposal.

super interesting and easy to follow, upvoted. i love to read stuff like this on my sundays! :)

interesting reading

Hi, Ian, great article, and I am inspired by your ideas regarding digital contract and learned a lot. Thanks.

I want to introduce your idea through translating your articles into Chinese, and seek your permission to post this translation on https://www.bihu.com, which is kind of the Chinese version of steemit. I might receive some Token generated by this project due to the translation work.

I will put author, title and link at the top and encourage people to visit the original article here, and clap for it.

Thanks a lot. and please let me know if it is ok.

You can reply to me directly here, or reach me via email: [email protected]

Thanks a lot.

Of course, translations are most welcome - however they are done.