Skip to content

Commit

Permalink
Substats chall (#203)
Browse files Browse the repository at this point in the history
* add Punishment

* update QueryChallengeInfo

* add QueryCompleteSnapShot and QueryRoundReward
  • Loading branch information
AstaFrode authored Apr 28, 2024
1 parent 833fad2 commit 0f967ad
Show file tree
Hide file tree
Showing 9 changed files with 262 additions and 17 deletions.
19 changes: 16 additions & 3 deletions chain/audit.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ func (c *ChainClient) QueryChallengeVerifyExpiration() (uint32, error) {
return uint32(data), nil
}

func (c *ChainClient) QueryChallengeInfo(accountID []byte) (bool, pattern.ChallengeInfo, error) {
func (c *ChainClient) QueryChallengeInfo(accountID []byte, block int32) (bool, pattern.ChallengeInfo, error) {
defer func() {
if err := recover(); err != nil {
log.Println(utils.RecoverError(err))
Expand All @@ -70,13 +70,26 @@ func (c *ChainClient) QueryChallengeInfo(accountID []byte) (bool, pattern.Challe
return false, data, err
}

ok, err := c.api.RPC.State.GetStorageLatest(key, &data)
if block < 0 {
ok, err := c.api.RPC.State.GetStorageLatest(key, &data)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorageLatest: %v", c.GetCurrentRpcAddr(), pattern.AUDIT, pattern.CHALLENGESNAPSHOT, err)
c.SetChainState(false)
return false, data, err
}
return ok, data, nil
}
blockhash, err := c.api.RPC.Chain.GetBlockHash(uint64(block))
if err != nil {
return false, data, err
}

ok, err := c.api.RPC.State.GetStorage(key, &data, blockhash)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorageLatest: %v", c.GetCurrentRpcAddr(), pattern.AUDIT, pattern.CHALLENGESNAPSHOT, err)
c.SetChainState(false)
return false, data, err
}

return ok, data, nil
}

Expand Down
13 changes: 13 additions & 0 deletions chain/chain.go
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ type ChainClient struct {
tokenSymbol string
networkEnv string
signatureAcc string
treasuryAcc string
name string
chainState bool
}
Expand Down Expand Up @@ -143,6 +144,14 @@ func NewChainClient(
return nil, err
}

if strings.Contains(chainClient.networkEnv, "test") {
chainClient.treasuryAcc = "cXhT9Xh3DhrBMDmXcGeMPDmTzDm1J8vDxBtKvogV33pPshnWS"
} else if strings.Contains(chainClient.networkEnv, "main") {
chainClient.treasuryAcc = "cXhT9Xh3DhrBMDmXcGeMPDmTzDm1J8vDxBtKvogV33pPshnWS"
} else {
chainClient.treasuryAcc = "cXhT9Xh3DhrBMDmXcGeMPDmTzDm1J8vDxBtKvogV33pPshnWS"
}

return chainClient, nil
}

Expand Down Expand Up @@ -231,6 +240,10 @@ func (c *ChainClient) GetURI() string {
return c.keyring.URI
}

func (c *ChainClient) GetTreasuryAccount() string {
return c.treasuryAcc
}

func (c *ChainClient) Sign(msg []byte) ([]byte, error) {
return signature.Sign(msg, c.keyring.URI)
}
Expand Down
72 changes: 63 additions & 9 deletions chain/event.go
Original file line number Diff line number Diff line change
Expand Up @@ -2170,6 +2170,14 @@ func (c *ChainClient) ParseBlockData(blocknumber uint64) (event.BlockData, error
if err != nil {
return blockdata, err
}
if to == c.treasuryAcc {
blockdata.Punishment = append(blockdata.Punishment, event.Punishment{
ExtrinsicHash: blockdata.Extrinsics[extrinsicIndex].Hash,
From: from,
To: to,
Amount: amount,
})
}
blockdata.TransferInfo = append(blockdata.TransferInfo, event.TransferInfo{
ExtrinsicName: name,
ExtrinsicHash: blockdata.Extrinsics[extrinsicIndex].Hash,
Expand Down Expand Up @@ -2301,55 +2309,101 @@ func (c *ChainClient) ParseBlockData(blocknumber uint64) (event.BlockData, error
} else if e.Name == event.SystemExtrinsicFailed {
for m := 0; m < len(blockdata.UploadDecInfo); m++ {
if blockdata.UploadDecInfo[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.UploadDecInfo = append(blockdata.UploadDecInfo[:extrinsicIndex], blockdata.UploadDecInfo[extrinsicIndex+1:]...)
if len(blockdata.UploadDecInfo) == 1 {
blockdata.UploadDecInfo = nil
} else {
blockdata.UploadDecInfo = append(blockdata.UploadDecInfo[:m], blockdata.UploadDecInfo[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.DeleteFileInfo); m++ {
if blockdata.DeleteFileInfo[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.DeleteFileInfo = append(blockdata.DeleteFileInfo[:extrinsicIndex], blockdata.DeleteFileInfo[extrinsicIndex+1:]...)
if len(blockdata.DeleteFileInfo) == 1 {
blockdata.DeleteFileInfo = nil
} else {
blockdata.DeleteFileInfo = append(blockdata.DeleteFileInfo[:m], blockdata.DeleteFileInfo[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.MinerReg); m++ {
if blockdata.MinerReg[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.MinerReg = append(blockdata.MinerReg[:extrinsicIndex], blockdata.MinerReg[extrinsicIndex+1:]...)
if len(blockdata.MinerReg) == 1 {
blockdata.MinerReg = nil
} else {
blockdata.MinerReg = append(blockdata.MinerReg[:m], blockdata.MinerReg[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.CreateBucketInfo); m++ {
if blockdata.CreateBucketInfo[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.CreateBucketInfo = append(blockdata.CreateBucketInfo[:extrinsicIndex], blockdata.CreateBucketInfo[extrinsicIndex+1:]...)
if len(blockdata.CreateBucketInfo) == 1 {
blockdata.CreateBucketInfo = nil
} else {
blockdata.CreateBucketInfo = append(blockdata.CreateBucketInfo[:m], blockdata.CreateBucketInfo[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.DeleteBucketInfo); m++ {
if blockdata.DeleteBucketInfo[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.DeleteBucketInfo = append(blockdata.DeleteBucketInfo[:extrinsicIndex], blockdata.DeleteBucketInfo[extrinsicIndex+1:]...)
if len(blockdata.DeleteBucketInfo) == 1 {
blockdata.DeleteBucketInfo = nil
} else {
blockdata.DeleteBucketInfo = append(blockdata.DeleteBucketInfo[:m], blockdata.DeleteBucketInfo[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.SubmitIdleProve); m++ {
if blockdata.SubmitIdleProve[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.SubmitIdleProve = append(blockdata.SubmitIdleProve[:extrinsicIndex], blockdata.SubmitIdleProve[extrinsicIndex+1:]...)
if len(blockdata.SubmitIdleProve) == 1 {
blockdata.SubmitIdleProve = nil
} else {
blockdata.SubmitIdleProve = append(blockdata.SubmitIdleProve[:m], blockdata.SubmitIdleProve[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.SubmitServiceProve); m++ {
if blockdata.SubmitServiceProve[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.SubmitServiceProve = append(blockdata.SubmitServiceProve[:extrinsicIndex], blockdata.SubmitServiceProve[extrinsicIndex+1:]...)
if len(blockdata.SubmitServiceProve) == 1 {
blockdata.SubmitServiceProve = nil
} else {
blockdata.SubmitServiceProve = append(blockdata.SubmitServiceProve[:m], blockdata.SubmitServiceProve[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.SubmitIdleResult); m++ {
if blockdata.SubmitIdleResult[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.SubmitIdleResult = append(blockdata.SubmitIdleResult[:extrinsicIndex], blockdata.SubmitIdleResult[extrinsicIndex+1:]...)
if len(blockdata.SubmitIdleResult) == 1 {
blockdata.SubmitIdleResult = nil
} else {
blockdata.SubmitIdleResult = append(blockdata.SubmitIdleResult[:m], blockdata.SubmitIdleResult[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.SubmitServiceResult); m++ {
if blockdata.SubmitServiceResult[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
blockdata.SubmitServiceResult = append(blockdata.SubmitServiceResult[:extrinsicIndex], blockdata.SubmitServiceResult[extrinsicIndex+1:]...)
if len(blockdata.SubmitServiceResult) == 1 {
blockdata.SubmitServiceResult = nil
} else {
blockdata.SubmitServiceResult = append(blockdata.SubmitServiceResult[:m], blockdata.SubmitServiceResult[m+1:]...)
}
break
}
}
for m := 0; m < len(blockdata.Punishment); m++ {
if blockdata.Punishment[m].ExtrinsicHash == blockdata.Extrinsics[extrinsicIndex].Hash {
if len(blockdata.Punishment) == 1 {
blockdata.Punishment = nil
} else {
blockdata.Punishment = append(blockdata.Punishment[:m], blockdata.Punishment[m+1:]...)
}
break
}
}
Expand Down
58 changes: 58 additions & 0 deletions chain/sminer.go
Original file line number Diff line number Diff line change
Expand Up @@ -430,6 +430,64 @@ func (c *ChainClient) QueryPendingReplacements(puk []byte) (types.U128, error) {
return data, nil
}

func (c *ChainClient) QueryCompleteSnapShot(era uint32, block int32) (uint32, uint64, error) {
defer func() {
if err := recover(); err != nil {
log.Println(utils.RecoverError(err))
}
}()

var data pattern.CompleteSnapShotType

if !c.GetChainState() {
return 0, 0, pattern.ERR_RPC_CONNECTION
}

param, err := codec.Encode(era)
if err != nil {
return 0, 0, err
}

key, err := types.CreateStorageKey(c.metadata, pattern.SMINER, pattern.CompleteSnapShot, param)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] CreateStorageKey: %v", c.GetCurrentRpcAddr(), pattern.SMINER, pattern.CompleteSnapShot, err)
c.SetChainState(false)
return 0, 0, err
}

if block < 0 {
ok, err := c.api.RPC.State.GetStorageLatest(key, &data)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorageLatest: %v", c.GetCurrentRpcAddr(), pattern.SMINER, pattern.CompleteSnapShot, err)
c.SetChainState(false)
return 0, 0, err
}
if !ok {
return 0, 0, pattern.ERR_RPC_EMPTY_VALUE
}
return uint32(data.MinerCount), data.TotalPower.Uint64(), nil
}

blockhash, err := c.api.RPC.Chain.GetBlockHash(uint64(block))
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetBlockHash: %v", c.GetCurrentRpcAddr(), pattern.SMINER, pattern.CompleteSnapShot, err)
c.SetChainState(false)
return 0, 0, err
}

ok, err := c.api.RPC.State.GetStorage(key, &data, blockhash)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorage: %v", c.GetCurrentRpcAddr(), pattern.SMINER, pattern.CompleteSnapShot, err)
c.SetChainState(false)
return 0, 0, err
}
if !ok {
return 0, 0, pattern.ERR_RPC_EMPTY_VALUE
}

return uint32(data.MinerCount), data.TotalPower.Uint64(), nil
}

func (c *ChainClient) UpdateSminerPeerId(peerid pattern.PeerId) (string, error) {
c.lock.Lock()
defer func() {
Expand Down
76 changes: 76 additions & 0 deletions chain/treasury.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,76 @@
/*
Copyright (C) CESS. All rights reserved.
Copyright (C) Cumulus Encrypted Storage System. All rights reserved.
SPDX-License-Identifier: Apache-2.0
*/

package chain

import (
"fmt"
"log"

"github.com/CESSProject/cess-go-sdk/core/pattern"
"github.com/CESSProject/cess-go-sdk/utils"
"github.com/centrifuge/go-substrate-rpc-client/v4/types"
"github.com/centrifuge/go-substrate-rpc-client/v4/types/codec"
)

func (c *ChainClient) QueryRoundReward(era uint32, block int32) (string, error) {
defer func() {
if err := recover(); err != nil {
log.Println(utils.RecoverError(err))
}
}()

var data pattern.RoundRewardType

if !c.GetChainState() {
return "", pattern.ERR_RPC_CONNECTION
}

param, err := codec.Encode(era)
if err != nil {
return "", err
}

key, err := types.CreateStorageKey(c.metadata, pattern.CessTreasury, pattern.RoundReward, param)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] CreateStorageKey: %v", c.GetCurrentRpcAddr(), pattern.CessTreasury, pattern.RoundReward, err)
c.SetChainState(false)
return "", err
}

if block < 0 {
ok, err := c.api.RPC.State.GetStorageLatest(key, &data)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorageLatest: %v", c.GetCurrentRpcAddr(), pattern.CessTreasury, pattern.RoundReward, err)
c.SetChainState(false)
return "", err
}
if !ok {
return "", pattern.ERR_RPC_EMPTY_VALUE
}
return data.TotalReward.String(), nil
}

blockhash, err := c.api.RPC.Chain.GetBlockHash(uint64(block))
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetBlockHash: %v", c.GetCurrentRpcAddr(), pattern.CessTreasury, pattern.RoundReward, err)
c.SetChainState(false)
return "", err
}

ok, err := c.api.RPC.State.GetStorage(key, &data, blockhash)
if err != nil {
err = fmt.Errorf("rpc err: [%s] [st] [%s.%s] GetStorage: %v", c.GetCurrentRpcAddr(), pattern.CessTreasury, pattern.RoundReward, err)
c.SetChainState(false)
return "", err
}
if !ok {
return "", pattern.ERR_RPC_EMPTY_VALUE
}

return data.TotalReward.String(), nil
}
8 changes: 8 additions & 0 deletions core/event/events.go
Original file line number Diff line number Diff line change
Expand Up @@ -654,6 +654,7 @@ type BlockData struct {
SubmitServiceProve []SubmitServiceProve
SubmitIdleResult []SubmitIdleResult
SubmitServiceResult []SubmitServiceResult
Punishment []Punishment
}

type ExtrinsicsInfo struct {
Expand Down Expand Up @@ -724,3 +725,10 @@ type SubmitServiceResult struct {
Miner string
Result bool
}

type Punishment struct {
ExtrinsicHash string
From string
To string
Amount string
}
Loading

0 comments on commit 0f967ad

Please sign in to comment.