Remove monautil and monad

pull/71/head
wakiyamap 2018-10-03 19:13:18 -04:00
parent 95de0425d1
commit 3e20db5c06
1 changed files with 3 additions and 104 deletions

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
)
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
}
}