Commit graph

3355 commits

Author SHA1 Message Date
Roy Lee
4cccf98786 [lbry] blockchain: change the difficulty adjustment algorithm.
adjusted := target + (actual - target) / 8

  max := target + (target / 2)
  min := target - (target / 8)

  if adjusted > max {
    adjusted = max
  } else if adj < min {
    adjusted = min
  }

  diffculty := lastDifficulty * adjusted / target
2021-10-18 16:36:42 -07:00
Roy Lee
c48856b510 [lbry] blockchain: make UTXO in Genesis block spendable 2021-10-18 16:36:42 -07:00
Roy Lee
eba47240c1 [lbry] blockchain, txscript: change maxScriptElementSize from 520 t0 20,000 bytes 2021-10-18 16:36:42 -07:00
Roy Lee
e42ee8a123 [lbry] blockchain, wire: verify blockheaders using LBRY PoW 2021-10-18 16:36:42 -07:00
Roy Lee
b8ac55a63c [lbry] blockchain: change max block size to 2,000,000 2021-10-18 16:36:42 -07:00
Roy Lee
559cdd6c0d [lbry] wire: update protocol NetIDs 2021-10-18 16:36:42 -07:00
Roy Lee
7507550503 [lbry] chaincfg: update chainparams for LBRY chain
Co-authored-by: Brannon King <countprimes@gmail.com>
Co-authored-by: Alex Grintsvayg <grin@lbry.com>
2021-10-18 16:36:42 -07:00
Roy Lee
876a9c08f3 [lbry] chaincfg: setup genisis blocks 2021-10-18 16:36:42 -07:00
Roy Lee
e90dc4231f [lbry] chaincfg: implement LBRY PoW Hash 2021-10-18 16:36:42 -07:00
Roy Lee
e6fb242e93 [lbry] add ClaimTrie to Block Header 2021-10-18 16:36:42 -07:00
Brannon King
605eae2b8b profile: support fgprof (flame graph) 2021-10-18 16:36:42 -07:00
Brannon King
682019d156 wire: optimize binaryFreeList handling 2021-10-18 16:36:42 -07:00
Roy Lee
900cee56a7 gitignore: ignore IDE stuff 2021-10-18 16:36:42 -07:00
Roy Lee
49c4b0f119 ci: Update Go toolchain to 1.16 2021-10-18 16:36:42 -07:00
Anirudha Bose
98fb089a21 Update release date for v0.22.0-beta in CHANGES file 2021-10-18 16:36:42 -07:00
John C. Vernaleo
97d1d114dc btcd: bump version to v0.22.0-beta 2021-10-18 16:36:42 -07:00
Anirudha Bose
34b571304f Update CHANGES file for 0.22.0 release 2021-10-18 16:36:42 -07:00
Olaoluwa Osuntokun
352e6e25bb mempool: add additional test case for inherited RBF replacement
In this commit, we add an additional test case for inherited RBF
replacement. This test case asserts that if a parent is marked as being
replaceable, but the child isn't, then the child can still be replaced
as according to BIP 125 it shoudl _inhreit_ the replaceability of its
parent.

The addition of this test case was prompted by the recently discovered
Bitcoin Core "CVE" [1]. It turns out that bitcoind doesn't properly
implement BIP 125. Namely it fails to allow a child to "inherit"
replaceability if its parent is also replaceable. Our implementation
makes this trait rather explicit due to its recursive implementation.
Kudos to the original implementer @wpaulino for getting this correct.

[1]: https://lists.linuxfoundation.org/pipermail/bitcoin-dev/2021-May/018893.html.
2021-10-18 16:36:42 -07:00
Oliver Gugger
8e94e9154e chaincfg: fix deployment bit numbers
On signet all previous soft forks and also taproot are always activated,
meaning the version is always 0x20000000 for all blocks. To make sure
they activate properly in `btcd` we therefore need to use the correct
bit to mask the version.
This means that on any custom signet there would need to be 2016 blocks
mined before SegWit or Taproot can be used.
2021-10-18 16:36:41 -07:00
John C. Vernaleo
75c5193db9 Don't reference the readme that we don't produce 2021-10-18 16:36:41 -07:00
Johan T. Halseth
f780a6086f rpctest: add witness commitment when calling CreateBlock
If we tried to include transactions having witnesses, the block would be
invalid since the witness commitment was not added.
2021-10-18 16:36:41 -07:00
Johan T. Halseth
1d9815573a mining: extract witness commitment add into method 2021-10-18 16:36:41 -07:00
Oliver Gugger
a76afa1e98 btcctl: add signet param
This commit adds the --signet command line flag to the btcctl utility.
2021-10-18 16:36:41 -07:00
Oliver Gugger
d069d16fc7 rpcserver: add taproot deployment to getblockchaininfo 2021-10-18 16:36:41 -07:00
Oliver Gugger
a0a92386e6 config+params: add signet config option
This commit adds the --signet command line flag (or signet config
option) for starting btcd in signet mode.
2021-10-18 16:36:41 -07:00
Oliver Gugger
d17e62ae3e wire+chaincfg: add signet params
This commit adds all necessary chain parameters for connecting to the
public signet network.
Reference: https://github.com/bitcoin/bitcoin/pull/18267
2021-10-18 16:36:41 -07:00
Aurèle Oulès
e04fea4c23 btcjson: Updated TxRawResult.Version from int32 to uint32 2021-10-18 16:36:41 -07:00
Jake Sylvestre
5f18190000 rpcclient: fix documentation typo 2021-10-18 16:36:41 -07:00
Wilmer Paulino
46c53fa346 build: update btcutil dependency 2021-10-18 16:36:41 -07:00
Gustavo Chain
8dc0b54ebf addrmgr: Use RLock/RUnlock when possible 2021-10-18 16:36:41 -07:00
Wilmer Paulino
fdb479f121
peer: allow external testing of peer.Peer
The previous use of allowSelfConns prevented this, as users aren't able
to invoke peer.TstAllowSelfConns themselves due to being part of a test
file, which aren't exported at the library level, leading to a
"disconnecting peer connected to self" error upon establishing a mock
connection between two peers. By including the option at the config
level instead (false by default, prevents connections to self) we enable
users of the peer library to properly test the behavior of the peer.Peer
struct externally.
2021-03-11 18:24:13 -08:00
Gustavo Chain
556620fea6 rpcserver: Fix Error message returned by processRequest
When processRequest can't find a rpc command, standardCmdResult returns
a `btcjson.ErrRPCMethodNotFound` but it gets ignored and a
`btcjson.ErrRPCInvalidRequest` is returned instead.

This makes processRequest return the right error message.
2021-03-09 10:34:32 -05:00
Jake Sylvestre
d08785547a docs: update shields 2021-03-05 07:45:19 -05:00
Appelberg-s
dff2198fc5 Fix error message returned by EstimateFee
When you provide an argument to EstimateFee(numblocks uint32) that exceeds the estimateFeeDepth (which is set to 25), you get an error message that says "can only estimate fees for up to 100 blocks from now".  The variable used in the if condition and the variable used for creating the error message should be the same.
2021-02-09 09:54:33 -05:00
Jake Sylvestre
2a1aa5129e Add Batch JSON-RPC support (rpc client & server) 2021-02-09 09:47:46 -05:00
Anirudha Bose
31b66488b4 btcec: validate R and S signature components in RecoverCompact 2021-02-09 09:43:01 -05:00
Olaoluwa Osuntokun
fa683a69dc
Merge pull request #1689 from cfromknecht/hashcache-flake
txscript/hashcache_test: fix flake due to resetting RNG
2021-02-03 19:32:39 -08:00
Conner Fromknecht
5300a19d06
txscript/hashcache_test: call rand.Seed once in init
This resolves the more fundamental flake in the unit tests noted in the
prior commit.

Because multiple unit tests call rand.Seed in parallel, it's possible
they can be executed with the same unix timestamp (in seconds). If the
second call happens between generating the hash cache and checking that
the cache doesn't contain a random txn, the random transaction is in
fact a duplicate of one generated earlier since the RNG state was reset.

To remedy, we initialize rand.Seed once in the init function.
2021-02-02 13:31:47 -08:00
Conner Fromknecht
1dd693480c
txscript/hashcache_test: always add inputs during getTxn
TestHashCacheAddContainsHashes flakes fairly regularly when rebasing
PR #1684 with:
    txid <txid> wasn't inserted into cache but was found.

With probabilty 1/10^2 there will be no inputs on the transaction. This
reduces the entropy in the txid, and I belive is the primary cause of
the flake.
2021-02-02 12:44:22 -08:00
Dan Cline
77fd96753c txscript: add benchmark for IsUnspendable
- create benchmarks to measure allocations
 - add test for benchmark input
 - create a low alloc parseScriptTemplate
 - refactor parsing logic for a single opcode
2021-02-02 09:20:31 -05:00
Steven Kreuzer
7bbd9b0284 btcjson: Update fields in GetBlockChainInfoResult
Update the fields of GetBlockChainInfoResult to reflect the current state of
the RPC returned by other full-node implementations.

 * InitialBlockDownload - Node is in Initial Block Download mode if True.
 * SizeOnDisk - The estimated size of the block and undo files on disk.
2021-01-26 09:52:38 -05:00
Vinayak Borkar
c3ece697da Fixes btcsuite/btcd#1653 2021-01-18 13:51:45 -05:00
Victor Lavaud
e747eb9284 Add support for arm32v7 in Dockerfile 2021-01-18 13:50:30 -05:00
ebiiim
12abc84cb2 fixed broken link 2021-01-18 13:48:02 -05:00
Olaoluwa Osuntokun
6bd4c64a54
Merge pull request #1670 from breez/sendaddrv2
Add support for receiving sendaddrv2 message from a peer
2020-12-07 19:32:08 -08:00
Yaacov Akiba Slama
29c9ff351c Add support for receiving sendaddrv2 message from a peer 2020-12-02 12:10:43 +02:00
10gic
610bb55ae8 rpcclient: add ExtraHeaders in ConnConfig 2020-11-24 14:15:14 -05:00
Iskander Sharipov
0886f1e5c1 simplify s[:] to s where s is a slice
Found using https://go-critic.github.io/overview#unslice-ref
2020-11-20 15:43:12 -05:00
Olaoluwa Osuntokun
e9c7a5ac64
Merge pull request #1659 from guggero/itest-fixes
integration: optimize harness for better itest control, restore bitcoind compatibility
2020-11-13 16:05:16 -08:00
Oliver Gugger
9e8bb3eddb
btcjson+rpcserverhelp: restore bitcoind compatibility
The PR #1594 introduced a change that made the order of parameters
relevant, if one of them is nil. This makes it harder to be backward
compatible with the same JSON message if an existing parameter in
bitcoind was re-purposed to have a different meaning.
2020-11-12 15:47:51 +01:00