2013-06-12 16:22:01 -05:00
|
|
|
btcscript
|
|
|
|
=========
|
|
|
|
|
2013-12-10 18:01:11 -06:00
|
|
|
[![Build Status](https://travis-ci.org/conformal/btcscript.png?branch=master)]
|
|
|
|
(https://travis-ci.org/conformal/btcscript)
|
|
|
|
|
2013-06-28 01:15:10 +01:00
|
|
|
Package btcscript implements the bitcoin transaction scripts. There is
|
|
|
|
a comprehensive test suite. `test_coverage.txt` contains the current
|
|
|
|
coverage statistics (generated using gocov). On a UNIX-like OS, the
|
|
|
|
script `cov_report.sh` can be used to generate the report. Package
|
|
|
|
btcscript is licensed under the liberal ISC license.
|
2013-06-12 16:35:27 -05:00
|
|
|
|
|
|
|
This package is one of the core packages from btcd, an alternative full-node
|
|
|
|
implementation of bitcoin which is under active development by Conformal.
|
|
|
|
Although it was primarily written for btcd, this package has intentionally been
|
|
|
|
designed so it can be used as a standalone package for any projects needing to
|
|
|
|
use or validate bitcoin transaction scripts.
|
|
|
|
|
|
|
|
## Bitcoin Scripts
|
|
|
|
|
|
|
|
Bitcoin provides a stack-based, FORTH-like langauge for the scripts in
|
|
|
|
the bitcoin transactions. This language is not turing complete
|
|
|
|
although it is still fairly powerful. A description of the language
|
|
|
|
can be found at https://en.bitcoin.it/wiki/Script
|
|
|
|
|
|
|
|
## Sample Use
|
|
|
|
|
|
|
|
```Go
|
|
|
|
pkscript := txS.TxOut[origintxidx].PkScript
|
|
|
|
engine, err := btcscript.NewScript(sigScript, pkscript, txInIdx,
|
2013-08-05 15:08:28 -05:00
|
|
|
txValidator, timestamp.After(btcscript.Bip16Activation))
|
2013-06-12 16:35:27 -05:00
|
|
|
err = engine.Execute()
|
|
|
|
```
|
|
|
|
|
|
|
|
## Documentation
|
|
|
|
|
|
|
|
Full `go doc` style documentation for the project can be viewed online without
|
|
|
|
installing this package by using the GoDoc site
|
|
|
|
[here](http://godoc.org/github.com/conformal/btcscript).
|
|
|
|
|
|
|
|
You can also view the documentation locally once the package is installed with
|
|
|
|
the `godoc` tool by running `godoc -http=":6060"` and pointing your browser to
|
|
|
|
http://localhost:6060/pkg/github.com/conformal/btcscript
|
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
|
|
|
```bash
|
|
|
|
$ go get github.com/conformal/btcscript
|
|
|
|
```
|
|
|
|
|
|
|
|
## TODO
|
|
|
|
|
|
|
|
- Increase test coverage to 100%
|
|
|
|
|
|
|
|
## GPG Verification Key
|
|
|
|
|
|
|
|
All official release tags are signed by Conformal so users can ensure the code
|
|
|
|
has not been tampered with and is coming from Conformal. To verify the
|
|
|
|
signature perform the following:
|
|
|
|
|
|
|
|
- Download the public key from the Conformal website at
|
|
|
|
https://opensource.conformal.com/GIT-GPG-KEY-conformal.txt
|
|
|
|
|
|
|
|
- Import the public key into your GPG keyring:
|
|
|
|
```bash
|
|
|
|
gpg --import GIT-GPG-KEY-conformal.txt
|
|
|
|
```
|
|
|
|
|
|
|
|
- Verify the release tag with the following command where `TAG_NAME` is a
|
|
|
|
placeholder for the specific tag:
|
|
|
|
```bash
|
|
|
|
git tag -v TAG_NAME
|
|
|
|
```
|
|
|
|
|
|
|
|
## License
|
|
|
|
|
|
|
|
Package btcscript is licensed under the liberal ISC License.
|