Cleanup
* Bugfixes * Removed whether to include sigs in txin for readElement/writeElement
This commit is contained in:
parent
1772108544
commit
2d3253b95d
@ -64,7 +64,7 @@ func (c *FundingRequest) Decode(r io.Reader, pver uint32) error {
|
|||||||
//Inputs: Create the TxIns
|
//Inputs: Create the TxIns
|
||||||
// First byte is number of inputs
|
// First byte is number of inputs
|
||||||
// For each input, it's 32bytes txin & 4bytes index
|
// For each input, it's 32bytes txin & 4bytes index
|
||||||
err := readElements(r, false,
|
err := readElements(r,
|
||||||
&c.ChannelType,
|
&c.ChannelType,
|
||||||
&c.RequesterFundingAmount,
|
&c.RequesterFundingAmount,
|
||||||
&c.MinTotalFundingAmount,
|
&c.MinTotalFundingAmount,
|
||||||
@ -106,7 +106,7 @@ func (c *FundingRequest) Encode(w io.Writer, pver uint32) error {
|
|||||||
//DeliveryPkScript
|
//DeliveryPkScript
|
||||||
//ChangePkScript
|
//ChangePkScript
|
||||||
//Inputs: Append the actual Txins
|
//Inputs: Append the actual Txins
|
||||||
err := writeElements(w, false,
|
err := writeElements(w,
|
||||||
c.ChannelType,
|
c.ChannelType,
|
||||||
c.RequesterFundingAmount,
|
c.RequesterFundingAmount,
|
||||||
c.MinTotalFundingAmount,
|
c.MinTotalFundingAmount,
|
||||||
@ -204,6 +204,12 @@ func (c *FundingRequest) String() string {
|
|||||||
inputs += fmt.Sprintf("\tIndex\t%d\n", in.PreviousOutPoint.Index)
|
inputs += fmt.Sprintf("\tIndex\t%d\n", in.PreviousOutPoint.Index)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var serializedPubkey []byte
|
||||||
|
if &c.Pubkey != nil && c.Pubkey.X != nil {
|
||||||
|
serializedPubkey = c.Pubkey.SerializeCompressed()
|
||||||
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("\n--- Begin FundingRequest ---\n") +
|
return fmt.Sprintf("\n--- Begin FundingRequest ---\n") +
|
||||||
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
||||||
fmt.Sprintf("RequesterFundingAmount:\t\t%s\n", c.RequesterFundingAmount.String()) +
|
fmt.Sprintf("RequesterFundingAmount:\t\t%s\n", c.RequesterFundingAmount.String()) +
|
||||||
@ -215,7 +221,7 @@ func (c *FundingRequest) String() string {
|
|||||||
fmt.Sprintf("LockTime\t\t\t%d\n", c.LockTime) +
|
fmt.Sprintf("LockTime\t\t\t%d\n", c.LockTime) +
|
||||||
fmt.Sprintf("FeePayer\t\t\t%x\n", c.FeePayer) +
|
fmt.Sprintf("FeePayer\t\t\t%x\n", c.FeePayer) +
|
||||||
fmt.Sprintf("RevocationHash\t\t\t%x\n", c.RevocationHash) +
|
fmt.Sprintf("RevocationHash\t\t\t%x\n", c.RevocationHash) +
|
||||||
fmt.Sprintf("Pubkey\t\t\t\t%x\n", c.Pubkey.SerializeCompressed()) +
|
fmt.Sprintf("Pubkey\t\t\t\t%x\n", serializedPubkey) +
|
||||||
fmt.Sprintf("DeliveryPkScript\t\t%x\n", c.DeliveryPkScript) +
|
fmt.Sprintf("DeliveryPkScript\t\t%x\n", c.DeliveryPkScript) +
|
||||||
fmt.Sprintf("Inputs:") +
|
fmt.Sprintf("Inputs:") +
|
||||||
inputs +
|
inputs +
|
||||||
|
@ -58,7 +58,7 @@ func (c *FundingResponse) Decode(r io.Reader, pver uint32) error {
|
|||||||
//Inputs: Create the TxIns
|
//Inputs: Create the TxIns
|
||||||
// First byte is number of inputs
|
// First byte is number of inputs
|
||||||
// For each input, it's 32bytes txin & 4bytes index
|
// For each input, it's 32bytes txin & 4bytes index
|
||||||
err := readElements(r, false,
|
err := readElements(r,
|
||||||
&c.ReservationID,
|
&c.ReservationID,
|
||||||
&c.ChannelType,
|
&c.ChannelType,
|
||||||
&c.ResponderFundingAmount,
|
&c.ResponderFundingAmount,
|
||||||
@ -101,7 +101,7 @@ func (c *FundingResponse) Encode(w io.Writer, pver uint32) error {
|
|||||||
//ChangePkScript (change for extra from inputs)
|
//ChangePkScript (change for extra from inputs)
|
||||||
//CommitSig
|
//CommitSig
|
||||||
//Inputs
|
//Inputs
|
||||||
err := writeElements(w, false,
|
err := writeElements(w,
|
||||||
c.ReservationID,
|
c.ReservationID,
|
||||||
c.ChannelType,
|
c.ChannelType,
|
||||||
c.ResponderFundingAmount,
|
c.ResponderFundingAmount,
|
||||||
@ -180,11 +180,16 @@ func (c *FundingResponse) String() string {
|
|||||||
for i, in := range c.Inputs {
|
for i, in := range c.Inputs {
|
||||||
inputs += fmt.Sprintf("\n Slice\t%d\n", i)
|
inputs += fmt.Sprintf("\n Slice\t%d\n", i)
|
||||||
if &in != nil {
|
if &in != nil {
|
||||||
|
|
||||||
inputs += fmt.Sprintf("\tHash\t%s\n", in.PreviousOutPoint.Hash)
|
inputs += fmt.Sprintf("\tHash\t%s\n", in.PreviousOutPoint.Hash)
|
||||||
inputs += fmt.Sprintf("\tIndex\t%d\n", in.PreviousOutPoint.Index)
|
inputs += fmt.Sprintf("\tIndex\t%d\n", in.PreviousOutPoint.Index)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var serializedPubkey []byte
|
||||||
|
if &c.Pubkey != nil && c.Pubkey.X != nil {
|
||||||
|
serializedPubkey = c.Pubkey.SerializeCompressed()
|
||||||
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("\n--- Begin FundingResponse ---\n") +
|
return fmt.Sprintf("\n--- Begin FundingResponse ---\n") +
|
||||||
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
||||||
fmt.Sprintf("ReservationID:\t\t\t%d\n", c.ReservationID) +
|
fmt.Sprintf("ReservationID:\t\t\t%d\n", c.ReservationID) +
|
||||||
@ -195,7 +200,7 @@ func (c *FundingResponse) String() string {
|
|||||||
fmt.Sprintf("LockTime\t\t\t%d\n", c.LockTime) +
|
fmt.Sprintf("LockTime\t\t\t%d\n", c.LockTime) +
|
||||||
fmt.Sprintf("FeePayer\t\t\t%x\n", c.FeePayer) +
|
fmt.Sprintf("FeePayer\t\t\t%x\n", c.FeePayer) +
|
||||||
fmt.Sprintf("RevocationHash\t\t\t%x\n", c.RevocationHash) +
|
fmt.Sprintf("RevocationHash\t\t\t%x\n", c.RevocationHash) +
|
||||||
fmt.Sprintf("Pubkey\t\t\t\t%x\n", c.Pubkey.SerializeCompressed()) +
|
fmt.Sprintf("Pubkey\t\t\t\t%x\n", serializedPubkey) +
|
||||||
fmt.Sprintf("CommitSig\t\t\t%x\n", c.CommitSig.Serialize()) +
|
fmt.Sprintf("CommitSig\t\t\t%x\n", c.CommitSig.Serialize()) +
|
||||||
fmt.Sprintf("DeliveryPkScript\t\t%x\n", c.DeliveryPkScript) +
|
fmt.Sprintf("DeliveryPkScript\t\t%x\n", c.DeliveryPkScript) +
|
||||||
fmt.Sprintf("ChangePkScript\t\t%x\n", c.ChangePkScript) +
|
fmt.Sprintf("ChangePkScript\t\t%x\n", c.ChangePkScript) +
|
||||||
|
@ -21,7 +21,7 @@ func (c *FundingSignAccept) Decode(r io.Reader, pver uint32) error {
|
|||||||
// First byte is number of FundingTxSigs
|
// First byte is number of FundingTxSigs
|
||||||
// Sorted list of the requester's input signatures
|
// Sorted list of the requester's input signatures
|
||||||
// (originally provided in the Funding Request)
|
// (originally provided in the Funding Request)
|
||||||
err := readElements(r, false,
|
err := readElements(r,
|
||||||
&c.ReservationID,
|
&c.ReservationID,
|
||||||
&c.CommitSig,
|
&c.CommitSig,
|
||||||
&c.FundingTXSigs)
|
&c.FundingTXSigs)
|
||||||
@ -43,7 +43,7 @@ func (c *FundingSignAccept) Encode(w io.Writer, pver uint32) error {
|
|||||||
//ReservationID (8)
|
//ReservationID (8)
|
||||||
//CommitSig
|
//CommitSig
|
||||||
//FundingTxSigs
|
//FundingTxSigs
|
||||||
err := writeElements(w, false,
|
err := writeElements(w,
|
||||||
c.ReservationID,
|
c.ReservationID,
|
||||||
c.CommitSig,
|
c.CommitSig,
|
||||||
c.FundingTXSigs)
|
c.FundingTXSigs)
|
||||||
@ -73,13 +73,19 @@ func (c *FundingSignAccept) String() string {
|
|||||||
var sigs string
|
var sigs string
|
||||||
for i, in := range *c.FundingTXSigs {
|
for i, in := range *c.FundingTXSigs {
|
||||||
sigs += fmt.Sprintf("\n Slice\t%d\n", i)
|
sigs += fmt.Sprintf("\n Slice\t%d\n", i)
|
||||||
if &in != nil {
|
if &in != nil && in.R != nil {
|
||||||
sigs += fmt.Sprintf("\tSig\t%x\n", in.Serialize())
|
sigs += fmt.Sprintf("\tSig\t%x\n", in.Serialize())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var serializedSig []byte
|
||||||
|
if &c.CommitSig != nil && c.CommitSig.R != nil {
|
||||||
|
serializedSig = c.CommitSig.Serialize()
|
||||||
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("\n--- Begin FundingSignAccept ---\n") +
|
return fmt.Sprintf("\n--- Begin FundingSignAccept ---\n") +
|
||||||
fmt.Sprintf("ReservationID:\t\t%d\n", c.ReservationID) +
|
fmt.Sprintf("ReservationID:\t\t%d\n", c.ReservationID) +
|
||||||
fmt.Sprintf("CommitSig\t\t%x\n", c.CommitSig.Serialize()) +
|
fmt.Sprintf("CommitSig\t\t%x\n", serializedSig) +
|
||||||
fmt.Sprintf("FundingTxSigs:") +
|
fmt.Sprintf("FundingTxSigs:") +
|
||||||
sigs +
|
sigs +
|
||||||
fmt.Sprintf("--- End FundingSignAccept ---\n")
|
fmt.Sprintf("--- End FundingSignAccept ---\n")
|
||||||
|
@ -21,7 +21,7 @@ func (c *FundingSignComplete) Decode(r io.Reader, pver uint32) error {
|
|||||||
// First byte is number of FundingTxSigs
|
// First byte is number of FundingTxSigs
|
||||||
// Sorted list of the requester's input signatures
|
// Sorted list of the requester's input signatures
|
||||||
// (originally provided in the Funding Request)
|
// (originally provided in the Funding Request)
|
||||||
err := readElements(r, false,
|
err := readElements(r,
|
||||||
&c.ReservationID,
|
&c.ReservationID,
|
||||||
&c.TxID,
|
&c.TxID,
|
||||||
&c.FundingTXSigs)
|
&c.FundingTXSigs)
|
||||||
@ -43,7 +43,7 @@ func (c *FundingSignComplete) Encode(w io.Writer, pver uint32) error {
|
|||||||
//ReservationID (8)
|
//ReservationID (8)
|
||||||
//CommitSig
|
//CommitSig
|
||||||
//FundingTxSigs
|
//FundingTxSigs
|
||||||
err := writeElements(w, false,
|
err := writeElements(w,
|
||||||
c.ReservationID,
|
c.ReservationID,
|
||||||
c.TxID,
|
c.TxID,
|
||||||
c.FundingTXSigs)
|
c.FundingTXSigs)
|
||||||
@ -73,10 +73,11 @@ func (c *FundingSignComplete) String() string {
|
|||||||
var sigs string
|
var sigs string
|
||||||
for i, in := range *c.FundingTXSigs {
|
for i, in := range *c.FundingTXSigs {
|
||||||
sigs += fmt.Sprintf("\n Slice\t%d\n", i)
|
sigs += fmt.Sprintf("\n Slice\t%d\n", i)
|
||||||
if &in != nil {
|
if &in != nil && in.R != nil {
|
||||||
sigs += fmt.Sprintf("\tSig\t%x\n", in.Serialize())
|
sigs += fmt.Sprintf("\tSig\t%x\n", in.Serialize())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return fmt.Sprintf("\n--- Begin FundingSignComplete ---\n") +
|
return fmt.Sprintf("\n--- Begin FundingSignComplete ---\n") +
|
||||||
fmt.Sprintf("ReservationID:\t\t%d\n", c.ReservationID) +
|
fmt.Sprintf("ReservationID:\t\t%d\n", c.ReservationID) +
|
||||||
fmt.Sprintf("TxID\t\t%s\n", c.TxID.String()) +
|
fmt.Sprintf("TxID\t\t%s\n", c.TxID.String()) +
|
||||||
|
@ -21,7 +21,7 @@ type MicroSatoshi int32
|
|||||||
//Unified function to call when writing different types
|
//Unified function to call when writing different types
|
||||||
//Pre-allocate a byte-array of the correct size for cargo-cult security
|
//Pre-allocate a byte-array of the correct size for cargo-cult security
|
||||||
//More copies but whatever...
|
//More copies but whatever...
|
||||||
func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
func writeElement(w io.Writer, element interface{}) error {
|
||||||
var err error
|
var err error
|
||||||
switch e := element.(type) {
|
switch e := element.(type) {
|
||||||
case uint8:
|
case uint8:
|
||||||
@ -72,13 +72,13 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
return fmt.Errorf("Too many signatures!")
|
return fmt.Errorf("Too many signatures!")
|
||||||
}
|
}
|
||||||
//Write the size
|
//Write the size
|
||||||
err = writeElement(w, false, uint8(numSigs))
|
err = writeElement(w, uint8(numSigs))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
//Write the data
|
//Write the data
|
||||||
for i := 0; i < numSigs; i++ {
|
for i := 0; i < numSigs; i++ {
|
||||||
err = writeElement(w, false, &(*e)[i])
|
err = writeElement(w, &(*e)[i])
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -91,7 +91,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
return fmt.Errorf("Signature too long!")
|
return fmt.Errorf("Signature too long!")
|
||||||
}
|
}
|
||||||
//Write the size
|
//Write the size
|
||||||
err = writeElement(w, false, uint8(sigLength))
|
err = writeElement(w, uint8(sigLength))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -128,7 +128,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
return fmt.Errorf("PkScript too long!")
|
return fmt.Errorf("PkScript too long!")
|
||||||
}
|
}
|
||||||
//Write the size (1-byte)
|
//Write the size (1-byte)
|
||||||
err = writeElement(w, false, uint8(scriptLength))
|
err = writeElement(w, uint8(scriptLength))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -144,7 +144,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
if len(e) > 127 {
|
if len(e) > 127 {
|
||||||
return fmt.Errorf("Too many txins")
|
return fmt.Errorf("Too many txins")
|
||||||
}
|
}
|
||||||
err = writeElement(w, false, uint8(len(e)))
|
err = writeElement(w, uint8(len(e)))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -165,16 +165,6 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
//Signature(optional)
|
|
||||||
if includeSig {
|
|
||||||
var sig [33]byte
|
|
||||||
copy(sig[:], in.SignatureScript)
|
|
||||||
_, err = w.Write(sig[:])
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
default:
|
default:
|
||||||
@ -184,9 +174,9 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func writeElements(w io.Writer, includeSig bool, elements ...interface{}) error {
|
func writeElements(w io.Writer, elements ...interface{}) error {
|
||||||
for _, element := range elements {
|
for _, element := range elements {
|
||||||
err := writeElement(w, includeSig, element)
|
err := writeElement(w, element)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -194,7 +184,7 @@ func writeElements(w io.Writer, includeSig bool, elements ...interface{}) error
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
func readElement(r io.Reader, element interface{}) error {
|
||||||
var err error
|
var err error
|
||||||
switch e := element.(type) {
|
switch e := element.(type) {
|
||||||
case *uint8:
|
case *uint8:
|
||||||
@ -251,7 +241,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
return nil
|
return nil
|
||||||
case **[]btcec.Signature:
|
case **[]btcec.Signature:
|
||||||
var numSigs uint8
|
var numSigs uint8
|
||||||
err = readElement(r, false, &numSigs)
|
err = readElement(r, &numSigs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -263,14 +253,17 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
var sigs []btcec.Signature
|
var sigs []btcec.Signature
|
||||||
for i := uint8(0); i < numSigs; i++ {
|
for i := uint8(0); i < numSigs; i++ {
|
||||||
sig := new(btcec.Signature)
|
sig := new(btcec.Signature)
|
||||||
readElement(r, false, &sig)
|
err = readElement(r, &sig)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
sigs = append(sigs, *sig)
|
sigs = append(sigs, *sig)
|
||||||
}
|
}
|
||||||
*e = &sigs
|
*e = &sigs
|
||||||
return nil
|
return nil
|
||||||
case **btcec.Signature:
|
case **btcec.Signature:
|
||||||
var sigLength uint8
|
var sigLength uint8
|
||||||
err = readElement(r, false, &sigLength)
|
err = readElement(r, &sigLength)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -311,7 +304,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
case *PkScript:
|
case *PkScript:
|
||||||
//Get the script length first
|
//Get the script length first
|
||||||
var scriptLength uint8
|
var scriptLength uint8
|
||||||
err = readElement(r, false, &scriptLength)
|
err = readElement(r, &scriptLength)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -333,7 +326,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
case *[]*wire.TxIn:
|
case *[]*wire.TxIn:
|
||||||
//Read the size (1-byte number of txins)
|
//Read the size (1-byte number of txins)
|
||||||
var numScripts uint8
|
var numScripts uint8
|
||||||
err = readElement(r, false, &numScripts)
|
err = readElement(r, &numScripts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -362,19 +355,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
}
|
}
|
||||||
index := binary.BigEndian.Uint32(idxBytes[:])
|
index := binary.BigEndian.Uint32(idxBytes[:])
|
||||||
outPoint := wire.NewOutPoint(shaHash, index)
|
outPoint := wire.NewOutPoint(shaHash, index)
|
||||||
//Signature(optional)
|
|
||||||
if includeSig {
|
|
||||||
var sig [33]byte
|
|
||||||
_, err = io.ReadFull(r, sig[:])
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
//Create TxIn
|
|
||||||
txins = append(txins, wire.NewTxIn(outPoint, sig[:]))
|
|
||||||
} else { //no signature
|
|
||||||
//Create TxIn
|
|
||||||
txins = append(txins, wire.NewTxIn(outPoint, nil))
|
txins = append(txins, wire.NewTxIn(outPoint, nil))
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
*e = *&txins
|
*e = *&txins
|
||||||
@ -386,9 +367,9 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func readElements(r io.Reader, includeSig bool, elements ...interface{}) error {
|
func readElements(r io.Reader, elements ...interface{}) error {
|
||||||
for _, element := range elements {
|
for _, element := range elements {
|
||||||
err := readElement(r, includeSig, element)
|
err := readElement(r, element)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -398,6 +379,9 @@ func readElements(r io.Reader, includeSig bool, elements ...interface{}) error {
|
|||||||
|
|
||||||
//Validates whether a PkScript byte array is P2SH or P2PKH
|
//Validates whether a PkScript byte array is P2SH or P2PKH
|
||||||
func ValidatePkScript(pkScript PkScript) error {
|
func ValidatePkScript(pkScript PkScript) error {
|
||||||
|
if &pkScript == nil {
|
||||||
|
return fmt.Errorf("PkScript should not be empty!")
|
||||||
|
}
|
||||||
if len(pkScript) == 25 {
|
if len(pkScript) == 25 {
|
||||||
//P2PKH
|
//P2PKH
|
||||||
//Begins with OP_DUP OP_HASH160 PUSHDATA(20)
|
//Begins with OP_DUP OP_HASH160 PUSHDATA(20)
|
||||||
|
@ -68,7 +68,7 @@ func readMessageHeader(r io.Reader) (int, *messageHeader, error) {
|
|||||||
|
|
||||||
hdr := messageHeader{}
|
hdr := messageHeader{}
|
||||||
|
|
||||||
err = readElements(hr, false,
|
err = readElements(hr,
|
||||||
&hdr.magic,
|
&hdr.magic,
|
||||||
&hdr.command,
|
&hdr.command,
|
||||||
&hdr.length)
|
&hdr.length)
|
||||||
@ -134,7 +134,7 @@ func WriteMessage(w io.Writer, msg Message, pver uint32, btcnet wire.BitcoinNet)
|
|||||||
// rather than directly to the writer since writeElements doesn't
|
// rather than directly to the writer since writeElements doesn't
|
||||||
// return the number of bytes written.
|
// return the number of bytes written.
|
||||||
hw := bytes.NewBuffer(make([]byte, 0, MessageHeaderSize))
|
hw := bytes.NewBuffer(make([]byte, 0, MessageHeaderSize))
|
||||||
writeElements(hw, false, hdr.magic, hdr.command, hdr.length)
|
writeElements(hw, hdr.magic, hdr.command, hdr.length)
|
||||||
|
|
||||||
//Write header
|
//Write header
|
||||||
n, err := w.Write(hw.Bytes())
|
n, err := w.Write(hw.Bytes())
|
||||||
|
Loading…
Reference in New Issue
Block a user