forked from TrueCloudLab/frostfs-contract
[#74] processing: Add processing contract
Processing contract deployed in main chain and processes multi signature invocations of NeoFS contract by verifying multi signature and paying for it. Signed-off-by: Alex Vanin <alexey@nspcc.ru>
This commit is contained in:
parent
e850d4fc78
commit
4c932ae930
3 changed files with 72 additions and 1 deletions
2
Makefile
2
Makefile
|
@ -10,7 +10,7 @@ sidechain: alphabet morph
|
|||
|
||||
alphabet_sc = alphabet
|
||||
morph_sc = audit balance container neofsid netmap proxy reputation
|
||||
mainnet_sc = neofs
|
||||
mainnet_sc = neofs processing
|
||||
|
||||
define sc_template
|
||||
$(2)$(1)/$(1)_contract.nef: $(2)$(1)/$(1)_contract.go
|
||||
|
|
2
processing/config.yml
Normal file
2
processing/config.yml
Normal file
|
@ -0,0 +1,2 @@
|
|||
name: "NeoFS Multi Signature Processing"
|
||||
safemethods: ["verify", "version"]
|
69
processing/processing_contract.go
Normal file
69
processing/processing_contract.go
Normal file
|
@ -0,0 +1,69 @@
|
|||
package processingcontract
|
||||
|
||||
import (
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop"
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop/contract"
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop/native/gas"
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop/native/management"
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop/runtime"
|
||||
"github.com/nspcc-dev/neo-go/pkg/interop/storage"
|
||||
"github.com/nspcc-dev/neofs-contract/common"
|
||||
)
|
||||
|
||||
const (
|
||||
version = 1
|
||||
|
||||
neofsContractKey = "neofsScriptHash"
|
||||
|
||||
multiaddrMethod = "alphabetAddress"
|
||||
)
|
||||
|
||||
func OnNEP17Payment(from interop.Hash160, amount int, data interface{}) {
|
||||
caller := runtime.GetCallingScriptHash()
|
||||
if !common.BytesEqual(caller, []byte(gas.Hash)) {
|
||||
panic("onNEP17Payment: processing contract accepts GAS only")
|
||||
}
|
||||
}
|
||||
|
||||
func Init(owner, addrNeoFS interop.Hash160) {
|
||||
ctx := storage.GetContext()
|
||||
|
||||
if !common.HasUpdateAccess(ctx) {
|
||||
panic("only owner can reinitialize contract")
|
||||
}
|
||||
|
||||
if len(addrNeoFS) != 20 {
|
||||
panic("init: incorrect length of contract script hash")
|
||||
}
|
||||
|
||||
storage.Put(ctx, common.OwnerKey, owner)
|
||||
storage.Put(ctx, neofsContractKey, addrNeoFS)
|
||||
|
||||
runtime.Log("processing contract initialized")
|
||||
}
|
||||
|
||||
func Migrate(script []byte, manifest []byte) bool {
|
||||
ctx := storage.GetReadOnlyContext()
|
||||
|
||||
if !common.HasUpdateAccess(ctx) {
|
||||
runtime.Log("only owner can update contract")
|
||||
return false
|
||||
}
|
||||
|
||||
management.Update(script, manifest)
|
||||
runtime.Log("processing contract updated")
|
||||
|
||||
return true
|
||||
}
|
||||
|
||||
func Verify() bool {
|
||||
ctx := storage.GetContext()
|
||||
neofsContractAddr := storage.Get(ctx, neofsContractKey).(interop.Hash160)
|
||||
multiaddr := contract.Call(neofsContractAddr, multiaddrMethod, contract.ReadOnly).(interop.Hash160)
|
||||
|
||||
return runtime.CheckWitness(multiaddr)
|
||||
}
|
||||
|
||||
func Version() int {
|
||||
return version
|
||||
}
|
Loading…
Reference in a new issue