Commit Graph

3658 Commits

Author SHA1 Message Date
Tadge Dryja
10bcaeccc8 Merge branch 'uspvdev'
Conflicts:
	uspv/txstore.go
2016-02-03 00:16:27 -08:00
Tadge Dryja
624e776987 add shell spv testing mode
To try uspv, do ./lnd -spv
The remote node is hardcoded in shell.go.  If you aren't
running a full node on localhost, specify where to connect to.
Nearby nodes will be much faster but random testnet nodes on the
internet should also work.
2016-02-02 23:37:29 -08:00
Tadge Dryja
d4f7fd4504 Merge branch 'master' into elkremdev 2016-02-02 20:46:38 -08:00
Tadge Dryja
2f9fc87636 fix sync, remove sum from TxStore
Synchronization now seems to work well even with the rapid fire
many inv-block messages that I'm seeing often on testnet3.  I'm
not 100% sure measuring the len() of a buffered channel is safe
but it seems to work fine.
Got rid of 'sum' in the TxStore; can be computed from GetAllUtxos()
Might want to merge SCon and TxStore since there's not much going
on in TxStore any more...
2016-02-02 19:04:03 -08:00
Tadge Dryja
a9cf239ec3 fix readme, better state machine for sync 2016-02-02 17:14:13 -08:00
Tadge Dryja
4513d77216 add readme documentation 2016-02-02 02:19:26 -08:00
Tadge Dryja
ead7108b98 add findpre and docs about nLockTime hints 2016-02-02 01:18:59 -08:00
Tadge Dryja
e56b1993fc move ser/des from utxodb to txstore 2016-02-01 19:03:01 -08:00
Tadge Dryja
f231113b90 some cleanup, store spent txs
pretty much everything is db based now.  Still some concurrency issues
when multiple block inv messages come in (which they do) where
we used len(mBlockQueue) as a check for being synched up, which doesn't
quite work.  Find a better way to do that...
2016-01-31 15:02:38 -08:00
Tadge Dryja
cf01e02d64 fix dumb loop break error
break was outside the if bytes.Equal {}, oops.  only checked first output.
Works now.  Concurrency also seems OK but need to test more.
2016-01-31 02:08:39 -08:00
Tadge Dryja
3b774ef361 move tx ingest to all db, fixes sync
Sync was non-deterministic because ingest was concurrent.
Now receiving tx messages is blocking, but that's OK, they really need
to be in the right order because the whole point of bitcoin is to put
txs in the right order.  SendTx still has a problem that the change address
may not be recognized by ingest.
2016-01-31 01:05:31 -08:00
Tadge Dryja
83dff432b1 mutex helps, still some sequence errors from mblocks
Seems that merkle blocks can return txs out of sequence, unlike
regular blocks which have to be in temporal/sequential order.
so maybe want to absorb ALL txs from mblock, then expel all?
2016-01-29 00:48:14 -08:00
Tadge Dryja
4cd9087f9f problems with concurrent disk access (header file)
maybe add mutexes or something
2016-01-29 00:40:52 -08:00
Tadge Dryja
5c2bbff3eb fix more sync problems. Seems to work OK
One edge case is with long chains of unconfirmed txs.
All self-signed txs are stored, but not used to negate false incoming utxos yet.
2016-01-28 22:31:05 -08:00
Tadge Dryja
6ef9dc3d4a not saying it works, but it works better
redo how db and header sync works, somewhat simpler but a little
recursve-ish.  There is still an off by 1 error somewhere with headers.
2016-01-28 19:35:49 -08:00
Tadge Dryja
d9afd623eb new stxo struct and more db methods
I'm getting away from having both in-ram and on-disk stores for the transaction store data.
it should all be on disk, it's safer that way.  It might be slower but this will not
process many txs / second anyway.
2016-01-27 01:24:16 -08:00
Tadge Dryja
851d3533e5 deals with incoming blocks and txs
gets stuck on reorgs though, until program is restarted
2016-01-22 17:15:56 -08:00
Tadge Dryja
5a7c04bdb5 incoming invs and tx signing
when we get inv messages, txs are easy but blocks are a little tricky
block heigh synchronization is done via os' file system
signing is a bit inelegant (searches through inputs for pkscript matches)
but fast enough in practice
2016-01-22 16:04:27 -08:00
Tadge Dryja
01c35e62ab check for already known txs (due to reorg?) 2016-01-22 01:41:08 -08:00
Tadge Dryja
fbc424492d update filters as txs come in; missed some before 2016-01-21 21:50:42 -08:00
Tadge Dryja
fc100921e8 add pushtx, and outpoint comparitor 2016-01-21 17:59:50 -08:00
Tadge Dryja
9215c18113 keep track of addresses, check incoming txs for full pkscript match 2016-01-21 01:04:45 -08:00
Tadge Dryja
b7a2c46ea6 remove storage of pkscript; don't need it. 2016-01-20 22:57:05 -08:00
Tadge Dryja
278971936f pass network parameters as function arg 2016-01-20 21:27:58 -08:00
Tadge Dryja
73bbb29026 add keyfileio to manage private key storage on disk 2016-01-20 21:08:05 -08:00
Tadge Dryja
1f40c7214e good enough storage of spent txs 2016-01-20 01:23:47 -08:00
Tadge Dryja
29d0c0cc6f fix bolt slices. db read / write works.
also switch heights from uint32 to int32, which I guess is what they use.
Makes this thing last 2 billion blocks shorter.  If we get past uint32 time.
2016-01-19 23:40:04 -08:00
Tadge Dryja
0b5daa9b2b add utxodb for on disk storage of transactions. 2016-01-19 20:02:18 -08:00
Tadge Dryja
58c8d32ac5 add a height channel to keep track of incoming merkleblocks 2016-01-19 14:23:18 -08:00
Tadge Dryja
ece5dc9d2d add txtostring 2016-01-19 11:59:01 -08:00
Tadge Dryja
709b8a05cd oh right, another fun thing I forgot about
When there's only the coinbase tx, the merkle root = the coinbase txid.
Needless complication in bitcoin == job security?
2016-01-19 10:59:13 -08:00
Tadge Dryja
7dbf4a4a4f update uspv, add function for height from header
still a bunch of problems getting utxo sets
2016-01-19 01:33:58 -08:00
Tadge Dryja
24afe237db Merge branch 'master' into uspvdev 2016-01-19 00:31:09 -08:00
Tadge Dryja
dd2c2274c8 export fields from lnid and add deserialization method 2016-01-19 00:05:02 -08:00
Tadge Dryja
229e34b326 make SPVCon version agnostic 2016-01-18 23:43:41 -08:00
Tadge Dryja
3fecd67920 cycle sender / receiver to bytes and back 2016-01-18 23:28:14 -08:00
Tadge Dryja
c1212d1369 off by 1 fix, a little more serdes check 2016-01-18 21:26:28 -08:00
Tadge Dryja
2b66c234c6 actually remove current from sender and calc on the fly for addnext 2016-01-18 21:08:16 -08:00
Tadge Dryja
2301af5615 remove "current" from receiver, add very simple serialization test 2016-01-18 21:04:53 -08:00
Tadge Dryja
d4a31d4127 add initial unit test for elkrem send / receive 2016-01-18 20:43:02 -08:00
Tadge Dryja
6f8cf3d75a remove node serdes, pretty sure it's redundant 2016-01-18 20:17:15 -08:00
Tadge Dryja
a3f65bb4ad serialization / deserialization of elkrem built, untested 2016-01-18 20:15:51 -08:00
Tadge Dryja
fc5e58ad7d add serdes (start) for elkrem 2016-01-18 18:24:34 -08:00
Tadge Dryja
26d9ae7f2b add tcp dial bypass for pbx 2016-01-17 22:32:19 -08:00
Olaoluwa Osuntokun
10835c6498 README: remove build error disclaimer 2016-01-17 21:53:14 -08:00
Olaoluwa Osuntokun
8e54e0c339 lnstate: fix compile errors 2016-01-17 21:51:58 -08:00
Olaoluwa Osuntokun
872db633df uspv: file compile error 2016-01-17 21:51:58 -08:00
Tadge Dryja
1f11e011de Merge pull request #3 from PaulCapestany/master
Make lnd go-gettable, add install instructions to readme
2016-01-17 20:59:13 -08:00
Paul Capestany
f24d9af85a Fix capitalization so go get instructions work properly 2016-01-17 19:59:54 -08:00
Paul Capestany
80b20bd039 Update README with general build instructions 2016-01-17 19:53:50 -08:00