Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature: v2 Alpha Release #33

Merged
merged 12 commits into from
Feb 3, 2022
6 changes: 3 additions & 3 deletions .goreleaser.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,9 +18,9 @@ changelog:
# ---------------------------
# Publishers
# ---------------------------
publishers:
- name: "Publish GoDocs"
cmd: make godocs
#publishers:
# - name: "Publish GoDocs"
# cmd: make godocs

# ---------------------------
# Builder
Expand Down
60 changes: 32 additions & 28 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ View the generated [documentation](https://pkg.go.dev/github.com/bitcoinschema/g
### Features

- **Addresses**
- [Address from PrivateKey (bsvec.PrivateKey)](address.go)
- [Address from PrivateKey (bec.PrivateKey)](address.go)
- [Address from Script](address.go)
- **Encryption**
- [Encrypt With Private Key](encryption.go)
Expand Down Expand Up @@ -98,6 +98,7 @@ View the generated [documentation](https://pkg.go.dev/github.com/bitcoinschema/g

- [bitcoinsv/bsvd](https://github.com/bitcoinsv/bsvd)
- [bitcoinsv/bsvutil](https://github.com/bitcoinsv/bsvutil)
- [libsv/go-bk](https://github.com/libsv/go-bk)
- [libsv/go-bt](https://github.com/libsv/go-bt)
</details>

Expand Down Expand Up @@ -126,33 +127,36 @@ make help
List of all current commands:

```text
all Runs multiple commands
clean Remove previous builds and any test cache data
clean-mods Remove all the Go mod cache
coverage Shows the test coverage
generate Runs the go generate command in the base of the repo
godocs Sync the latest tag with GoDocs
help Show this help message
install Install the application
install-go Install the application (Using Native Go)
lint Run the golangci-lint application (install if not found)
release Full production release (creates release in Github)
release Runs common.release then runs godocs
release-snap Test the full release (build binaries)
release-test Full production test release (everything except deploy)
replace-version Replaces the version in HTML/JS (pre-deploy)
tag Generate a new tag and push (tag version=0.0.0)
tag-remove Remove a tag if found (tag-remove version=0.0.0)
tag-update Update an existing tag to current commit (tag-update version=0.0.0)
test Runs vet, lint and ALL tests
test-ci Runs all tests via CI (exports coverage)
test-ci-no-race Runs all tests via CI (no race) (exports coverage)
test-ci-short Runs unit tests via CI (exports coverage)
test-short Runs vet, lint and tests (excludes integration tests)
test-unit Runs tests and outputs coverage
uninstall Uninstall the application (and remove files)
update-linter Update the golangci-lint package (macOS only)
vet Run the Go vet application
all Runs multiple commands
clean Remove previous builds and any test cache data
clean-mods Remove all the Go mod cache
coverage Shows the test coverage
diff Show the git diff
generate Runs the go generate command in the base of the repo
godocs Sync the latest tag with GoDocs
help Show this help message
install Install the application
install-go Install the application (Using Native Go)
install-releaser Install the GoReleaser application
lint Run the golangci-lint application (install if not found)
release Full production release (creates release in Github)
release Runs common.release then runs godocs
release-snap Test the full release (build binaries)
release-test Full production test release (everything except deploy)
replace-version Replaces the version in HTML/JS (pre-deploy)
tag Generate a new tag and push (tag version=0.0.0)
tag-remove Remove a tag if found (tag-remove version=0.0.0)
tag-update Update an existing tag to current commit (tag-update version=0.0.0)
test Runs lint and ALL tests
test-ci Runs all tests via CI (exports coverage)
test-ci-no-race Runs all tests via CI (no race) (exports coverage)
test-ci-short Runs unit tests via CI (exports coverage)
test-no-lint Runs just tests
test-short Runs vet, lint and tests (excludes integration tests)
test-unit Runs tests and outputs coverage
uninstall Uninstall the application (and remove files)
update-linter Update the golangci-lint package (macOS only)
vet Run the Go vet application
```

</details>
Expand Down
18 changes: 9 additions & 9 deletions address.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,10 @@ import (
"errors"
"fmt"

"github.com/bitcoinsv/bsvd/bsvec"
"github.com/bitcoinsv/bsvd/chaincfg"
"github.com/bitcoinsv/bsvd/txscript"
"github.com/bitcoinsv/bsvutil"
"github.com/libsv/go-bk/bec"
)

// A25 is a type for a 25 byte (not base58 encoded) bitcoin address.
Expand Down Expand Up @@ -89,8 +89,8 @@ func ValidA58(a58 []byte) (bool, error) {
return a.EmbeddedChecksum() == a.ComputeChecksum(), nil
}

// GetAddressFromPrivateKey takes a bsvec private key and returns a Bitcoin address
func GetAddressFromPrivateKey(privateKey *bsvec.PrivateKey, compressed bool) (string, error) {
// GetAddressFromPrivateKey takes a bec private key and returns a Bitcoin address
func GetAddressFromPrivateKey(privateKey *bec.PrivateKey, compressed bool) (string, error) {
address, err := GetAddressFromPubKey(privateKey.PubKey(), compressed)
if err != nil {
return "", err
Expand All @@ -111,21 +111,21 @@ func GetAddressFromPrivateKeyString(privateKey string, compressed bool) (string,
return address.EncodeAddress(), nil
}

// GetAddressFromPubKey gets a bsvutil.LegacyAddressPubKeyHash from a bsvec.PublicKey
func GetAddressFromPubKey(publicKey *bsvec.PublicKey, compressed bool) (*bsvutil.LegacyAddressPubKeyHash, error) {
// GetAddressFromPubKey gets a bsvutil.LegacyAddressPubKeyHash from a bec.PublicKey
func GetAddressFromPubKey(publicKey *bec.PublicKey, compressed bool) (*bsvutil.LegacyAddressPubKeyHash, error) {
if publicKey == nil {
return nil, fmt.Errorf("publicKey cannot be nil")
} else if publicKey.X == nil {
return nil, fmt.Errorf("publicKey.X cannot be nil")
}
var serializedPublicKey []byte
var SerialisedPublicKey []byte
if compressed {
serializedPublicKey = publicKey.SerializeCompressed()
SerialisedPublicKey = publicKey.SerialiseCompressed()
} else {
serializedPublicKey = publicKey.SerializeUncompressed()
SerialisedPublicKey = publicKey.SerialiseUncompressed()
}

return bsvutil.NewLegacyAddressPubKeyHash(bsvutil.Hash160(serializedPublicKey), &chaincfg.MainNetParams)
return bsvutil.NewLegacyAddressPubKeyHash(bsvutil.Hash160(SerialisedPublicKey), &chaincfg.MainNetParams)
}

// GetAddressFromPubKeyString is a convenience function to use a hex string pubKey
Expand Down
12 changes: 6 additions & 6 deletions address_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import (
"fmt"
"testing"

"github.com/bitcoinsv/bsvd/bsvec"
"github.com/libsv/go-bk/bec"
"github.com/stretchr/testify/assert"
)

Expand Down Expand Up @@ -97,7 +97,7 @@ func TestGetAddressFromPrivateKey(t *testing.T) {
// TestGetAddressFromPrivateKeyCompression will test the method GetAddressFromPrivateKey()
func TestGetAddressFromPrivateKeyCompression(t *testing.T) {

privateKey, err := bsvec.NewPrivateKey(bsvec.S256())
privateKey, err := bec.NewPrivateKey(bec.S256())
assert.NoError(t, err)

var addressUncompressed string
Expand Down Expand Up @@ -131,7 +131,7 @@ func BenchmarkGetAddressFromPrivateKey(b *testing.B) {
}

// testGetPublicKeyFromPrivateKey is a helper method for tests
func testGetPublicKeyFromPrivateKey(privateKey string) *bsvec.PublicKey {
func testGetPublicKeyFromPrivateKey(privateKey string) *bec.PublicKey {
rawKey, err := PrivateKeyFromString(privateKey)
if err != nil {
return nil
Expand All @@ -144,18 +144,18 @@ func TestGetAddressFromPubKey(t *testing.T) {
t.Parallel()

var tests = []struct {
input *bsvec.PublicKey
input *bec.PublicKey
expectedAddress string
expectedNil bool
expectedError bool
}{
{&bsvec.PublicKey{}, "", true, true},
{&bec.PublicKey{}, "", true, true},
{testGetPublicKeyFromPrivateKey("54035dd4c7dda99ac473905a3d82f7864322b49bab1ff441cc457183b9bd8abd"), "1DfGxKmgL3ETwUdNnXLBueEvNpjcDGcKgK", false, false},
{testGetPublicKeyFromPrivateKey("000000"), "15wJjXvfQzo3SXqoWGbWZmNYND1Si4siqV", false, false},
{testGetPublicKeyFromPrivateKey("0"), "15wJjXvfQzo3SXqoWGbWZmNYND1Si4siqV", true, true},
}

// todo: add more error cases of invalid *bsvec.PublicKey
// todo: add more error cases of invalid *bec.PublicKey

for _, test := range tests {
if rawKey, err := GetAddressFromPubKey(test.input, true); err != nil && !test.expectedError {
Expand Down
26 changes: 13 additions & 13 deletions encryption.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,14 @@ package bitcoin
import (
"encoding/hex"

"github.com/bitcoinsv/bsvd/bsvec"
"github.com/libsv/go-bk/bec"
)

// EncryptWithPrivateKey will encrypt the data using a given private key
func EncryptWithPrivateKey(privateKey *bsvec.PrivateKey, data string) (string, error) {
func EncryptWithPrivateKey(privateKey *bec.PrivateKey, data string) (string, error) {

// Encrypt using bsvec
encryptedData, err := bsvec.Encrypt(privateKey.PubKey(), []byte(data))
// Encrypt using bec
encryptedData, err := bec.Encrypt(privateKey.PubKey(), []byte(data))
if err != nil {
return "", err
}
Expand All @@ -21,7 +21,7 @@ func EncryptWithPrivateKey(privateKey *bsvec.PrivateKey, data string) (string, e

// DecryptWithPrivateKey is a wrapper to decrypt the previously encrypted
// information, given a corresponding private key
func DecryptWithPrivateKey(privateKey *bsvec.PrivateKey, data string) (string, error) {
func DecryptWithPrivateKey(privateKey *bec.PrivateKey, data string) (string, error) {

// Decode the hex encoded string
rawData, err := hex.DecodeString(data)
Expand All @@ -31,7 +31,7 @@ func DecryptWithPrivateKey(privateKey *bsvec.PrivateKey, data string) (string, e

// Decrypt the data
var decrypted []byte
if decrypted, err = bsvec.Decrypt(privateKey, rawData); err != nil {
if decrypted, err = bec.Decrypt(privateKey, rawData); err != nil {
return "", err
}
return string(decrypted), nil
Expand All @@ -46,7 +46,7 @@ func EncryptWithPrivateKeyString(privateKey, data string) (string, error) {
return "", err
}

// Encrypt using bsvec
// Encrypt using bec
return EncryptWithPrivateKey(rawPrivateKey, data)
}

Expand All @@ -64,26 +64,26 @@ func DecryptWithPrivateKeyString(privateKey, data string) (string, error) {
}

// EncryptShared will encrypt data and provide shared keys for decryption
func EncryptShared(user1PrivateKey *bsvec.PrivateKey, user2PubKey *bsvec.PublicKey, data []byte) (
*bsvec.PrivateKey, *bsvec.PublicKey, []byte, error) {
func EncryptShared(user1PrivateKey *bec.PrivateKey, user2PubKey *bec.PublicKey, data []byte) (
*bec.PrivateKey, *bec.PublicKey, []byte, error) {

// Generate shared keys that can be decrypted by either user
sharedPrivKey, sharedPubKey := GenerateSharedKeyPair(user1PrivateKey, user2PubKey)

// Encrypt data with shared key
encryptedData, err := bsvec.Encrypt(sharedPubKey, data)
encryptedData, err := bec.Encrypt(sharedPubKey, data)
return sharedPrivKey, sharedPubKey, encryptedData, err
}

// EncryptSharedString will encrypt a string to a hex encoded encrypted payload, and provide shared keys for decryption
func EncryptSharedString(user1PrivateKey *bsvec.PrivateKey, user2PubKey *bsvec.PublicKey, data string) (
*bsvec.PrivateKey, *bsvec.PublicKey, string, error) {
func EncryptSharedString(user1PrivateKey *bec.PrivateKey, user2PubKey *bec.PublicKey, data string) (
*bec.PrivateKey, *bec.PublicKey, string, error) {

// Generate shared keys that can be decrypted by either user
sharedPrivKey, sharedPubKey := GenerateSharedKeyPair(user1PrivateKey, user2PubKey)

// Encrypt data with shared key
encryptedData, err := bsvec.Encrypt(sharedPubKey, []byte(data))
encryptedData, err := bec.Encrypt(sharedPubKey, []byte(data))

return sharedPrivKey, sharedPubKey, hex.EncodeToString(encryptedData), err
}
14 changes: 7 additions & 7 deletions encryption_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
"fmt"
"testing"

"github.com/bitcoinsv/bsvd/bsvec"
"github.com/libsv/go-bk/bec"
"github.com/stretchr/testify/assert"
)

Expand All @@ -21,7 +21,7 @@ func TestEncryptWithPrivateKey(t *testing.T) {
assert.NotNil(t, privateKey)

var tests = []struct {
inputKey *bsvec.PrivateKey
inputKey *bec.PrivateKey
inputData string
expectedError bool
}{
Expand Down Expand Up @@ -170,7 +170,7 @@ func TestDecryptWithPrivateKey(t *testing.T) {
assert.NotNil(t, privateKey)

var tests = []struct {
inputKey *bsvec.PrivateKey
inputKey *bec.PrivateKey
inputEncrypted string
expectedData string
expectedError bool
Expand Down Expand Up @@ -408,7 +408,7 @@ func TestEncryptShared(t *testing.T) {
assert.NotNil(t, privKey1)

// User 2's private key
var privKey2 *bsvec.PrivateKey
var privKey2 *bec.PrivateKey
privKey2, err = CreatePrivateKey()
assert.NoError(t, err)
assert.NotNil(t, privKey1)
Expand All @@ -424,7 +424,7 @@ func TestEncryptShared(t *testing.T) {

// User 2 can decrypt using the shared private key
var decryptedTestData []byte
decryptedTestData, err = bsvec.Decrypt(user2SharedPrivKey, encryptedData)
decryptedTestData, err = bec.Decrypt(user2SharedPrivKey, encryptedData)
assert.NoError(t, err)

// Test the result
Expand Down Expand Up @@ -456,7 +456,7 @@ func TestEncryptSharedString(t *testing.T) {
assert.NotNil(t, privKey1)

// User 2's private key
var privKey2 *bsvec.PrivateKey
var privKey2 *bec.PrivateKey
privKey2, err = CreatePrivateKey()
assert.NoError(t, err)
assert.NotNil(t, privKey1)
Expand All @@ -475,7 +475,7 @@ func TestEncryptSharedString(t *testing.T) {
decoded, err = hex.DecodeString(encryptedData)
assert.NoError(t, err)

decryptedTestData, err = bsvec.Decrypt(user2SharedPrivKey, decoded)
decryptedTestData, err = bec.Decrypt(user2SharedPrivKey, decoded)
assert.NoError(t, err)

// Test the result
Expand Down
2 changes: 1 addition & 1 deletion examples/calculate_fee_for_tx/calculate_fee_for_tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,5 @@ func main() {
estimatedFee := bitcoin.CalculateFeeForTx(tx, nil, nil)

// Success!
log.Printf("tx id: %s estimated fee: %d satoshis", tx.GetTxID(), estimatedFee)
log.Printf("tx id: %s estimated fee: %d satoshis", tx.TxID(), estimatedFee)
}
6 changes: 3 additions & 3 deletions examples/create_tx/create_tx.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import (
"log"

"github.com/bitcoinschema/go-bitcoin/v2"
"github.com/libsv/go-bt"
"github.com/libsv/go-bt/v2"
)

func main() {
Expand Down Expand Up @@ -48,6 +48,6 @@ func main() {
}

// Success!
log.Printf("rawTx: %s", rawTx.ToString())
log.Printf("tx_id: %s", rawTx.GetTxID())
log.Printf("rawTx: %s", rawTx.String())
log.Printf("tx_id: %s", rawTx.TxID())
}
2 changes: 1 addition & 1 deletion examples/create_tx_using_wif/create_tx_using_wif.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,5 +39,5 @@ func main() {
}

// Success!
log.Printf("rawTx: %s", rawTx.ToString())
log.Printf("rawTx: %s", rawTx.String())
}
2 changes: 1 addition & 1 deletion examples/create_tx_with_change/create_tx_with_change.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,5 +42,5 @@ func main() {
}

// Success!
log.Printf("rawTx: %s", rawTx.ToString())
log.Printf("rawTx: %s", rawTx.String())
}
4 changes: 2 additions & 2 deletions examples/encrypt_shared_keys/encrypt_shared_keys.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import (
"log"

"github.com/bitcoinschema/go-bitcoin/v2"
"github.com/bitcoinsv/bsvd/bsvec"
"github.com/libsv/go-bk/bec"
)

func main() {
Expand All @@ -30,7 +30,7 @@ func main() {

// User 2 can decrypt using the shared private key
var decryptedTestData []byte
decryptedTestData, err = bsvec.Decrypt(user2SharedPrivKey, encryptedData)
decryptedTestData, err = bec.Decrypt(user2SharedPrivKey, encryptedData)
if err != nil {
log.Fatalf("failed to decrypt test data %s", err)
}
Expand Down
Loading