-
Notifications
You must be signed in to change notification settings - Fork 26
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #62 from twostack/2.0.0-release-prep
2.0.0-rc1 release prep
- Loading branch information
Showing
3 changed files
with
59 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,20 +5,29 @@ | |
## Overview | ||
|
||
TwoStack WalletSDK is a Bitcoin library for the Dart Language \( [dartlang.org](https://dartlang.org) \), loosely based on the [Moneybutton/BSV](https://github.com/moneybutton/bsv) Javascript library. This library has been built in line with the ideals espoused by BitcoinSV, i.e. massive on-chain scaling, protocol stability and original-bitcoin-protocol implementation. | ||
It is intended for use in building multi-platform applications using the Flutter framework, or server-side | ||
bitcoin applications using frameworks like [Serverpod](https://serverpod.dev/) | ||
|
||
### A note about Version 2.x (August 2023) | ||
Version 2.x of the library is a major refactor and breaks backwards compatibility | ||
with several previous library APIs. | ||
|
||
This library therefore lacks , and will not implement : | ||
* Segregated Witness \(Segwit\) Transaction support | ||
* Schnorr Signature support | ||
* Check Datasig \(OP\_CHECKDATASIG\) | ||
* A new `TransactionBuilder` class for composing Transactions | ||
* Removal of the old Builder interface which was directly attached to the `Transaction` class | ||
* A complete re-implementation of the Script Interpreter | ||
* The `Sighash` class now exposes the SigHash Pre-Image; useful when creating `OP_PUSH_TX` spending scripts. | ||
* A new `ScriptBuilder` class to make it easy to create custom locking/unlocking scripts. | ||
* Merged contributed code to have better Flutter Web support. | ||
|
||
Current Supported features are : | ||
* P2PKH Transactions | ||
* P2SH Transactions | ||
* P2MS Transactions (naked multisig) | ||
* P2PK Transactions | ||
Generally Supported features are : | ||
* Custom-Script Builder Interface to support novel locking/spending conditions within Script | ||
* Data-only Transactions | ||
* Pre-built library code to support "standard" locking/unlocking scripts | ||
* P2PKH Transactions | ||
* P2SH Transactions | ||
* P2MS Transactions (naked multisig) | ||
* P2PK Transactions | ||
* Data-only Transactions (locked with `OP_FALSE OP_RETURN`) | ||
* Spendable data-carrier Transactions (locked with `PUSH_DATA [your_data] OP_DROP [P2PKH locking code]`) | ||
* HD Key Derivation \(BIP32\) | ||
* Original Bitcoin Address format | ||
* Bitcoin Signed Messages | ||
|
@@ -29,23 +38,33 @@ Current Supported features are : | |
#### Sample of the Transaction API: | ||
|
||
```dart | ||
var unlockBuilder = P2PKHUnlockBuilder(privateKey.publicKey); | ||
var transaction = new Transaction() | ||
.spendFromOutput(utxo, Transaction.NLOCKTIME_MAX_VALUE, scriptBuilder: unlockBuilder) | ||
.spendTo(recipientAddress, BigInt.from(50000000), scriptBuilder: P2PKHLockBuilder(recipientAddress)) | ||
.sendChangeTo(changeAddress, scriptBuilder: P2PKHLockBuilder(changeAddress)) | ||
.withFeePerKb(1000); | ||
//Sign the Transaction Input | ||
transaction.signInput(0, privateKey, sighashType: SighashType.SIGHASH_ALL | SighashType.SIGHASH_FORKID); | ||
var utxo = txWithUTXO.outputs[0]; | ||
var outpoint = TransactionOutpoint(txWithUTXO.id, 0, utxo.satoshis, utxo.script); | ||
var signer = TransactionSigner(SighashType.SIGHASH_FORKID.value | SighashType.SIGHASH_ALL.value, privateKey); | ||
var unlocker = P2PKHUnlockBuilder(privateKey.publicKey); | ||
var transaction = TransactionBuilder() | ||
.spendFromOutpointWithSigner(signer, outpoint, TransactionInput.MAX_SEQ_NUMBER, unlocker) | ||
.spendToPKH(recipientAddress, BigInt.from(50000000)) //spend half of a bitcoin | ||
.sendChangeToPKH(changeAddress) // spend change to a different address | ||
.withFeePerKb(50) //set a fee of 50 satoshis per kilobyte | ||
.build(false); //build the transaction, disabling checks | ||
//at this point you have a fully signed transaction ready to be broadcast | ||
try { | ||
transaction.verify(); //perform a pre-broadcast sanity check on the transaction | ||
} on VerificationException catch (ex){ | ||
print("Transaction failed verification - ${ex.cause}"); | ||
} | ||
``` | ||
|
||
### Installation | ||
**Note**: Version 1.0.0 is a major version update to support Dart Null-Safety. | ||
|
||
This library was built using version _2.14.3_ of the Dart SDK( [https://dart.dev/tools/sdk](https://dart.dev/tools/sdk) ). | ||
As of Version 1.0.0 this library supports Dart Null Safety, and will therefore require a minimum SDK Version of 2.12.2. | ||
This library was built using version _3.0.7_ of the Dart SDK( [https://dart.dev/tools/sdk](https://dart.dev/tools/sdk) ). | ||
As of Version 1.0.0 this library supports Dart Null Safety. Current minimum Dart SDK version required is version _2.18.0_. | ||
|
||
Navigate to the root folder of this project, and pull the required supported Dart libraries using the `pub` package manager. | ||
|
||
|
@@ -63,13 +82,16 @@ In the root folder of this project, run the command: | |
|
||
## Acknowledgement | ||
|
||
A debt of gratitude is owed to the developers acknowledged in the LICENSE file. Without the hard work of individuals working on earlier library and node implementations like Bitcoin Core, Bitcoin Cash, MoneyButton/BSV, BitcoinJ and many more, this library would likely not have come to fruition. Thank you. | ||
A debt of gratitude is owed to the developers acknowledged in the LICENSE file. | ||
Without the hard work of individuals working on earlier library and node | ||
implementations like Bitcoin Core, Bitcoin Cash, MoneyButton/BSV, BitcoinJ and many | ||
more, this library would likely not have come to fruition. Thank you. | ||
|
||
## Contact | ||
|
||
You can reach the author at : | ||
|
||
* @twostack_org on Twitter | ||
* [email protected] \(PayMail to buy me a beer\) | ||
* [email protected] | ||
* [email protected] (drop me an email. GPG supported. ) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters