From 4f1cf070752176c7863d54d14fd73316287cf5b1 Mon Sep 17 00:00:00 2001 From: Anna Shaleva Date: Fri, 5 Jun 2020 21:01:21 +0300 Subject: [PATCH] compiler: add public key recovering syscalls Added Secp256r1Recover and Secp256k1Recover syscalls. --- pkg/compiler/syscall.go | 4 ++++ pkg/interop/crypto/crypto.go | 22 +++++++++++++++++++++- 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/pkg/compiler/syscall.go b/pkg/compiler/syscall.go index 086112040..e8c372020 100644 --- a/pkg/compiler/syscall.go +++ b/pkg/compiler/syscall.go @@ -11,6 +11,10 @@ var syscalls = map[string]map[string]string{ "GetUsage": "Neo.Attribute.GetUsage", "GetData": "Neo.Attribute.GetData", }, + "crypto": { + "Secp256k1Recover": "Neo.Cryptography.Secp256k1Recover", + "Secp256r1Recover": "Neo.Cryptography.Secp256r1Recover", + }, "enumerator": { "Concat": "Neo.Enumerator.Concat", "Create": "Neo.Enumerator.Create", diff --git a/pkg/interop/crypto/crypto.go b/pkg/interop/crypto/crypto.go index 5dbee46ed..02fce7c5a 100644 --- a/pkg/interop/crypto/crypto.go +++ b/pkg/interop/crypto/crypto.go @@ -1,5 +1,5 @@ /* -Package crypto provides an interface to VM cryptographic instructions. +Package crypto provides an interface to VM cryptographic instructions and syscalls. */ package crypto @@ -30,3 +30,23 @@ func Hash256(b []byte) []byte { func VerifySignature(msg []byte, sig []byte, pub []byte) bool { return false } + +// Secp256k1Recover recovers public key from the given signature (r, s) on the +// given message hash using Secp256k1 elliptic curve. Flag isEven denotes Y's +// least significant bit in decompression algorithm. The return value is byte +// array representation of the public key which is either empty (if it's not +// possible to recover key) or contains 32 bytes in BE for X point (in case of +// success). This function uses Neo.Cryptography.Secp256k1Recover syscall. +func Secp256k1Recover(r []byte, s []byte, messageHash []byte, isEven bool) []byte { + return nil +} + +// Secp256r1Recover recovers public key from the given signature (r, s) on the +// given message hash using Secp256r1 elliptic curve. Flag isEven denotes Y's +// least significant bit in decompression algorithm. The return value is byte +// array representation of the public key which is either empty (if it's not +// possible to recover key) or contains 32 bytes in BE for X point (in case of +// success). This function uses Neo.Cryptography.Secp256r1Recover syscall. +func Secp256r1Recover(r []byte, s []byte, messageHash []byte, isEven bool) []byte { + return nil +}