Author

Topic: Making Hot Wallets Impossible to Steal - Now with 5 BTC bounty. (Read 3400 times)

sdp
sr. member
Activity: 470
Merit: 281
I can think of two ideas for this.  One is you need to start an ALT coin.   The other is a trusted party with a multi-sig address to ensure your Bitcoin address follows the rules you have laid down.

The ALT coins are experiments for features of crypto-currencies.  I have read up on the bitcoin protocol and there is no way to load the time into it.  The scripting language has no way of querying the time on the server.  Hypothetically, if you could query the time on a server you could make an address that requires it to be some timestamp in the future and have a program run on a server or two to generate new such addresses each time the timestamp constant would push the time into the future.  Being an alt coin this could be made a lot easier maybe associating a 'speed' with the 'coins' that the owner can set.

The other is with multisig addresses.  Being 'unstandard', it wont be relayed by the network according to the Wiki article. (https://en.bitcoin.it/wiki/Script).

sdp
legendary
Activity: 2618
Merit: 1007
Might work with the "oracle" style transactions, but then you (or your customers) trust the oracle again...

An oracle that just broadcasts the current UNIX timestamp should be fairly easy to deploy and validate I guess.
legendary
Activity: 3794
Merit: 1375
Armory Developer
Some sort of transaction script could get it to work I guess:

To clear coins on current address one needs to
1) either wait x blocks to send to any address
2) or send them instantly to a predefined "safe" address under your control

Since you have to clear the script requirements of an output to redeem its balance, you can thus enforce transaction emitters to add this "spend in X blocks" rule. Other txns would be turned down by the network, unless they point directly to the safe address listed in the output's script.

Once the new txn is hashed into a block, the signed coins will be available until hashed block number +X is achieved, which gives you time to emit a direct txn to the safe address if needs be. Kind of a delayed double spend I guess. Should be implementable in the main chain at limited cost, just a matter of activating some script opcodes I think.
legendary
Activity: 3416
Merit: 1912
The Concierge of Crypto
I don't see how this would work, as it seems similar to your earlier proposal. But good luck anyway.
sr. member
Activity: 367
Merit: 250
Find me at Bitrated
What about if i client is created that allows a user to only send bitcoins to one address, ever.  Then, you send the the second address to where it needs to go.  This way, an attacker would need access to both private keys, to steal the funds, since they wouldn't be able to take the funds from wallet A, even if accessed.

This is essential the function of an address that requires multiple private keys to spend.  A Vault Chain would attempt to do exactly this, but instead of just keeping the other key(s) on a computer, it would entrusting the other private key to a distributed network.  This network would enforce conditions that you applied when making that address. (agreed upon by consensus and buried with each successive block), they must be followed and cannot be bypassed by any practical means.  Thus, your "spend delay" or "forwarding" rules that you specify in the beginning would become concrete and unchangeable, even by someone who attempted to run a rogue program that told the network to act differently.  
sr. member
Activity: 367
Merit: 250
Find me at Bitrated
5 BTC is just a joke. You won't get such thing implemented in bitcoin even with 50,000 BTC bounty.

And there are free solutions to theft: cold storage.


This kind of criticism is narrow minded.  Cold storage is fine but don't assume it's applicable or preferable to every situation. 

Properly implemented, this would require exactly zero changes to the bitcoin protocol.  It would be a 3rd party network than anyone could run and mine from. 
It would inform users when their systems are compromised and give them a chance to counter an attack, no paper or extra hardware required. 
newbie
Activity: 56
Merit: 0
What about if i client is created that allows a user to only send bitcoins to one address, ever.  Then, you send the the second address to where it needs to go.  This way, an attacker would need access to both private keys, to steal the funds, since they wouldnt be able to take the funds from wallet A, even if accessed.
legendary
Activity: 1792
Merit: 1111
5 BTC is just a joke. You won't get such thing implemented in bitcoin even with 50,000 BTC bounty.

And there are free solutions to theft: cold storage.
sr. member
Activity: 367
Merit: 250
Find me at Bitrated
Cold storage and hardware wallets are fine, I am not here to knock them. I am looking to improve hot wallet security.

It occurred to me the other day that if I had some way of enforcing a "spend delay" on my bitcoins, they could never be stolen from my hot wallet during that delay.
I would need the ability to store bitcoins with the following rules:

  • Specify a delay time: X
  • If the last spend attempt is greater than X time ago, send the transaction.
  • If not, or if no previous attempt, create a new spend attempt.

These simple but powerful rules (if enforced) would mean I could spend my coins as I please anytime, simply suffering a small delay before they actually start getting sent out. If a thief accessed my private key and tried to spend my BTC they too would suffer the same delay. Yet, as long as I was watching (or had some program to watch for me) I'd be able to redirect the transaction back to a destination of my choice!  In order to avoid a game of endlessly redirecting transactions between myself and a thief, the wallet could also include instructions for a fail-safe address.  

But how on earth could these rules be enforced to the most absolute degree possible? It's not good enough to simply design a wallet with these constraints, because a thief could design another wallet to simply bypass these rules.  How could I make sure that everyone absolutely had to follow them?

Imagine a special wallet program that contributes to and communicates with another kind of blockchain. It does not replace the bitcoin blockchain, but it moves in parallel to it.  It would be a peer to peer decentralized network that stores transaction attempts, private keys, and the specific delays made by their owners. It could ultimately forward to the bitcoin network to create transactions, but only after the specified waiting conditions are satisfied.

Creating an address in a Vault Wallet creates a 2-of-2 multisignature address that requires both private keys to spend. Within minutes it is confirmed and your rules are eternally bound to this address.  
You hold one private key in your wallet, encrypted by a password (similar to the bitcoin-qt).  The other private key is held by the vault chain itself, encrypted until its conditions are satisfied. These are the rules you created at the beginning, and once logged in the vault chain they are buried by consensus blocks and forever granted primacy so no one can supersede or overwrite your instructions.  

When you go to spend your coins, your private key is only the first half of the spend equation. The coins go into limbo in the vault chain as a spend attempt is registered. They must wait there until your X delay is over.  If the destination of the coins changes with another spend attempt then the waiting time reset and overwrite the first attempt.  Once the timer is up and enough confirmation blocks have been created, the Vault chain decrypts the other necessary private key and immediately creates a transaction to spend in the bitcoin blockchain.  A receiving address would see zero activity until this process is completed, so this is not a way to chargeback or revoke payment, only delay the spending of the coins on your end for security purposes.  Once actually sent in the bitcoin blockchain, the transaction is irreversible.  

Since the keys are split up and one of them isn't even on my computer, there is no point in trying to hack my password.
Since the vault-chain is trust-less and decentralized and requires consensus in order to spend the transaction, there is no point in trying to run a rogue client with its own rules that attempts to ignore the delays.  

Try to spend my coins and I'd know about it right away, and I can stop you. I'd fail-safe them right into a paper wallet. Think about that for a second. Imagine being alerted that your coins are being stolen before they're gone for good, and imagine being able to do something about it!

And how is it all supported? With tiny extra transaction fees for those that want the security. There are blocks to be found, transaction attempts to be logged, bitcoins to be earned, and miners to be paid. ASIC miners can contribute to both chains simultaneously, and their power would continue to find blocks in each chain and secure both of these networks.

What I'm imagining requires quite a bit of creative thinking to implement properly, but it results in rules that are very hard to circumvent and a hot wallet with very hard to steal bitcoins. I want to give people the power to put a delayed-fuse on their coins. All of these changes would be user-initiated, optional, and would require zero changes to the bitcoin protocol itself.  A Vault wallet is simply software, no extra hardware or paper required. Please poke holes in this idea, I'd love to heard your feedback.  (I am also aware of Oracles, but they are not quite trust-less enough in my opinion)

I am willing to add a 5BTC bounty to this idea if it can be successfully implemented and a Core-Dev confirms it performs as described.  
Jump to: