* Bugfixes
* Removed whether to include sigs in txin for readElement/writeElement
This commit is contained in:
Joseph Poon 2015-12-30 23:34:40 -08:00 committed by Olaoluwa Osuntokun
parent 1772108544
commit 2d3253b95d
6 changed files with 57 additions and 55 deletions

@ -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())