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
|
||||
// First byte is number of inputs
|
||||
// For each input, it's 32bytes txin & 4bytes index
|
||||
err := readElements(r, false,
|
||||
err := readElements(r,
|
||||
&c.ChannelType,
|
||||
&c.RequesterFundingAmount,
|
||||
&c.MinTotalFundingAmount,
|
||||
@ -106,7 +106,7 @@ func (c *FundingRequest) Encode(w io.Writer, pver uint32) error {
|
||||
//DeliveryPkScript
|
||||
//ChangePkScript
|
||||
//Inputs: Append the actual Txins
|
||||
err := writeElements(w, false,
|
||||
err := writeElements(w,
|
||||
c.ChannelType,
|
||||
c.RequesterFundingAmount,
|
||||
c.MinTotalFundingAmount,
|
||||
@ -204,6 +204,12 @@ func (c *FundingRequest) String() string {
|
||||
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") +
|
||||
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
||||
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("FeePayer\t\t\t%x\n", c.FeePayer) +
|
||||
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("Inputs:") +
|
||||
inputs +
|
||||
|
@ -58,7 +58,7 @@ func (c *FundingResponse) Decode(r io.Reader, pver uint32) error {
|
||||
//Inputs: Create the TxIns
|
||||
// First byte is number of inputs
|
||||
// For each input, it's 32bytes txin & 4bytes index
|
||||
err := readElements(r, false,
|
||||
err := readElements(r,
|
||||
&c.ReservationID,
|
||||
&c.ChannelType,
|
||||
&c.ResponderFundingAmount,
|
||||
@ -101,7 +101,7 @@ func (c *FundingResponse) Encode(w io.Writer, pver uint32) error {
|
||||
//ChangePkScript (change for extra from inputs)
|
||||
//CommitSig
|
||||
//Inputs
|
||||
err := writeElements(w, false,
|
||||
err := writeElements(w,
|
||||
c.ReservationID,
|
||||
c.ChannelType,
|
||||
c.ResponderFundingAmount,
|
||||
@ -180,11 +180,16 @@ func (c *FundingResponse) String() string {
|
||||
for i, in := range c.Inputs {
|
||||
inputs += fmt.Sprintf("\n Slice\t%d\n", i)
|
||||
if &in != nil {
|
||||
|
||||
inputs += fmt.Sprintf("\tHash\t%s\n", in.PreviousOutPoint.Hash)
|
||||
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") +
|
||||
fmt.Sprintf("ChannelType:\t\t\t%x\n", c.ChannelType) +
|
||||
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("FeePayer\t\t\t%x\n", c.FeePayer) +
|
||||
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("DeliveryPkScript\t\t%x\n", c.DeliveryPkScript) +
|
||||
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
|
||||
// Sorted list of the requester's input signatures
|
||||
// (originally provided in the Funding Request)
|
||||
err := readElements(r, false,
|
||||
err := readElements(r,
|
||||
&c.ReservationID,
|
||||
&c.CommitSig,
|
||||
&c.FundingTXSigs)
|
||||
@ -43,7 +43,7 @@ func (c *FundingSignAccept) Encode(w io.Writer, pver uint32) error {
|
||||
//ReservationID (8)
|
||||
//CommitSig
|
||||
//FundingTxSigs
|
||||
err := writeElements(w, false,
|
||||
err := writeElements(w,
|
||||
c.ReservationID,
|
||||
c.CommitSig,
|
||||
c.FundingTXSigs)
|
||||
@ -73,13 +73,19 @@ func (c *FundingSignAccept) String() string {
|
||||
var sigs string
|
||||
for i, in := range *c.FundingTXSigs {
|
||||
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())
|
||||
}
|
||||
}
|
||||
|
||||
var serializedSig []byte
|
||||
if &c.CommitSig != nil && c.CommitSig.R != nil {
|
||||
serializedSig = c.CommitSig.Serialize()
|
||||
}
|
||||
|
||||
return fmt.Sprintf("\n--- Begin FundingSignAccept ---\n") +
|
||||
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:") +
|
||||
sigs +
|
||||
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
|
||||
// Sorted list of the requester's input signatures
|
||||
// (originally provided in the Funding Request)
|
||||
err := readElements(r, false,
|
||||
err := readElements(r,
|
||||
&c.ReservationID,
|
||||
&c.TxID,
|
||||
&c.FundingTXSigs)
|
||||
@ -43,7 +43,7 @@ func (c *FundingSignComplete) Encode(w io.Writer, pver uint32) error {
|
||||
//ReservationID (8)
|
||||
//CommitSig
|
||||
//FundingTxSigs
|
||||
err := writeElements(w, false,
|
||||
err := writeElements(w,
|
||||
c.ReservationID,
|
||||
c.TxID,
|
||||
c.FundingTXSigs)
|
||||
@ -73,10 +73,11 @@ func (c *FundingSignComplete) String() string {
|
||||
var sigs string
|
||||
for i, in := range *c.FundingTXSigs {
|
||||
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())
|
||||
}
|
||||
}
|
||||
|
||||
return fmt.Sprintf("\n--- Begin FundingSignComplete ---\n") +
|
||||
fmt.Sprintf("ReservationID:\t\t%d\n", c.ReservationID) +
|
||||
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
|
||||
//Pre-allocate a byte-array of the correct size for cargo-cult security
|
||||
//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
|
||||
switch e := element.(type) {
|
||||
case uint8:
|
||||
@ -72,13 +72,13 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
return fmt.Errorf("Too many signatures!")
|
||||
}
|
||||
//Write the size
|
||||
err = writeElement(w, false, uint8(numSigs))
|
||||
err = writeElement(w, uint8(numSigs))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
//Write the data
|
||||
for i := 0; i < numSigs; i++ {
|
||||
err = writeElement(w, false, &(*e)[i])
|
||||
err = writeElement(w, &(*e)[i])
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -91,7 +91,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
return fmt.Errorf("Signature too long!")
|
||||
}
|
||||
//Write the size
|
||||
err = writeElement(w, false, uint8(sigLength))
|
||||
err = writeElement(w, uint8(sigLength))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -128,7 +128,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
return fmt.Errorf("PkScript too long!")
|
||||
}
|
||||
//Write the size (1-byte)
|
||||
err = writeElement(w, false, uint8(scriptLength))
|
||||
err = writeElement(w, uint8(scriptLength))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -144,7 +144,7 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
if len(e) > 127 {
|
||||
return fmt.Errorf("Too many txins")
|
||||
}
|
||||
err = writeElement(w, false, uint8(len(e)))
|
||||
err = writeElement(w, uint8(len(e)))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -165,16 +165,6 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
if err != nil {
|
||||
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
|
||||
default:
|
||||
@ -184,9 +174,9 @@ func writeElement(w io.Writer, includeSig bool, element interface{}) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func writeElements(w io.Writer, includeSig bool, elements ...interface{}) error {
|
||||
func writeElements(w io.Writer, elements ...interface{}) error {
|
||||
for _, element := range elements {
|
||||
err := writeElement(w, includeSig, element)
|
||||
err := writeElement(w, element)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -194,7 +184,7 @@ func writeElements(w io.Writer, includeSig bool, elements ...interface{}) error
|
||||
return nil
|
||||
}
|
||||
|
||||
func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
func readElement(r io.Reader, element interface{}) error {
|
||||
var err error
|
||||
switch e := element.(type) {
|
||||
case *uint8:
|
||||
@ -251,7 +241,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
return nil
|
||||
case **[]btcec.Signature:
|
||||
var numSigs uint8
|
||||
err = readElement(r, false, &numSigs)
|
||||
err = readElement(r, &numSigs)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -263,14 +253,17 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
var sigs []btcec.Signature
|
||||
for i := uint8(0); i < numSigs; i++ {
|
||||
sig := new(btcec.Signature)
|
||||
readElement(r, false, &sig)
|
||||
err = readElement(r, &sig)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
sigs = append(sigs, *sig)
|
||||
}
|
||||
*e = &sigs
|
||||
return nil
|
||||
case **btcec.Signature:
|
||||
var sigLength uint8
|
||||
err = readElement(r, false, &sigLength)
|
||||
err = readElement(r, &sigLength)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -311,7 +304,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
case *PkScript:
|
||||
//Get the script length first
|
||||
var scriptLength uint8
|
||||
err = readElement(r, false, &scriptLength)
|
||||
err = readElement(r, &scriptLength)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -333,7 +326,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
case *[]*wire.TxIn:
|
||||
//Read the size (1-byte number of txins)
|
||||
var numScripts uint8
|
||||
err = readElement(r, false, &numScripts)
|
||||
err = readElement(r, &numScripts)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -362,19 +355,7 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
}
|
||||
index := binary.BigEndian.Uint32(idxBytes[:])
|
||||
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))
|
||||
}
|
||||
|
||||
}
|
||||
*e = *&txins
|
||||
@ -386,9 +367,9 @@ func readElement(r io.Reader, includeSig bool, element interface{}) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func readElements(r io.Reader, includeSig bool, elements ...interface{}) error {
|
||||
func readElements(r io.Reader, elements ...interface{}) error {
|
||||
for _, element := range elements {
|
||||
err := readElement(r, includeSig, element)
|
||||
err := readElement(r, element)
|
||||
if err != nil {
|
||||
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
|
||||
func ValidatePkScript(pkScript PkScript) error {
|
||||
if &pkScript == nil {
|
||||
return fmt.Errorf("PkScript should not be empty!")
|
||||
}
|
||||
if len(pkScript) == 25 {
|
||||
//P2PKH
|
||||
//Begins with OP_DUP OP_HASH160 PUSHDATA(20)
|
||||
|
@ -68,7 +68,7 @@ func readMessageHeader(r io.Reader) (int, *messageHeader, error) {
|
||||
|
||||
hdr := messageHeader{}
|
||||
|
||||
err = readElements(hr, false,
|
||||
err = readElements(hr,
|
||||
&hdr.magic,
|
||||
&hdr.command,
|
||||
&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
|
||||
// return the number of bytes written.
|
||||
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
|
||||
n, err := w.Write(hw.Bytes())
|
||||
|
Loading…
Reference in New Issue
Block a user