From c1afaf8ea8c53c6ca8161fc905c61d536ab21e7f Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Sat, 10 Dec 2022 11:35:03 +0300 Subject: [PATCH] rpcsrv: use more robust NEP-11 divisibility check It's more heavyweight at the same time, but should be OK for the purpose. Inspired by https://github.com/neo-project/neo-modules/issues/754#issuecomment-1345176986 --- pkg/services/rpcsrv/server.go | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/pkg/services/rpcsrv/server.go b/pkg/services/rpcsrv/server.go index eb72ccd09..24dc02a5d 100644 --- a/pkg/services/rpcsrv/server.go +++ b/pkg/services/rpcsrv/server.go @@ -48,6 +48,7 @@ import ( "github.com/nspcc-dev/neo-go/pkg/smartcontract" "github.com/nspcc-dev/neo-go/pkg/smartcontract/callflag" "github.com/nspcc-dev/neo-go/pkg/smartcontract/manifest" + "github.com/nspcc-dev/neo-go/pkg/smartcontract/manifest/standard" "github.com/nspcc-dev/neo-go/pkg/smartcontract/trigger" "github.com/nspcc-dev/neo-go/pkg/util" "github.com/nspcc-dev/neo-go/pkg/vm" @@ -931,7 +932,7 @@ contract_loop: if cs == nil { continue } - isDivisible := (cs.Manifest.ABI.GetMethod("balanceOf", 2) != nil) + isDivisible := (standard.ComplyABI(&cs.Manifest, standard.Nep11Divisible) == nil) lub, ok := lastUpdated[cs.ID] if !ok { cfg := s.chain.GetConfig()