Merge pull request #71 from wakiyamap/master

Remove unnecessary monautil and monad libraries
This commit is contained in:
Martin 2018-10-04 09:00:27 +02:00 committed by GitHub
commit fe0008bf8d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 6 additions and 143 deletions

38
Gopkg.lock generated
View File

@ -1,24 +1,12 @@
# This file is autogenerated, do not edit; changes may be undone by the next 'dep ensure'.
[[projects]]
branch = "master"
name = "github.com/aead/skein"
packages = [".","threefish"]
revision = "9365ae6e95d294dc113a0b308852f97c916db233"
[[projects]]
branch = "master"
name = "github.com/beorn7/perks"
packages = ["quantile"]
revision = "3a771d992973f24aa725d07868b467d1ddfceafb"
[[projects]]
branch = "master"
name = "github.com/bitgoin/lyra2rev2"
packages = [".","sha3"]
revision = "bae9ad2043bb55facb14c4918e909f88a7d3ed84"
[[projects]]
branch = "master"
name = "github.com/bsm/go-vlq"
@ -43,18 +31,6 @@
packages = [".","base58","bech32"]
revision = "501929d3d046174c3d39f0ea54ece471aa17238c"
[[projects]]
branch = "master"
name = "github.com/btcsuite/golangcrypto"
packages = ["ripemd160"]
revision = "53f62d9b43e87a6c56975cf862af7edf33a8d0df"
[[projects]]
name = "github.com/dchest/blake256"
packages = ["."]
revision = "dee3fe6eb0e98dc774a94fc231f85baf7c29d360"
version = "v1.0.0"
[[projects]]
name = "github.com/deckarep/golang-set"
packages = ["."]
@ -193,18 +169,6 @@
packages = ["."]
revision = "3e476152774442234f9a9f747386a48a1d82a515"
[[projects]]
branch = "master"
name = "github.com/wakiyamap/monad"
packages = ["btcec","chaincfg","chaincfg/chainhash","txscript","wire"]
revision = "2b35d553bb7e65947d87100f50758ee11261da33"
[[projects]]
branch = "master"
name = "github.com/wakiyamap/monautil"
packages = [".","base58","bech32"]
revision = "c1fba54cb210ffa57c4cb5e40fa09c789daa56b8"
[[projects]]
branch = "master"
name = "golang.org/x/crypto"
@ -232,6 +196,6 @@
[solve-meta]
analyzer-name = "dep"
analyzer-version = 1
inputs-digest = "7cb7ad84fe0b30276bb7775d85c4f3281acddb12cb2e10ea4d80198981c9f80b"
inputs-digest = "37517a6a6dbd6e924bf6761b562697a069e952f72f4d3ef984faf72738e91670"
solver-name = "gps-cdcl"
solver-version = 1

View File

@ -1,29 +1,20 @@
package monacoin
import (
"blockbook/bchain"
"blockbook/bchain/coins/btc"
"github.com/btcsuite/btcd/wire"
"github.com/jakm/btcutil/chaincfg"
monacoinCfg "github.com/wakiyamap/monad/chaincfg"
"github.com/wakiyamap/monad/txscript"
monacoinWire "github.com/wakiyamap/monad/wire"
"github.com/wakiyamap/monautil"
)
const (
MainnetMagic wire.BitcoinNet = 0x39393939 //dummy. Correct value is 0xdbb6c0fb
TestnetMagic wire.BitcoinNet = 0x69696969 //dummy. Correct value is 0xf1c8d2fd
MonaMainMagic monacoinWire.BitcoinNet = 0xdbb6c0fb
MonaTestMagic monacoinWire.BitcoinNet = 0xf1c8d2fd
MainnetMagic wire.BitcoinNet = 0xdbb6c0fb
TestnetMagic wire.BitcoinNet = 0xf1c8d2fd
)
var (
MainNetParams chaincfg.Params
TestNetParams chaincfg.Params
MonaMainParams monacoinCfg.Params
MonaTestParams monacoinCfg.Params
MainNetParams chaincfg.Params
TestNetParams chaincfg.Params
)
func init() {
@ -32,22 +23,12 @@ func init() {
MainNetParams.PubKeyHashAddrID = []byte{50}
MainNetParams.ScriptHashAddrID = []byte{55}
MainNetParams.Bech32HRPSegwit = "mona"
MonaMainParams = monacoinCfg.MainNetParams
MonaMainParams.Net = MonaMainMagic
MonaMainParams.PubKeyHashAddrID = 50
MonaMainParams.ScriptHashAddrID = 55
MonaMainParams.Bech32HRPSegwit = "mona"
TestNetParams = chaincfg.TestNet3Params
TestNetParams.Net = TestnetMagic
TestNetParams.PubKeyHashAddrID = []byte{111}
TestNetParams.ScriptHashAddrID = []byte{117}
TestNetParams.Bech32HRPSegwit = "tmona"
MonaTestParams = monacoinCfg.TestNet4Params
MonaTestParams.Net = MonaTestMagic
MonaTestParams.PubKeyHashAddrID = 111
MonaTestParams.ScriptHashAddrID = 117
MonaTestParams.Bech32HRPSegwit = "tmona"
}
// MonacoinParser handle
@ -57,9 +38,7 @@ type MonacoinParser struct {
// NewMonacoinParser returns new MonacoinParser instance
func NewMonacoinParser(params *chaincfg.Params, c *btc.Configuration) *MonacoinParser {
p := &MonacoinParser{BitcoinParser: btc.NewBitcoinParser(params, c)}
p.OutputScriptToAddressesFunc = p.outputScriptToAddresses
return p
return &MonacoinParser{BitcoinParser: btc.NewBitcoinParser(params, c)}
}
// GetChainParams contains network parameters for the main Monacoin network,
@ -81,83 +60,3 @@ func GetChainParams(chain string) *chaincfg.Params {
return &MainNetParams
}
}
// GetAddrDescFromAddress returns internal address representation (descriptor) of given address
func (p *MonacoinParser) GetAddrDescFromAddress(address string) (bchain.AddressDescriptor, error) {
return p.addressToOutputScript(address)
}
// addressToOutputScript converts monacoin address to ScriptPubKey
func (p *MonacoinParser) addressToOutputScript(address string) ([]byte, error) {
switch p.Params.Net {
case MainnetMagic:
da, err := monautil.DecodeAddress(address, &MonaMainParams)
if err != nil {
return nil, err
}
script, err := txscript.PayToAddrScript(da)
if err != nil {
return nil, err
}
return script, nil
default:
da, err := monautil.DecodeAddress(address, &MonaTestParams)
if err != nil {
return nil, err
}
script, err := txscript.PayToAddrScript(da)
if err != nil {
return nil, err
}
return script, nil
}
}
// GetAddressesFromAddrDesc returns addresses for given address descriptor with flag if the addresses are searchable
func (p *MonacoinParser) GetAddressesFromAddrDesc(addrDesc bchain.AddressDescriptor) ([]string, bool, error) {
return p.OutputScriptToAddressesFunc(addrDesc)
}
// outputScriptToAddresses converts ScriptPubKey to bitcoin addresses
func (p *MonacoinParser) outputScriptToAddresses(script []byte) ([]string, bool, error) {
switch p.Params.Net {
case MainnetMagic:
sc, addresses, _, err := txscript.ExtractPkScriptAddrs(script, &MonaMainParams)
if err != nil {
return nil, false, err
}
rv := make([]string, len(addresses))
for i, a := range addresses {
rv[i] = a.EncodeAddress()
}
var s bool
if sc == txscript.PubKeyHashTy || sc == txscript.WitnessV0PubKeyHashTy || sc == txscript.ScriptHashTy || sc == txscript.WitnessV0ScriptHashTy {
s = true
} else if len(rv) == 0 {
or := btc.TryParseOPReturn(script)
if or != "" {
rv = []string{or}
}
}
return rv, s, nil
default:
sc, addresses, _, err := txscript.ExtractPkScriptAddrs(script, &MonaTestParams)
if err != nil {
return nil, false, err
}
rv := make([]string, len(addresses))
for i, a := range addresses {
rv[i] = a.EncodeAddress()
}
var s bool
if sc == txscript.PubKeyHashTy || sc == txscript.WitnessV0PubKeyHashTy || sc == txscript.ScriptHashTy || sc == txscript.WitnessV0ScriptHashTy {
s = true
} else if len(rv) == 0 {
or := btc.TryParseOPReturn(script)
if or != "" {
rv = []string{or}
}
}
return rv, s, nil
}
}