Pages:
Author

Topic: Experiment: A signed offer to buy BTC that one may accept by sending the BTC (Read 2457 times)

vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
I have updated GitHub and my alpha version with my initial draft of a real 3-party escrow generator that actually works.

It is NOT COMPLETE... but from the looks of it, it DOES WORK.

NOT COMPLETE refers to me not having added functionality to save or print the escrow codes, but you can still copy them off the clipboard and experiment with them.  There are save and print buttons that do nothing.  It's good enough to play with for 0.01 BTC, but do not use this for any real amounts of money!

https://casascius.com/btcaddress-alpha.zip

Simply run, and click: Tools -> Escrow Tools

The instructions are in there, plus three screens to let you play any of three escrow roles: Payer, Payee, and Escrow Agent, and then finally a redemption screen that lets you cash out (get the private key) when an escrow is released in your favor.

As an Escrow Agent, you can generate an Escrow Invitation to give to two others.  (You get two codes, and give only one to each)  They can do a transaction and you'll be the agent.

As a Payee, you generate a Payment Invitation and a bitcoin address after having been given an Escrow Invitation by somebody else.  You give the Payment Invitation and the bitcoin address to the person that should be paying you bitcoins.

As a Payer, you can confirm that a Bitcoin address is really under control of an escrow arrangement, by pasting the Escrow Invitation and Payment Invitation and verifying you get the same address.

In order to release the escrow, you simply give all the invitations you've got to the person you're releasing to.  The person with all 3 pieces of the invitation gets the private key and the bitcoins!
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
Courts? It's an escrow service...you are the judge Smiley

If it's for a serious amount - like $50k or $500k for example - it most definitely doesn't work that way.  If I ran an escrow service and sent a large amount of funds the wrong way for the unlawful reason of my choice, I would expect to be sued and my actions scrutinized by a court.  Breach of the written contract would be the grounds for bringing it to court.

That's not a bad thing: having a backstop to ensure there's recourse when bad things happen adds confidence that people desire in order to participate in the market.  There are MANY people who would buy lots of BTC today if it weren't for having to wire money to Japan and worry that one of many things could happen with nothing they could do about it.

For a $20 buy-in, or someone trading some xbox games, then yeah sure, I'm the judge.  But this escrow solution is meant to evolve into something viable for the high rollers as well.

donator
Activity: 1466
Merit: 1048
I outlived my lifetime membership:)
And a good web front end will make it all human readable and seamless.
donator
Activity: 1466
Merit: 1048
I outlived my lifetime membership:)
I think this is your next business...why not?

Mainly that most courts don't recognize encoded binary numbers in the block chain as a valid form of contract.  My proposal is meant to benefit normal people, so it will have to be that they agree to a normal-looking contract written in plain English.  The blockchain just provides an objective and non-tamperable means for determining that an execution has or has not occurred - something that adds a meaningful benefit.  The PGP software already does a good enough job for establishing that someone signed some text and needs no further improvement.

Courts? It's an escrow service...you are the judge Smiley
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
I think this is your next business...why not?

Mainly that most courts don't recognize encoded binary numbers in the block chain as a valid form of contract.  My proposal is meant to benefit normal people, so it will have to be that they agree to a normal-looking contract written in plain English.  The blockchain just provides an objective and non-tamperable means for determining that an execution has or has not occurred - something that adds a meaningful benefit.  The PGP software already does a good enough job for establishing that someone signed some text and needs no further improvement.
donator
Activity: 1466
Merit: 1048
I outlived my lifetime membership:)
Mike -- another excellent idea. I like where you are heading with this. Any way to encode in the block chain the the price and currency of the completed trade? This way reading the blockchain could also tell you the ticker price.

 You could imagine other forms of communication and time stamping using the blockchain (ie, sending binary messages in the Bitcoin amount...spy's could communicate this way, for example)

Not really - remember I am not doing any magic with the block chain - I am simply assigning a meaning to the existence of a normal transaction in the block chain using plain English language... a transaction that gets put there by a user using the software of their choice.

If I do something with escrow, this too will not be block chain magic.  Rather, it will simply be math magic, where someone pays an address nobody knows the private key to, and people release the funds by releasing mathematical clues that enable the right person to calculate the private key and take the funds with the software of their choice.

Well, you could send a series of transactions to the address in binary code describing the proposed transaction...then 100% of your communicating could be done via the blockchain itself (and you wouldn't have to post on forums the details of the transactions).

Escrow could work like this: joe registers with Casascius escrow ltd and tells you his credit card info and a Bitcoin address. Bob registers with as well and tells you his Bitcoin address...when joe wants to make an offer to sell, he uses the Casascius offer encoder to send himself some Bitcoins as a string of 1's and 0's that fully describe the transaction (serving as proof of the terms).  Bob likes those terms and sends the coins.  The "Casascius insta-p2p distributed exchange block chain analyzer / trade detector" notices that bob kept up his half of the bargain and issues a charge (according to the terms) to joes credit card.

I think this is your next business...why not?
legendary
Activity: 3038
Merit: 1032
RIP Mommy
c. I believe that writing an actual agreement using language with legal meaning and signing it myself has greater enforceability than putting an unsigned line in the OTC order book.

Iirc you can only put lines in the orderbook if you're id'd with gribble, which means everything in there is actually signed.

True, and effectively true.
hero member
Activity: 756
Merit: 522
a. I'm using the blockchain to make an objective indication as to whether an offer still exists, whether it's been satisfied, by whom, and when.  My method automatically cancels the order when filled, and picks a winner if two people accept it at the same time, automatically and objectively.

This is true, and I think it has its advantages.

b. My offer is much easier to accept.  By signifying that sending bitcoins accepts my order, one does not need to bother with getting in contact with me and hoping I am able to respond in a timeframe that works for them.  They don't need to do anything other than determining that I'm trustworthy enough to perform as agreed, and then send some bitcoins.

This is true, it does resolve that part of administrative problems, but it creates a whole new set: someone needs to keep track of all the offers from all the parties, eventually this would have to somehow be built into a database, which rather than scouring the web for signed documents would more reasonably be pushed into by the very party offering. Which would make it a sort of OTC-OB.

c. I believe that writing an actual agreement using language with legal meaning and signing it myself has greater enforceability than putting an unsigned line in the OTC order book.

Iirc you can only put lines in the orderbook if you're id'd with gribble, which means everything in there is actually signed.
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
Mike -- another excellent idea. I like where you are heading with this. Any way to encode in the block chain the the price and currency of the completed trade? This way reading the blockchain could also tell you the ticker price.

 You could imagine other forms of communication and time stamping using the blockchain (ie, sending binary messages in the Bitcoin amount...spy's could communicate this way, for example)

Not really - remember I am not doing any magic with the block chain - I am simply assigning a meaning to the existence of a normal transaction in the block chain using plain English language... a transaction that gets put there by a user using the software of their choice.

If I do something with escrow, this too will not be block chain magic.  Rather, it will simply be math magic, where someone pays an address nobody knows the private key to, and people release the funds by releasing mathematical clues that enable the right person to calculate the private key and take the funds with the software of their choice.
donator
Activity: 1466
Merit: 1048
I outlived my lifetime membership:)
Mike -- another excellent idea. I like where you are heading with this. Any way to encode in the block chain the the price and currency of the completed trade? This way reading the blockchain could also tell you the ticker price.

 You could imagine other forms of communication and time stamping using the blockchain (ie, sending binary messages in the Bitcoin amount...spy's could communicate this way, for example)
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
I am interested if you come up with an escrow function.

I do see this as something that would be good to have several Bitcoin escrow companies that compete and provide the trust needed.

That's precisely where I'm going with this...
legendary
Activity: 3598
Merit: 2386
Viva Ut Vivas
So what stops someone from putting out such an offer and then not paying the cash?

It still comes down to the trust factor.

I am interested if you come up with an escrow function.

I do see this as something that would be good to have several Bitcoin escrow companies that compete and provide the trust needed.
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
Basically you're slowly discovering/moving towards the OTC order book. http://bitcoin-otc.com/vieworderbook.php

Other than:

1. I'm not sure what there is to discover given that I have trading history on the OTC order book almost two years old.
2. I think what I'm proposing has some useful differences:
 a. I'm using the blockchain to make an objective indication as to whether an offer still exists, whether it's been satisfied, by whom, and when.  My method automatically cancels the order when filled, and picks a winner if two people accept it at the same time, automatically and objectively.
 b. My offer is much easier to accept.  By signifying that sending bitcoins accepts my order, one does not need to bother with getting in contact with me and hoping I am able to respond in a timeframe that works for them.  They don't need to do anything other than determining that I'm trustworthy enough to perform as agreed, and then send some bitcoins.
 c. I believe that writing an actual agreement using language with legal meaning and signing it myself has greater enforceability than putting an unsigned line in the OTC order book.
hero member
Activity: 756
Merit: 522
You bring up some excellent points.

Not only could I offer a fluctuating rate as you point out, I could also include terms that make my offer contingent on a stable price.  If I make an offer based on a MtGox price, I could say that my offer is only valid if accepted while 24 hours of substantially reliable MtGox data is available and the MtGox high over the last 24 hours is no greater than 105% of the low over the same time period (and that otherwise, I issue a refund).  The glitches and gotchas are still present if MtGox is having issues of their own, but their impact is severely limited if an acceptance isn't allowed if it isn't clear that none of that is happening.

One of the things that doing orders like this would accomplish is to add major liquidity to the bitcoin-wide order book, especially if people are willing to put out fixed-price orders looking for dips and spikes in the price without having to leave money in exchanges to do so.  Fixed price orders wouldn't have so much need to depend on a stable price, and if escrow changed the trading landscape significantly, it would represent a good way for lots of non-technical people to get into Bitcoin using paper wallets "if the price drops a couple bucks" as I always seem to hear people say.

Basically you're slowly discovering/moving towards the OTC order book. http://bitcoin-otc.com/vieworderbook.php
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
I am conducting an experiment that I am hoping will generate some discussion about the way bitcoins are traded.

On the occasions that I put a buy offer on #bitcoin-otc marketplace I use the "{mtgoxlast}" macro substitution so that the exchange rate will fluctuate with the market rate.

Though you had put out a fixed exchange rate, this fluctuating rate could still be offered.  This is because the mtgox trading history is publicly available and has a timestamp (i.e., can be independently verified).

But I hate seeing a third-party data source being relied on in ways it wasn't designed to be.  There's no service agreement from blockchain.info that the timestamp displayed won't change (e.g., if had to re-index the database perhaps).   And the quote data from Mt. Gox has historically not been pure as well (trades getting cancelled).  

But these things occur with other trading systems and agreements so there's ways to deal with them, including acknowledging there is the risk someone will sell to you during a trade spike way above what ends up being the VWAP or similar less-volatile price method.

You bring up some excellent points.

Not only could I offer a fluctuating rate as you point out, I could also include terms that make my offer contingent on a stable price.  If I make an offer based on a MtGox price, I could say that my offer is only valid if accepted while 24 hours of substantially reliable MtGox data is available and the MtGox high over the last 24 hours is no greater than 105% of the low over the same time period (and that otherwise, I issue a refund).  The glitches and gotchas are still present if MtGox is having issues of their own, but their impact is severely limited if an acceptance isn't allowed if it isn't clear that none of that is happening.

One of the things that doing orders like this would accomplish is to add major liquidity to the bitcoin-wide order book, especially if people are willing to put out fixed-price orders looking for dips and spikes in the price without having to leave money in exchanges to do so.  Fixed price orders wouldn't have so much need to depend on a stable price, and if escrow changed the trading landscape significantly, it would represent a good way for lots of non-technical people to get into Bitcoin using paper wallets "if the price drops a couple bucks" as I always seem to hear people say.
legendary
Activity: 2506
Merit: 1010
I am conducting an experiment that I am hoping will generate some discussion about the way bitcoins are traded.

On the occasions that I put a buy offer on #bitcoin-otc marketplace I use the "{mtgoxlast}" macro substitution so that the exchange rate will fluctuate with the market rate.

Though you had put out a fixed exchange rate, this fluctuating rate could still be offered.  This is because the mtgox trading history is publicly available and has a timestamp (i.e., can be independently verified).

But I hate seeing a third-party data source being relied on in ways it wasn't designed to be.  There's no service agreement from blockchain.info that the timestamp displayed won't change (e.g., if had to re-index the database perhaps).   And the quote data from Mt. Gox has historically not been pure as well (trades getting cancelled).  

But these things occur with other trading systems and agreements so there's ways to deal with them, including acknowledging there is the risk someone will sell to you during a trade spike way above what ends up being the VWAP or similar less-volatile price method.
hero member
Activity: 756
Merit: 522
Limiting to first person only should work in the sense that pretty much anyone can check in the blockchain. There's some potential for trouble if transactions haven't propagated tho', but yeah, the "refund or execute" policy covers nicely.
legendary
Activity: 1246
Merit: 1016
Strength in numbers
I just glanced at the thread. This makes it all good imo:

4. The first person who pays the above address (as determined by the BlockChain.info first-seen
timestamp) is the person whose Bitcoins I am buying.  If more than one person accepts the offer,
I reserve the right to choose to either give a refund or to perform the same transaction with the
additional parties.
vip
Activity: 1386
Merit: 1140
The Casascius 1oz 10BTC Silver Round (w/ Gold B)
Blockchain.info records first seen time, and short of that, they go into a block in a certain order, how ever the miner put it there.  That may not be absolutely correct in terms of time, but will work as a last resort for determining a winner.

Realistically I expect blockchain.info's first seen time will be good enough.
Pages:
Jump to: