compiler: emit Neo.Crypto.ECDsaVerify syscall instead of CHECKSIG

Also change the name of `VerifySignature` interop, to match
syscall's name. It also accepts arguments in different order.
This commit is contained in:
Evgenii Stratonikov 2020-03-23 12:44:23 +03:00
parent 948729137f
commit 4ad29d0867
5 changed files with 20 additions and 15 deletions

View file

@ -14,7 +14,7 @@ var (
builtinFuncs = []string{ builtinFuncs = []string{
"len", "append", "SHA256", "len", "append", "SHA256",
"SHA1", "Hash256", "Hash160", "SHA1", "Hash256", "Hash160",
"VerifySignature", "AppCall", "AppCall",
"FromAddress", "Equals", "FromAddress", "Equals",
"panic", "panic",
} }

View file

@ -1063,8 +1063,6 @@ func (c *codegen) convertBuiltin(expr *ast.CallExpr) {
emit.Opcode(c.prog.BinWriter, opcode.SHA256) emit.Opcode(c.prog.BinWriter, opcode.SHA256)
case "SHA1": case "SHA1":
emit.Opcode(c.prog.BinWriter, opcode.SHA1) emit.Opcode(c.prog.BinWriter, opcode.SHA1)
case "VerifySignature":
emit.Opcode(c.prog.BinWriter, opcode.VERIFY)
case "AppCall": case "AppCall":
numArgs := len(expr.Args) - 1 numArgs := len(expr.Args) - 1
c.emitReverse(numArgs) c.emitReverse(numArgs)

View file

@ -1,6 +1,9 @@
package compiler package compiler
var syscalls = map[string]map[string]string{ var syscalls = map[string]map[string]string{
"crypto": {
"ECDsaVerify": "Neo.Crypto.ECDsaVerify",
},
"storage": { "storage": {
"GetContext": "Neo.Storage.GetContext", "GetContext": "Neo.Storage.GetContext",
"Put": "Neo.Storage.Put", "Put": "Neo.Storage.Put",

View file

@ -5,24 +5,28 @@ import (
"testing" "testing"
"github.com/nspcc-dev/neo-go/pkg/crypto/keys" "github.com/nspcc-dev/neo-go/pkg/crypto/keys"
"github.com/nspcc-dev/neo-go/pkg/vm"
"github.com/stretchr/testify/assert"
"github.com/stretchr/testify/require" "github.com/stretchr/testify/require"
) )
// In this test we only check that needed interop
// is called with the provided arguments in the right order.
func TestVerifyGood(t *testing.T) { func TestVerifyGood(t *testing.T) {
msg := []byte("test message") msg := []byte("test message")
pub, sig := signMessage(t, msg) pub, sig := signMessage(t, msg)
src := getVerifyProg(pub, sig, msg) src := getVerifyProg(pub, sig, msg)
eval(t, src, true) v, p := vmAndCompileInterop(t, src)
} p.interops[vm.InteropNameToID([]byte("Neo.Crypto.ECDsaVerify"))] = func(v *vm.VM) error {
assert.Equal(t, msg, v.Estack().Pop().Bytes())
assert.Equal(t, pub, v.Estack().Pop().Bytes())
assert.Equal(t, sig, v.Estack().Pop().Bytes())
v.Estack().PushVal(true)
return nil
}
func TestVerifyBad(t *testing.T) { require.NoError(t, v.Run())
msg := []byte("test message")
pub, sig := signMessage(t, msg)
sig[0] = ^sig[0]
src := getVerifyProg(pub, sig, msg)
eval(t, src, false)
} }
func signMessage(t *testing.T, msg []byte) ([]byte, []byte) { func signMessage(t *testing.T, msg []byte) ([]byte, []byte) {
@ -49,7 +53,7 @@ func getVerifyProg(pub, sig, msg []byte) string {
pub := ` + pubS + ` pub := ` + pubS + `
sig := ` + sigS + ` sig := ` + sigS + `
msg := ` + msgS + ` msg := ` + msgS + `
return crypto.VerifySignature(msg, sig, pub) return crypto.ECDsaVerify(msg, pub, sig)
} }
` `
} }

View file

@ -13,7 +13,7 @@ func SHA256(b []byte) []byte {
return nil return nil
} }
// VerifySignature checks that sig is msg's signature with pub. // ECDsaVerify checks that sig is msg's signature with pub.
func VerifySignature(msg []byte, sig []byte, pub []byte) bool { func ECDsaVerify(msg []byte, pub []byte, sig []byte) bool {
return false return false
} }