transaction: fix witness script length limits
See neo-project/neo#1958.
This commit is contained in:
parent
273b803f52
commit
d029f5c0d8
2 changed files with 50 additions and 2 deletions
|
@ -6,6 +6,16 @@ import (
|
||||||
"github.com/nspcc-dev/neo-go/pkg/util"
|
"github.com/nspcc-dev/neo-go/pkg/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// MaxInvocationScript is the maximum length of allowed invocation
|
||||||
|
// script. It should fit 11/21 multisignature for the committee.
|
||||||
|
MaxInvocationScript = 1024
|
||||||
|
|
||||||
|
// MaxVerificationScript is the maximum allowed length of verification
|
||||||
|
// script. It should be appropriate for 11/21 multisignature committee.
|
||||||
|
MaxVerificationScript = 1024
|
||||||
|
)
|
||||||
|
|
||||||
// Witness contains 2 scripts.
|
// Witness contains 2 scripts.
|
||||||
type Witness struct {
|
type Witness struct {
|
||||||
InvocationScript []byte `json:"invocation"`
|
InvocationScript []byte `json:"invocation"`
|
||||||
|
@ -14,8 +24,8 @@ type Witness struct {
|
||||||
|
|
||||||
// DecodeBinary implements Serializable interface.
|
// DecodeBinary implements Serializable interface.
|
||||||
func (w *Witness) DecodeBinary(br *io.BinReader) {
|
func (w *Witness) DecodeBinary(br *io.BinReader) {
|
||||||
w.InvocationScript = br.ReadVarBytes()
|
w.InvocationScript = br.ReadVarBytes(MaxInvocationScript)
|
||||||
w.VerificationScript = br.ReadVarBytes()
|
w.VerificationScript = br.ReadVarBytes(MaxVerificationScript)
|
||||||
}
|
}
|
||||||
|
|
||||||
// EncodeBinary implements Serializable interface.
|
// EncodeBinary implements Serializable interface.
|
||||||
|
|
38
pkg/core/transaction/witness_test.go
Normal file
38
pkg/core/transaction/witness_test.go
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
package transaction
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neo-go/pkg/internal/testserdes"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestWitnessSerDes(t *testing.T) {
|
||||||
|
var good1 = &Witness{
|
||||||
|
InvocationScript: make([]byte, 64),
|
||||||
|
VerificationScript: make([]byte, 32),
|
||||||
|
}
|
||||||
|
var good2 = &Witness{
|
||||||
|
InvocationScript: make([]byte, MaxInvocationScript),
|
||||||
|
VerificationScript: make([]byte, MaxVerificationScript),
|
||||||
|
}
|
||||||
|
var bad1 = &Witness{
|
||||||
|
InvocationScript: make([]byte, MaxInvocationScript+1),
|
||||||
|
VerificationScript: make([]byte, 32),
|
||||||
|
}
|
||||||
|
var bad2 = &Witness{
|
||||||
|
InvocationScript: make([]byte, 128),
|
||||||
|
VerificationScript: make([]byte, MaxVerificationScript+1),
|
||||||
|
}
|
||||||
|
var exp = new(Witness)
|
||||||
|
testserdes.MarshalUnmarshalJSON(t, good1, exp)
|
||||||
|
testserdes.MarshalUnmarshalJSON(t, good2, exp)
|
||||||
|
testserdes.EncodeDecodeBinary(t, good1, exp)
|
||||||
|
testserdes.EncodeDecodeBinary(t, good2, exp)
|
||||||
|
bin1, err := testserdes.EncodeBinary(bad1)
|
||||||
|
require.NoError(t, err)
|
||||||
|
bin2, err := testserdes.EncodeBinary(bad2)
|
||||||
|
require.NoError(t, err)
|
||||||
|
require.Error(t, testserdes.DecodeBinary(bin1, exp))
|
||||||
|
require.Error(t, testserdes.DecodeBinary(bin2, exp))
|
||||||
|
}
|
Loading…
Reference in a new issue