Major breaking API change!
While this interim release doesn't by itself include segwit support, it does
change the name of the CTransaction/CMutableTransaction
method GetHash()
to
GetTxid()
to prepare for a future segwit-enabled release. Incorrect calls to
GetHash()
will now raise a AttributeError
exception with an explanation.
Since this release doesn't yet include segwit support, you will need to set the
Bitcoin Core -rpcserialversion=0
option, either as a command line argument,
or in your bitcoin.conf
file. Otherwise the RPC interface will return
segwit-serialized transactions that this release's RPC support doesn't
understand.
Other changes:
- Cookie file RPC authentication is now supported.
msg_header
now correctly usesCBlockHeader
rather thanCBlock
.- RPC
getbalance
now supportsinclude_watchonly
- RPC
unlockwallet
is now supported
Breaking API changes:
-
The 'cooked' CScript iterator now returns
OP_0
for the empty binary string rather thanb''
-
The alias
JSONRPCException = JSONRPCError
has been removed. This alias was added for compatibility with v0.4.0 of python-bitcoinlib. -
Where appropriate,
RPC_INVALID_ADDRESS_OR_KEY
errors are now caught properly, which means that rather than raisingIndexError
, RPC commands such asgetblock
may raiseJSONRPCError
instead. For instance during initial startup previously python-bitcoinlib would incorrectly raiseIndexError
rather than letting the callee know that RPC was unusable. Along those lines,JSONRPCError
subclasses have been added for some (but not all!) of the types of RPC errors Bitcoin Core returns.
Bugfixes:
- Fixed a spurious
AttributeError
whenbitcoin.rpc.Proxy()
fails.
New features:
- getblockheader RPC call now supports the verbose option; there's no other way to get the block height, among other things, from the RPC interface.
- subtoaddress and sendmany RPC calls now support comment and subtractfeefromamount arguments.
Breaking API changes:
-
RPC over SSL support removed to match Bitcoin Core's removal of RPC SSL support in v0.12.0 If you need this, use an alternative such as a stunnel or a SSH tunnel.
-
Removed SCRIPT_VERIFY constants
bitcoin.core.script
, leaving just the constants inbitcoin.core.scripteval
; being singletons the redundant constants were broken anyway. -
SCRIPT_VERIFY_EVEN_S renamed to SCRIPT_VERIFY_LOW_S to match Bitcoin Core's naming
-
SCRIPT_VERIFY_NOCACHE removed as Bitcoin Core no longer has it (and we never did anything with it anyway)
Various small bugfixes; see git history.
New features:
- New RPC calls: fundrawtransaction, generate, getblockheader
- OP_CHECKLOCKTIMEVERIFY opcode constant
Major fix: Fixed OpenSSL related crashes on OSX and Arch Linux. Big thanks to everyone who helped fix this!
Breaking API changes:
- Proxy no longer has
__getattr__
to support arbitrary methods. Use RawProxy or Proxy.call instead. This allows new wrappers to be added safely. See docstrings for details.
New features:
- New RPC calls: getbestblockhash, getblockcount, getmininginfo
- Signing and verification of Bitcoin Core compatible messages. (w/ pubkey recovery)
- Tox tests
- Sphinx docs
Notable bugfixes:
- getinfo() now works where disablewallet=1
Major fix: OpenSSL 1.0.1k rejects non-canonical DER signatures, which Bitcoin Core does not, so we now canonicalize signatures prior to passing them to OpenSSL. Secondly we now only generate low-S DER signatures as per BIP62.
API changes that might break compatibility with existing code:
- MAX_MONEY is now a core chain parameter
- MainParams now inherits from CoreMainParams rather than CoreChainParams
- str() now returns hash:n format; previously was same as repr()
- RawProxy() no longer has _connection parameter
Notable bugfixes:
- MsgSerializable.to_bytes() no longer clobbers testnet params
- HTTPS RPC connections now use port 443 as default
- No longer assumes bitcoin.conf specifes rpcuser
New features:
- New RPC calls: dumpprivkey, importaddress
- Added P2P support for msg_notfound and msg_reject
- Added support for IPv6 addr messages
Major change: cleaned up what symbols are exported by modules. __all__ is now used extensively, which may break some applications that were not importing the right modules. Along those lines some implementation details like the ssl attribute of the bitcoin.core.key module, and the entire bitcoin.core.bignum module, are no longer part of the public API. This should not affect too many users, but it will break some code.
Other notable changes:
- New getreceivedbyaddress RPC call.
- Fixed getbalance RPC call when wallet is configured off.
- Various code cleanups and minor bug fixes.
- Improve bitcoin address handling. P2SH and P2PKH addresses now get their own classes - P2SHBitcoinAddress and P2PKHBitcoinAddress respectively - and P2PKH can now convert scriptPubKeys containing non-canonical pushes as well as bare checksig to addresses.
- .deserialize() methods now fail if there is extra data left over.
- Various other small bugfixes.
- License is now LGPL v3 or later.
Major change: CTransaction, CBlock, etc. now come in immutable (default) and mutable forms. In most cases mutable and immutable can be used interchangeably; when that is not possible methods are provided to create new (im)mutable objects from (im)mutable ones efficiently.
Other changes:
- New BIP70 payment protocol example. (Derren Desouza)
- Rework of message serialization. Note that this may not represent the final form of P2P support, which is still in flux. (Florian Schmaus)
- Various bugfixes
Finally starting this release, git tags will be of the form 'python-bitcoinlib-(version)', replacing the less specific '(version)' form previously used.