diff --git a/examples/engine/go.mod b/examples/engine/go.mod index a34a0d2a3..ec7beb2ec 100644 --- a/examples/engine/go.mod +++ b/examples/engine/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/engine go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/engine/go.sum b/examples/engine/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/engine/go.sum +++ b/examples/engine/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/events/go.mod b/examples/events/go.mod index 1d9b66f97..9295234c2 100644 --- a/examples/events/go.mod +++ b/examples/events/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/events go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/events/go.sum b/examples/events/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/events/go.sum +++ b/examples/events/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/iterator/go.mod b/examples/iterator/go.mod index 310eeeb8c..5fb4baa21 100644 --- a/examples/iterator/go.mod +++ b/examples/iterator/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/iterator go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/iterator/go.sum b/examples/iterator/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/iterator/go.sum +++ b/examples/iterator/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/nft-d/go.mod b/examples/nft-d/go.mod index 7b847f531..cb9257ff6 100644 --- a/examples/nft-d/go.mod +++ b/examples/nft-d/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/nft go 1.15 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/nft-d/go.sum b/examples/nft-d/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/nft-d/go.sum +++ b/examples/nft-d/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/nft-nd-nns/go.mod b/examples/nft-nd-nns/go.mod index de8e56613..651aeacb9 100644 --- a/examples/nft-nd-nns/go.mod +++ b/examples/nft-nd-nns/go.mod @@ -3,7 +3,7 @@ module github.com/nspcc-dev/neo-go/examples/nft-nd-nns go 1.16 require ( - github.com/nspcc-dev/neo-go v0.98.1-pre.0.20220125094106-e890c32dccf3 - github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 + github.com/nspcc-dev/neo-go v0.98.2-pre.0.20220301153200-78f2998b61c6 + github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e github.com/stretchr/testify v1.7.0 ) diff --git a/examples/nft-nd-nns/go.sum b/examples/nft-nd-nns/go.sum index 7b0b840cc..9bab5360e 100644 --- a/examples/nft-nd-nns/go.sum +++ b/examples/nft-nd-nns/go.sum @@ -134,6 +134,7 @@ github.com/json-iterator/go v1.1.10/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/ github.com/json-iterator/go v1.1.11/go.mod h1:KdQUCv79m/52Kvf8AW2vK1V8akMuk1QjK/uOdHXbAo4= github.com/julienschmidt/httprouter v1.2.0/go.mod h1:SYymIcj16QtmaHHD7aYtjjsJG7VTCxuUUipMqKk8s4w= github.com/julienschmidt/httprouter v1.3.0/go.mod h1:JR6WtHb+2LUe8TCKY3cZOxFyyO8IZAc4RVcycCCAKdM= +github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51/go.mod h1:CzGEWj7cYgsdH8dAjBGEr58BoE7ScuLd+fwFZ44+/x8= github.com/kkdai/bstream v0.0.0-20161212061736-f391b8402d23/go.mod h1:J+Gs4SYgM6CZQHDETBtE9HaSEkGmuNXF86RwHhHUvq4= github.com/konsorten/go-windows-terminal-sequences v1.0.1/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= github.com/konsorten/go-windows-terminal-sequences v1.0.3/go.mod h1:T0+1ngSBFLxvqU3pZ+m/2kptfBszLMUkC4ZK/EgS/cQ= @@ -175,11 +176,10 @@ github.com/nspcc-dev/hrw v1.0.9 h1:17VcAuTtrstmFppBjfRiia4K2wA/ukXZhLFS8Y8rz5Y= github.com/nspcc-dev/hrw v1.0.9/go.mod h1:l/W2vx83vMQo6aStyx2AuZrJ+07lGv2JQGlVkPG06MU= github.com/nspcc-dev/neo-go v0.73.1-pre.0.20200303142215-f5a1b928ce09/go.mod h1:pPYwPZ2ks+uMnlRLUyXOpLieaDQSEaf4NM3zHVbRjmg= github.com/nspcc-dev/neo-go v0.98.0/go.mod h1:E3cc1x6RXSXrJb2nDWXTXjnXk3rIqVN8YdFyWv+FrqM= -github.com/nspcc-dev/neo-go v0.98.1-pre.0.20220125094106-e890c32dccf3 h1:CWjuUzlwxm4ReG4PqD89/nlNEi4hGTlPh4SrSE4nXeA= -github.com/nspcc-dev/neo-go v0.98.1-pre.0.20220125094106-e890c32dccf3/go.mod h1:Rf/5TNob3k3ficd0cin9bnXO3DC7zWRErzzdZ5ah+4k= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220120102126-25583f9aeb13/go.mod h1:/zA6GVDzpSkwq8/HQJxPWDcvfn2BbZnahUO9A1wAevM= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go v0.98.2-pre.0.20220301153200-78f2998b61c6 h1:PEAaThtkL6MmPBtPW/vdo3LZqYGmmRn9/5uob2xHQL0= +github.com/nspcc-dev/neo-go v0.98.2-pre.0.20220301153200-78f2998b61c6/go.mod h1:ahEhaTYsPP78ODCXc9J6g364zEsGRlJ3Lg//REhWxaQ= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= github.com/nspcc-dev/neofs-api-go/v2 v2.11.0-pre.0.20211201134523-3604d96f3fe1/go.mod h1:oS8dycEh8PPf2Jjp6+8dlwWyEv2Dy77h/XhhcdxYEFs= github.com/nspcc-dev/neofs-api-go/v2 v2.11.1 h1:SVqc523pZsSaS9vnPS1mm3VV6b6xY0gvdA0uYJ/GWZQ= github.com/nspcc-dev/neofs-api-go/v2 v2.11.1/go.mod h1:oS8dycEh8PPf2Jjp6+8dlwWyEv2Dy77h/XhhcdxYEFs= diff --git a/examples/nft-nd/go.mod b/examples/nft-nd/go.mod index b620a47ca..0b9c1d168 100644 --- a/examples/nft-nd/go.mod +++ b/examples/nft-nd/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/nft-nd go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/nft-nd/go.sum b/examples/nft-nd/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/nft-nd/go.sum +++ b/examples/nft-nd/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/oracle/go.mod b/examples/oracle/go.mod index 4d7fa345c..db8b921e2 100644 --- a/examples/oracle/go.mod +++ b/examples/oracle/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/oracle go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/oracle/go.sum b/examples/oracle/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/oracle/go.sum +++ b/examples/oracle/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/runtime/go.mod b/examples/runtime/go.mod index 04d954d45..1b6afd941 100644 --- a/examples/runtime/go.mod +++ b/examples/runtime/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/runtime go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/runtime/go.sum b/examples/runtime/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/runtime/go.sum +++ b/examples/runtime/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/storage/go.mod b/examples/storage/go.mod index 4af3d4826..31603ac9d 100644 --- a/examples/storage/go.mod +++ b/examples/storage/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/storage go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/storage/go.sum b/examples/storage/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/storage/go.sum +++ b/examples/storage/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/timer/go.mod b/examples/timer/go.mod index b1c0192e7..17e274ac9 100644 --- a/examples/timer/go.mod +++ b/examples/timer/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/timer go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/timer/go.sum b/examples/timer/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/timer/go.sum +++ b/examples/timer/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/token-sale/go.mod b/examples/token-sale/go.mod index 8c34718c3..c8dcbc469 100644 --- a/examples/token-sale/go.mod +++ b/examples/token-sale/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/token-sale go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/token-sale/go.sum b/examples/token-sale/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/token-sale/go.sum +++ b/examples/token-sale/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/examples/token/go.mod b/examples/token/go.mod index a23a905b2..104bb897b 100644 --- a/examples/token/go.mod +++ b/examples/token/go.mod @@ -2,4 +2,4 @@ module github.com/nspcc-dev/neo-go/examples/token go 1.16 -require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 +require github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e diff --git a/examples/token/go.sum b/examples/token/go.sum index c830a4ae5..e3c8473b4 100644 --- a/examples/token/go.sum +++ b/examples/token/go.sum @@ -1,2 +1,2 @@ -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= diff --git a/go.mod b/go.mod index 2c5c7e4be..c4eecad76 100644 --- a/go.mod +++ b/go.mod @@ -11,7 +11,7 @@ require ( github.com/mr-tron/base58 v1.2.0 github.com/nspcc-dev/dbft v0.0.0-20210721160347-1b03241391ac github.com/nspcc-dev/go-ordered-json v0.0.0-20220111165707-25110be27d22 - github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 + github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e github.com/nspcc-dev/neofs-sdk-go v0.0.0-20220113123743-7f3162110659 github.com/nspcc-dev/rfc6979 v0.2.0 github.com/pierrec/lz4 v2.6.1+incompatible diff --git a/go.sum b/go.sum index 3806d2704..2d53fa82e 100644 --- a/go.sum +++ b/go.sum @@ -182,8 +182,10 @@ github.com/nspcc-dev/hrw v1.0.9 h1:17VcAuTtrstmFppBjfRiia4K2wA/ukXZhLFS8Y8rz5Y= github.com/nspcc-dev/hrw v1.0.9/go.mod h1:l/W2vx83vMQo6aStyx2AuZrJ+07lGv2JQGlVkPG06MU= github.com/nspcc-dev/neo-go v0.73.1-pre.0.20200303142215-f5a1b928ce09/go.mod h1:pPYwPZ2ks+uMnlRLUyXOpLieaDQSEaf4NM3zHVbRjmg= github.com/nspcc-dev/neo-go v0.98.0/go.mod h1:E3cc1x6RXSXrJb2nDWXTXjnXk3rIqVN8YdFyWv+FrqM= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7 h1:8PxWk/d0NKfv5vU2Q0hdaDpocQvR7qxPDsIHQwFR79M= -github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220131192108-37ca96c20bf7/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301151951-4377d8f16e3d h1:6WFvxZkYdG7bQHBChmRO8HdfizM/Tc85QAwCh6tAgKY= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301151951-4377d8f16e3d/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e h1:D/S/V42XWvfn26DRjA+QoLHB2XdqPWfjj3R3Qv+NU/U= +github.com/nspcc-dev/neo-go/pkg/interop v0.0.0-20220301152507-4c415683e74e/go.mod h1:QBE0I30F2kOAISNpT5oks82yF4wkkUq3SCfI3Hqgx/Y= github.com/nspcc-dev/neofs-api-go/v2 v2.11.0-pre.0.20211201134523-3604d96f3fe1/go.mod h1:oS8dycEh8PPf2Jjp6+8dlwWyEv2Dy77h/XhhcdxYEFs= github.com/nspcc-dev/neofs-api-go/v2 v2.11.1 h1:SVqc523pZsSaS9vnPS1mm3VV6b6xY0gvdA0uYJ/GWZQ= github.com/nspcc-dev/neofs-api-go/v2 v2.11.1/go.mod h1:oS8dycEh8PPf2Jjp6+8dlwWyEv2Dy77h/XhhcdxYEFs= diff --git a/internal/fakechain/fakechain.go b/internal/fakechain/fakechain.go index 5255d6adb..4c559c040 100644 --- a/internal/fakechain/fakechain.go +++ b/internal/fakechain/fakechain.go @@ -139,6 +139,11 @@ func (chain *FakeChain) GetNotaryBalance(acc util.Uint160) *big.Int { panic("TODO") } +// GetNotaryServiceFeePerKey implements Blockchainer interface. +func (chain *FakeChain) GetNotaryServiceFeePerKey() int64 { + panic("TODO") +} + // GetBaseExecFee implements Policer interface. func (chain *FakeChain) GetBaseExecFee() int64 { return interop.DefaultBaseExecFee diff --git a/pkg/compiler/native_test.go b/pkg/compiler/native_test.go index 9aa5efa45..ab0d3c586 100644 --- a/pkg/compiler/native_test.go +++ b/pkg/compiler/native_test.go @@ -156,6 +156,8 @@ func TestNativeHelpersCompile(t *testing.T) { {"expirationOf", []string{u160}}, {"getMaxNotValidBeforeDelta", nil}, {"setMaxNotValidBeforeDelta", []string{"42"}}, + {"getNotaryServiceFeePerKey", nil}, + {"setNotaryServiceFeePerKey", []string{"42"}}, }) runNativeTestCases(t, cs.Management.ContractMD, "management", []nativeTestCase{ {"deploy", []string{"nil", "nil"}}, diff --git a/pkg/core/blockchain.go b/pkg/core/blockchain.go index e86b1fe0b..3694d0459 100644 --- a/pkg/core/blockchain.go +++ b/pkg/core/blockchain.go @@ -1502,6 +1502,12 @@ func (bc *Blockchain) GetNotaryBalance(acc util.Uint160) *big.Int { return bc.contracts.Notary.BalanceOf(bc.dao, acc) } +// GetNotaryServiceFeePerKey returns NotaryServiceFeePerKey which is a reward per +// notary request key for designated notary nodes. +func (bc *Blockchain) GetNotaryServiceFeePerKey() int64 { + return bc.contracts.Notary.GetNotaryServiceFeePerKey(bc.dao) +} + // GetNotaryContractScriptHash returns Notary native contract hash. func (bc *Blockchain) GetNotaryContractScriptHash() util.Uint160 { if bc.P2PSigExtensionsEnabled() { @@ -1916,7 +1922,7 @@ func (bc *Blockchain) verifyAndPoolTx(t *transaction.Transaction, pool *mempool. attrs := t.GetAttributes(transaction.NotaryAssistedT) if len(attrs) != 0 { na := attrs[0].Value.(*transaction.NotaryAssisted) - needNetworkFee += (int64(na.NKeys) + 1) * transaction.NotaryServiceFeePerKey + needNetworkFee += (int64(na.NKeys) + 1) * bc.contracts.Notary.GetNotaryServiceFeePerKey(bc.dao) } } netFee := t.NetworkFee - needNetworkFee @@ -2260,7 +2266,7 @@ func (bc *Blockchain) verifyTxWitnesses(t *transaction.Transaction, block *block attrs := t.GetAttributes(transaction.NotaryAssistedT) if len(attrs) != 0 { na := attrs[0].Value.(*transaction.NotaryAssisted) - gasLimit -= (int64(na.NKeys) + 1) * transaction.NotaryServiceFeePerKey + gasLimit -= (int64(na.NKeys) + 1) * bc.contracts.Notary.GetNotaryServiceFeePerKey(bc.dao) } } for i := range t.Signers { diff --git a/pkg/core/blockchain_test.go b/pkg/core/blockchain_test.go index fd4bfb7d0..7e827461e 100644 --- a/pkg/core/blockchain_test.go +++ b/pkg/core/blockchain_test.go @@ -318,6 +318,8 @@ func TestVerifyTx(t *testing.T) { require.NoError(t, err) } + notaryServiceFeePerKey := bc.contracts.Notary.GetNotaryServiceFeePerKey(bc.dao) + oracleAcc := accs[2] oraclePubs := keys.PublicKeys{oracleAcc.PrivateKey().PublicKey()} require.NoError(t, oracleAcc.ConvertMultisig(1, oraclePubs)) @@ -893,7 +895,7 @@ func TestVerifyTx(t *testing.T) { t.Run("Test verify", func(t *testing.T) { bc.config.P2PSigExtensions = true t.Run("no NotaryAssisted attribute", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Attributes = []transaction.Attribute{} tx.Signers = []transaction.Signer{ { @@ -917,7 +919,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("no deposit", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Signers = []transaction.Signer{ { Account: bc.contracts.Notary.Hash, @@ -940,7 +942,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("bad Notary signer scope", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Signers = []transaction.Signer{ { Account: testchain.CommitteeScriptHash(), @@ -963,7 +965,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("not signed by Notary", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Signers = []transaction.Signer{ { Account: testchain.CommitteeScriptHash(), @@ -979,7 +981,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("bad Notary node witness", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Signers = []transaction.Signer{ { Account: testchain.CommitteeScriptHash(), @@ -1004,7 +1006,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("missing payer", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) tx.Signers = []transaction.Signer{ { Account: bc.contracts.Notary.Hash, @@ -1019,7 +1021,7 @@ func TestVerifyTx(t *testing.T) { require.Error(t, bc.VerifyTx(tx)) }) t.Run("positive", func(t *testing.T) { - tx := getNotaryAssistedTx(1, (1+1)*transaction.NotaryServiceFeePerKey) + tx := getNotaryAssistedTx(1, (1+1)*notaryServiceFeePerKey) require.NoError(t, bc.VerifyTx(tx)) }) }) @@ -1057,7 +1059,7 @@ func TestVerifyTx(t *testing.T) { int64(sizeDelta)*bc.FeePerByte() + // fee for multisig size 66*bc.FeePerByte() + // fee for Notary signature size (66 bytes for Invocation script and 0 bytes for Verification script) 2*bc.FeePerByte() + // fee for the length of each script in Notary witness (they are nil, so we did not take them into account during `size` calculation) - transaction.NotaryServiceFeePerKey + // fee for Notary attribute + notaryServiceFeePerKey + // fee for Notary attribute fee.Opcode(bc.GetBaseExecFee(), // Notary verification script opcode.PUSHDATA1, opcode.RET, // invocation script opcode.PUSH0, opcode.SYSCALL, opcode.RET) + // Neo.Native.Call diff --git a/pkg/core/blockchainer/blockchainer.go b/pkg/core/blockchainer/blockchainer.go index 307e79990..a6e20e48e 100644 --- a/pkg/core/blockchainer/blockchainer.go +++ b/pkg/core/blockchainer/blockchainer.go @@ -55,6 +55,7 @@ type Blockchainer interface { GetTokenLastUpdated(acc util.Uint160) (map[int32]uint32, error) GetNotaryContractScriptHash() util.Uint160 GetNotaryBalance(acc util.Uint160) *big.Int + GetNotaryServiceFeePerKey() int64 GetValidators() ([]*keys.PublicKey, error) GetStateModule() StateRoot GetStorageItem(id int32, key []byte) state.StorageItem diff --git a/pkg/core/native/contract.go b/pkg/core/native/contract.go index 133f72c95..95faa2467 100644 --- a/pkg/core/native/contract.go +++ b/pkg/core/native/contract.go @@ -109,6 +109,7 @@ func NewContracts(cfg config.ProtocolConfiguration) *Contracts { notary.NEO = neo notary.Desig = desig cs.Notary = notary + gas.Notary = notary cs.Contracts = append(cs.Contracts, notary) } diff --git a/pkg/core/native/native_gas.go b/pkg/core/native/native_gas.go index 0e51f985f..d02b672e5 100644 --- a/pkg/core/native/native_gas.go +++ b/pkg/core/native/native_gas.go @@ -19,6 +19,8 @@ import ( type GAS struct { nep17TokenNative NEO *NEO + // Notary is a native Notary contract. It is set only when P2PSigExtensions are on. + Notary *Notary initialSupply int64 p2pSigExtensionsEnabled bool @@ -117,7 +119,7 @@ func (g *GAS) OnPersist(ic *interop.Context) error { attrs := tx.GetAttributes(transaction.NotaryAssistedT) if len(attrs) != 0 { na := attrs[0].Value.(*transaction.NotaryAssisted) - netFee -= (int64(na.NKeys) + 1) * transaction.NotaryServiceFeePerKey + netFee -= (int64(na.NKeys) + 1) * g.Notary.GetNotaryServiceFeePerKey(ic.DAO) } } } diff --git a/pkg/core/native/native_nep17.go b/pkg/core/native/native_nep17.go index e03069521..021364b5d 100644 --- a/pkg/core/native/native_nep17.go +++ b/pkg/core/native/native_nep17.go @@ -342,3 +342,11 @@ func toUint32(s stackitem.Item) uint32 { } return uint32(uint64Value) } + +func toInt64(s stackitem.Item) int64 { + bigInt := toBigInt(s) + if !bigInt.IsInt64() { + panic("bigint is not an uint64") + } + return bigInt.Int64() +} diff --git a/pkg/core/native/native_test/gas_test.go b/pkg/core/native/native_test/gas_test.go index 27205d6d1..8e5b2b3d4 100644 --- a/pkg/core/native/native_test/gas_test.go +++ b/pkg/core/native/native_test/gas_test.go @@ -71,6 +71,7 @@ func TestGAS_RewardWithP2PSigExtensionsEnabled(t *testing.T) { e := neotest.NewExecutor(t, bc, validator, committee) gasCommitteeInvoker := e.CommitteeInvoker(e.NativeHash(t, nativenames.Gas)) notaryHash := e.NativeHash(t, nativenames.Notary) + notaryServiceFeePerKey := e.Chain.GetNotaryServiceFeePerKey() // transfer funds to committee e.ValidatorInvoker(e.NativeHash(t, nativenames.Gas)).Invoke(t, true, "transfer", e.Validator.ScriptHash(), e.CommitteeHash, 1000_0000_0000, nil) @@ -90,7 +91,7 @@ func TestGAS_RewardWithP2PSigExtensionsEnabled(t *testing.T) { } // deposit GAS for `signer` with lock until the next block - depositAmount := 100_0000 + (2+int64(nKeys))*transaction.NotaryServiceFeePerKey // sysfee + netfee of the next transaction + depositAmount := 100_0000 + (2+int64(nKeys))*notaryServiceFeePerKey // sysfee + netfee of the next transaction gasCommitteeInvoker.Invoke(t, true, "transfer", e.CommitteeHash, notaryHash, depositAmount, []interface{}{e.CommitteeHash, e.Chain.BlockHeight() + 1}) // save initial GAS total supply @@ -106,7 +107,7 @@ func TestGAS_RewardWithP2PSigExtensionsEnabled(t *testing.T) { tx.Nonce = neotest.Nonce() tx.ValidUntilBlock = e.Chain.BlockHeight() + 1 tx.Attributes = append(tx.Attributes, transaction.Attribute{Type: transaction.NotaryAssistedT, Value: &transaction.NotaryAssisted{NKeys: uint8(nKeys)}}) - tx.NetworkFee = (2 + int64(nKeys)) * transaction.NotaryServiceFeePerKey + tx.NetworkFee = (2 + int64(nKeys)) * notaryServiceFeePerKey tx.Signers = []transaction.Signer{ { Account: notaryHash, @@ -131,7 +132,7 @@ func TestGAS_RewardWithP2PSigExtensionsEnabled(t *testing.T) { // check balance of notaries e.CheckGASBalance(t, notaryHash, big.NewInt(int64(depositAmount-tx.SystemFee-tx.NetworkFee))) for _, notaryNode := range notaryNodes { - e.CheckGASBalance(t, notaryNode.GetScriptHash(), big.NewInt(int64(transaction.NotaryServiceFeePerKey*(nKeys+1)/nNotaries))) + e.CheckGASBalance(t, notaryNode.GetScriptHash(), big.NewInt(notaryServiceFeePerKey*(nKeys+1)/nNotaries)) } tsUpdated := getGASTS(t) tsExpected := tsInitial + 5000_0000 - tx.SystemFee diff --git a/pkg/core/native/native_test/notary_test.go b/pkg/core/native/native_test/notary_test.go index 42094f8af..fd948294e 100644 --- a/pkg/core/native/native_test/notary_test.go +++ b/pkg/core/native/native_test/notary_test.go @@ -32,6 +32,11 @@ func TestNotary_MaxNotValidBeforeDelta(t *testing.T) { testGetSet(t, c, "MaxNotValidBeforeDelta", 140, int64(c.Chain.GetConfig().ValidatorsCount), int64(c.Chain.GetConfig().MaxValidUntilBlockIncrement/2)) } +func TestNotary_NotaryServiceFeePerKey(t *testing.T) { + c := newNotaryClient(t) + testGetSet(t, c, "NotaryServiceFeePerKey", 1000_0000, 0, 0) +} + func TestNotary_Pipeline(t *testing.T) { notaryCommitteeInvoker := newNotaryClient(t) e := notaryCommitteeInvoker.Executor @@ -39,11 +44,12 @@ func TestNotary_Pipeline(t *testing.T) { gasCommitteeInvoker := e.CommitteeInvoker(e.NativeHash(t, nativenames.Gas)) notaryHash := notaryCommitteeInvoker.NativeHash(t, nativenames.Notary) + feePerKey := e.Chain.GetNotaryServiceFeePerKey() multisigHash := notaryCommitteeInvoker.Validator.ScriptHash() // matches committee's one for single chain depositLock := 100 - checkBalanceOf := func(t *testing.T, acc util.Uint160, expected int) { // we don't have big numbers in this test, thus may use int - notaryCommitteeInvoker.CheckGASBalance(t, acc, big.NewInt(int64(expected))) + checkBalanceOf := func(t *testing.T, acc util.Uint160, expected int64) { // we don't have big numbers in this test, thus may use int + notaryCommitteeInvoker.CheckGASBalance(t, acc, big.NewInt(expected)) } // check Notary contract has no GAS on the account @@ -62,47 +68,47 @@ func TestNotary_Pipeline(t *testing.T) { neoCommitteeInvoker.InvokeFail(t, "only GAS can be accepted for deposit", "transfer", multisigHash, notaryHash, int64(1), []interface{}{nil, int64(depositLock)}) // `onPayment`: insufficient first deposit - gasCommitteeInvoker.InvokeFail(t, "first deposit can not be less then", "transfer", multisigHash, notaryHash, int64(2*transaction.NotaryServiceFeePerKey-1), []interface{}{nil, int64(depositLock)}) + gasCommitteeInvoker.InvokeFail(t, "first deposit can not be less then", "transfer", multisigHash, notaryHash, int64(2*feePerKey-1), []interface{}{nil, int64(depositLock)}) // `onPayment`: invalid `data` (missing `till` parameter) - gasCommitteeInvoker.InvokeFail(t, "`data` parameter should be an array of 2 elements", "transfer", multisigHash, notaryHash, 2*transaction.NotaryServiceFeePerKey, []interface{}{nil}) + gasCommitteeInvoker.InvokeFail(t, "`data` parameter should be an array of 2 elements", "transfer", multisigHash, notaryHash, 2*feePerKey, []interface{}{nil}) // `onPayment`: invalid `data` (outdated `till` parameter) - gasCommitteeInvoker.InvokeFail(t, "`till` shouldn't be less then the chain's height", "transfer", multisigHash, notaryHash, 2*transaction.NotaryServiceFeePerKey, []interface{}{nil, int64(0)}) + gasCommitteeInvoker.InvokeFail(t, "`till` shouldn't be less then the chain's height", "transfer", multisigHash, notaryHash, 2*feePerKey, []interface{}{nil, int64(0)}) // `onPayment`: good - gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, 2*transaction.NotaryServiceFeePerKey, []interface{}{nil, int64(depositLock)}) - checkBalanceOf(t, notaryHash, 2*transaction.NotaryServiceFeePerKey) + gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, 2*feePerKey, []interface{}{nil, int64(depositLock)}) + checkBalanceOf(t, notaryHash, 2*feePerKey) // `expirationOf`: check `till` was set notaryCommitteeInvoker.Invoke(t, depositLock, "expirationOf", multisigHash) // `balanceOf`: check deposited amount for the multisig account - notaryCommitteeInvoker.Invoke(t, 2*transaction.NotaryServiceFeePerKey, "balanceOf", multisigHash) + notaryCommitteeInvoker.Invoke(t, 2*feePerKey, "balanceOf", multisigHash) // `onPayment`: good second deposit and explicit `to` paramenter - gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, transaction.NotaryServiceFeePerKey, []interface{}{multisigHash, int64(depositLock + 1)}) - checkBalanceOf(t, notaryHash, 3*transaction.NotaryServiceFeePerKey) + gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, feePerKey, []interface{}{multisigHash, int64(depositLock + 1)}) + checkBalanceOf(t, notaryHash, 3*feePerKey) // `balanceOf`: check deposited amount for the multisig account - notaryCommitteeInvoker.Invoke(t, 3*transaction.NotaryServiceFeePerKey, "balanceOf", multisigHash) + notaryCommitteeInvoker.Invoke(t, 3*feePerKey, "balanceOf", multisigHash) // `expirationOf`: check `till` is updated. notaryCommitteeInvoker.Invoke(t, depositLock+1, "expirationOf", multisigHash) // `onPayment`: empty payment, should fail because `till` less then the previous one gasCommitteeInvoker.InvokeFail(t, "`till` shouldn't be less then the previous value", "transfer", multisigHash, notaryHash, int64(0), []interface{}{multisigHash, int64(depositLock)}) - checkBalanceOf(t, notaryHash, 3*transaction.NotaryServiceFeePerKey) + checkBalanceOf(t, notaryHash, 3*feePerKey) notaryCommitteeInvoker.Invoke(t, depositLock+1, "expirationOf", multisigHash) // `onPayment`: empty payment, should fail because `till` less then the chain height gasCommitteeInvoker.InvokeFail(t, "`till` shouldn't be less then the chain's height", "transfer", multisigHash, notaryHash, int64(0), []interface{}{multisigHash, int64(1)}) - checkBalanceOf(t, notaryHash, 3*transaction.NotaryServiceFeePerKey) + checkBalanceOf(t, notaryHash, 3*feePerKey) notaryCommitteeInvoker.Invoke(t, depositLock+1, "expirationOf", multisigHash) // `onPayment`: empty payment, should successfully update `till` gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, int64(0), []interface{}{multisigHash, int64(depositLock + 2)}) - checkBalanceOf(t, notaryHash, 3*transaction.NotaryServiceFeePerKey) + checkBalanceOf(t, notaryHash, 3*feePerKey) notaryCommitteeInvoker.Invoke(t, depositLock+2, "expirationOf", multisigHash) // `lockDepositUntil`: bad witness @@ -127,11 +133,11 @@ func TestNotary_Pipeline(t *testing.T) { // `withdraw`: bad witness notaryAccInvoker.Invoke(t, false, "withdraw", multisigHash, accHash) - notaryCommitteeInvoker.Invoke(t, 3*transaction.NotaryServiceFeePerKey, "balanceOf", multisigHash) + notaryCommitteeInvoker.Invoke(t, 3*feePerKey, "balanceOf", multisigHash) // `withdraw`: locked deposit notaryCommitteeInvoker.Invoke(t, false, "withdraw", multisigHash, multisigHash) - notaryCommitteeInvoker.Invoke(t, 3*transaction.NotaryServiceFeePerKey, "balanceOf", multisigHash) + notaryCommitteeInvoker.Invoke(t, 3*feePerKey, "balanceOf", multisigHash) // `withdraw`: unlock deposit and transfer GAS back to owner e.GenerateNewBlocks(t, depositLock) @@ -143,13 +149,13 @@ func TestNotary_Pipeline(t *testing.T) { notaryCommitteeInvoker.Invoke(t, false, "withdraw", multisigHash, accHash) // `onPayment`: good first deposit to other account, should set default `till` even if other `till` value is provided - gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, 2*transaction.NotaryServiceFeePerKey, []interface{}{accHash, int64(math.MaxUint32 - 1)}) - checkBalanceOf(t, notaryHash, 2*transaction.NotaryServiceFeePerKey) + gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, 2*feePerKey, []interface{}{accHash, int64(math.MaxUint32 - 1)}) + checkBalanceOf(t, notaryHash, 2*feePerKey) notaryCommitteeInvoker.Invoke(t, 5760+e.Chain.BlockHeight()-1, "expirationOf", accHash) // `onPayment`: good second deposit to other account, shouldn't update `till` even if other `till` value is provided - gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, transaction.NotaryServiceFeePerKey, []interface{}{accHash, int64(math.MaxUint32 - 1)}) - checkBalanceOf(t, notaryHash, 3*transaction.NotaryServiceFeePerKey) + gasCommitteeInvoker.Invoke(t, true, "transfer", multisigHash, notaryHash, feePerKey, []interface{}{accHash, int64(math.MaxUint32 - 1)}) + checkBalanceOf(t, notaryHash, 3*feePerKey) notaryCommitteeInvoker.Invoke(t, 5760+e.Chain.BlockHeight()-3, "expirationOf", accHash) } @@ -161,6 +167,7 @@ func TestNotary_NotaryNodesReward(t *testing.T) { designationCommitteeInvoker := e.CommitteeInvoker(e.NativeHash(t, nativenames.Designation)) notaryHash := notaryCommitteeInvoker.NativeHash(t, nativenames.Notary) + feePerKey := e.Chain.GetNotaryServiceFeePerKey() multisigHash := notaryCommitteeInvoker.Validator.ScriptHash() // matches committee's one for single chain var err error @@ -180,7 +187,7 @@ func TestNotary_NotaryNodesReward(t *testing.T) { } // deposit GAS for `signer` with lock until the next block - depositAmount := 100_0000 + (2+int64(nKeys))*transaction.NotaryServiceFeePerKey // sysfee + netfee of the next transaction + depositAmount := 100_0000 + (2+int64(nKeys))*feePerKey // sysfee + netfee of the next transaction if !spendFullDeposit { depositAmount += 1_0000 } @@ -191,7 +198,7 @@ func TestNotary_NotaryNodesReward(t *testing.T) { tx.Nonce = neotest.Nonce() tx.ValidUntilBlock = e.Chain.BlockHeight() + 1 tx.Attributes = append(tx.Attributes, transaction.Attribute{Type: transaction.NotaryAssistedT, Value: &transaction.NotaryAssisted{NKeys: uint8(nKeys)}}) - tx.NetworkFee = (2 + int64(nKeys)) * transaction.NotaryServiceFeePerKey + tx.NetworkFee = (2 + int64(nKeys)) * feePerKey tx.Signers = []transaction.Signer{ { Account: notaryHash, @@ -215,7 +222,7 @@ func TestNotary_NotaryNodesReward(t *testing.T) { e.CheckGASBalance(t, notaryHash, big.NewInt(int64(depositAmount-tx.SystemFee-tx.NetworkFee))) for _, notaryNode := range notaryNodes { - e.CheckGASBalance(t, notaryNode.GetScriptHash(), big.NewInt(int64(transaction.NotaryServiceFeePerKey*(nKeys+1)/nNotaryNodes))) + e.CheckGASBalance(t, notaryNode.GetScriptHash(), big.NewInt(feePerKey*int64((nKeys+1))/int64(nNotaryNodes))) } } diff --git a/pkg/core/native/notary.go b/pkg/core/native/notary.go index c13bdebb0..086a11da1 100644 --- a/pkg/core/native/notary.go +++ b/pkg/core/native/notary.go @@ -39,6 +39,7 @@ type Notary struct { // blockchain DAO persisting. If true, we can safely use cached values. isValid bool maxNotValidBeforeDelta uint32 + notaryServiceFeePerKey int64 } const ( @@ -46,10 +47,14 @@ const ( // prefixDeposit is a prefix for storing Notary deposits. prefixDeposit = 1 defaultDepositDeltaTill = 5760 - defaultMaxNotValidBeforeDelta = 140 // 20 rounds for 7 validators, a little more than half an hour + defaultMaxNotValidBeforeDelta = 140 // 20 rounds for 7 validators, a little more than half an hour + defaultNotaryServiceFeePerKey = 1000_0000 // 0.1 GAS ) -var maxNotValidBeforeDeltaKey = []byte{10} +var ( + maxNotValidBeforeDeltaKey = []byte{10} + notaryServiceFeeKey = []byte{5} +) // newNotary returns Notary native contract. func newNotary() *Notary { @@ -99,6 +104,15 @@ func newNotary() *Notary { md = newMethodAndPrice(n.setMaxNotValidBeforeDelta, 1<<15, callflag.States) n.AddMethod(md, desc) + desc = newDescriptor("getNotaryServiceFeePerKey", smartcontract.IntegerType) + md = newMethodAndPrice(n.getNotaryServiceFeePerKey, 1<<15, callflag.ReadStates) + n.AddMethod(md, desc) + + desc = newDescriptor("setNotaryServiceFeePerKey", smartcontract.VoidType, + manifest.NewParameter("value", smartcontract.IntegerType)) + md = newMethodAndPrice(n.setNotaryServiceFeePerKey, 1<<15, callflag.States) + n.AddMethod(md, desc) + return n } @@ -110,8 +124,10 @@ func (n *Notary) Metadata() *interop.ContractMD { // Initialize initializes Notary native contract and implements Contract interface. func (n *Notary) Initialize(ic *interop.Context) error { setIntWithKey(n.ID, ic.DAO, maxNotValidBeforeDeltaKey, defaultMaxNotValidBeforeDelta) + setIntWithKey(n.ID, ic.DAO, notaryServiceFeeKey, defaultNotaryServiceFeePerKey) n.isValid = true n.maxNotValidBeforeDelta = defaultMaxNotValidBeforeDelta + n.notaryServiceFeePerKey = defaultNotaryServiceFeePerKey return nil } @@ -150,7 +166,8 @@ func (n *Notary) OnPersist(ic *interop.Context) error { if nFees == 0 { return nil } - singleReward := calculateNotaryReward(nFees, len(notaries)) + feePerKey := n.GetNotaryServiceFeePerKey(ic.DAO) + singleReward := calculateNotaryReward(nFees, feePerKey, len(notaries)) for _, notary := range notaries { n.GAS.mint(ic, notary.GetScriptHash(), singleReward, false) } @@ -166,6 +183,7 @@ func (n *Notary) PostPersist(ic *interop.Context) error { } n.maxNotValidBeforeDelta = uint32(getIntWithKey(n.ID, ic.DAO, maxNotValidBeforeDeltaKey)) + n.notaryServiceFeePerKey = getIntWithKey(n.ID, ic.DAO, notaryServiceFeeKey) n.isValid = true return nil } @@ -198,9 +216,10 @@ func (n *Notary) onPayment(ic *interop.Context, args []stackitem.Item) stackitem if deposit != nil && till < deposit.Till { panic(fmt.Errorf("`till` shouldn't be less then the previous value %d", deposit.Till)) } + feePerKey := n.GetNotaryServiceFeePerKey(ic.DAO) if deposit == nil { - if amount.Cmp(big.NewInt(2*transaction.NotaryServiceFeePerKey)) < 0 { - panic(fmt.Errorf("first deposit can not be less then %d, got %d", 2*transaction.NotaryServiceFeePerKey, amount.Int64())) + if amount.Cmp(big.NewInt(2*feePerKey)) < 0 { + panic(fmt.Errorf("first deposit can not be less then %d, got %d", 2*feePerKey, amount.Int64())) } deposit = &state.Deposit{ Amount: new(big.Int), @@ -398,6 +417,37 @@ func (n *Notary) setMaxNotValidBeforeDelta(ic *interop.Context, args []stackitem return stackitem.Null{} } +// getNotaryServiceFeePerKey is Notary contract method and returns a reward per notary request key for notary nodes. +func (n *Notary) getNotaryServiceFeePerKey(ic *interop.Context, _ []stackitem.Item) stackitem.Item { + return stackitem.NewBigInteger(big.NewInt(int64(n.GetNotaryServiceFeePerKey(ic.DAO)))) +} + +// GetNotaryServiceFeePerKey is an internal representation of Notary getNotaryServiceFeePerKey method. +func (n *Notary) GetNotaryServiceFeePerKey(dao *dao.Simple) int64 { + n.lock.RLock() + defer n.lock.RUnlock() + if n.isValid { + return n.notaryServiceFeePerKey + } + return getIntWithKey(n.ID, dao, notaryServiceFeeKey) +} + +// setNotaryServiceFeePerKey is Notary contract method and sets a reward per notary request key for notary nodes. +func (n *Notary) setNotaryServiceFeePerKey(ic *interop.Context, args []stackitem.Item) stackitem.Item { + value := toInt64(args[0]) + if value < 0 { + panic("NotaryServiceFeePerKey can't be negative") + } + if !n.NEO.checkCommittee(ic) { + panic("invalid committee signature") + } + n.lock.Lock() + defer n.lock.Unlock() + setIntWithKey(n.ID, ic.DAO, notaryServiceFeeKey, int64(value)) + n.isValid = false + return stackitem.Null{} +} + // GetDepositFor returns state.Deposit for the account specified. It returns nil in case if // deposit is not found in storage and panics in case of any other error. func (n *Notary) GetDepositFor(dao *dao.Simple, acc util.Uint160) *state.Deposit { @@ -426,6 +476,6 @@ func (n *Notary) removeDepositFor(dao *dao.Simple, acc util.Uint160) { } // calculateNotaryReward calculates the reward for a single notary node based on FEE's count and Notary nodes count. -func calculateNotaryReward(nFees int64, notariesCount int) *big.Int { - return big.NewInt(nFees * transaction.NotaryServiceFeePerKey / int64(notariesCount)) +func calculateNotaryReward(nFees int64, feePerKey int64, notariesCount int) *big.Int { + return big.NewInt(nFees * feePerKey / int64(notariesCount)) } diff --git a/pkg/core/transaction/notary_assisted.go b/pkg/core/transaction/notary_assisted.go index 119dc6a3b..bac00c3ba 100644 --- a/pkg/core/transaction/notary_assisted.go +++ b/pkg/core/transaction/notary_assisted.go @@ -6,9 +6,6 @@ import ( "github.com/nspcc-dev/neo-go/pkg/io" ) -// NotaryServiceFeePerKey is a reward per key for notary nodes. -const NotaryServiceFeePerKey = 1000_0000 // 0.1 GAS - // NotaryAssisted represents attribute for notary service transactions. type NotaryAssisted struct { NKeys uint8 `json:"nkeys"` diff --git a/pkg/interop/native/notary/notary.go b/pkg/interop/native/notary/notary.go index 7c1907a6e..cacfc0acf 100644 --- a/pkg/interop/native/notary/notary.go +++ b/pkg/interop/native/notary/notary.go @@ -45,3 +45,13 @@ func GetMaxNotValidBeforeDelta() int { func SetMaxNotValidBeforeDelta(value int) { neogointernal.CallWithTokenNoRet(Hash, "setMaxNotValidBeforeDelta", int(contract.States), value) } + +// GetNotaryServiceFeePerKey represents `getNotaryServiceFeePerKey` method of Notary native contract. +func GetNotaryServiceFeePerKey() int { + return neogointernal.CallWithToken(Hash, "getNotaryServiceFeePerKey", int(contract.ReadStates)).(int) +} + +// SetNotaryServiceFeePerKey represents `setNotaryServiceFeePerKey` method of Notary native contract. +func SetNotaryServiceFeePerKey(value int) { + neogointernal.CallWithTokenNoRet(Hash, "setNotaryServiceFeePerKey", int(contract.States), value) +} diff --git a/pkg/rpc/client/native.go b/pkg/rpc/client/native.go index badab2a5a..7839ab941 100644 --- a/pkg/rpc/client/native.go +++ b/pkg/rpc/client/native.go @@ -16,7 +16,7 @@ import ( // GetOraclePrice invokes `getPrice` method on a native Oracle contract. func (c *Client) GetOraclePrice() (int64, error) { - oracleHash, err := c.GetNativeContractHash(nativenames.Notary) + oracleHash, err := c.GetNativeContractHash(nativenames.Oracle) if err != nil { return 0, fmt.Errorf("failed to get native Oracle hash: %w", err) } @@ -141,3 +141,13 @@ func (c *Client) NNSGetAllRecords(nnsHash util.Uint160, name string) ([]nns.Reco } return rss, nil } + +// GetNotaryServiceFeePerKey returns a reward per notary request key for designated +// notary nodes. It doesn't cache the result. +func (c *Client) GetNotaryServiceFeePerKey() (int64, error) { + notaryHash, err := c.GetNativeContractHash(nativenames.Notary) + if err != nil { + return 0, fmt.Errorf("failed to get native Notary hash: %w", err) + } + return c.invokeNativeGetMethod(notaryHash, "getNotaryServiceFeePerKey") +} diff --git a/pkg/rpc/client/rpc.go b/pkg/rpc/client/rpc.go index 3d035d40f..d643d4414 100644 --- a/pkg/rpc/client/rpc.go +++ b/pkg/rpc/client/rpc.go @@ -878,7 +878,11 @@ func (c *Client) CalculateNotaryFee(nKeys uint8) (int64, error) { if err != nil { return 0, fmt.Errorf("failed to get FeePerByte: %w", err) } - return int64((nKeys+1))*transaction.NotaryServiceFeePerKey + // fee for NotaryAssisted attribute + feePerKey, err := c.GetNotaryServiceFeePerKey() + if err != nil { + return 0, fmt.Errorf("failed to get NotaryServiceFeePerKey: %w", err) + } + return int64((nKeys+1))*feePerKey + // fee for NotaryAssisted attribute fee.Opcode(baseExecFee, // Notary node witness opcode.PUSHDATA1, opcode.RET, // invocation script opcode.PUSH0, opcode.SYSCALL, opcode.RET) + // System.Contract.CallNative diff --git a/pkg/rpc/server/client_test.go b/pkg/rpc/server/client_test.go index 4e9c8c4d3..a8d9f3fb8 100644 --- a/pkg/rpc/server/client_test.go +++ b/pkg/rpc/server/client_test.go @@ -983,3 +983,33 @@ func TestClient_NNS(t *testing.T) { require.Error(t, err) }) } + +func TestClient_GetNotaryServiceFeePerKey(t *testing.T) { + chain, rpcSrv, httpSrv := initServerWithInMemoryChain(t) + defer chain.Close() + defer func() { _ = rpcSrv.Shutdown() }() + + c, err := client.New(context.Background(), httpSrv.URL, client.Options{}) + require.NoError(t, err) + require.NoError(t, c.Init()) + + var defaultNotaryServiceFeePerKey int64 = 1000_0000 + actual, err := c.GetNotaryServiceFeePerKey() + require.NoError(t, err) + require.Equal(t, defaultNotaryServiceFeePerKey, actual) +} + +func TestClient_GetOraclePrice(t *testing.T) { + chain, rpcSrv, httpSrv := initServerWithInMemoryChain(t) + defer chain.Close() + defer func() { _ = rpcSrv.Shutdown() }() + + c, err := client.New(context.Background(), httpSrv.URL, client.Options{}) + require.NoError(t, err) + require.NoError(t, c.Init()) + + var defaultOracleRequestPrice int64 = 5000_0000 + actual, err := c.GetOraclePrice() + require.NoError(t, err) + require.Equal(t, defaultOracleRequestPrice, actual) +}