Some checks failed
DCO action / DCO (pull_request) Successful in 59s
Vulncheck / Vulncheck (pull_request) Successful in 1m4s
Pre-commit hooks / Pre-commit (pull_request) Successful in 1m55s
Build / Build Components (pull_request) Successful in 2m4s
Tests and linters / Staticcheck (pull_request) Successful in 2m38s
Tests and linters / Lint (pull_request) Successful in 3m16s
Tests and linters / Run gofumpt (pull_request) Successful in 3m54s
Tests and linters / Tests (pull_request) Successful in 4m12s
Tests and linters / gopls check (pull_request) Successful in 4m31s
Tests and linters / Tests with -race (pull_request) Successful in 4m38s
OCI image / Build container images (push) Failing after 18s
Vulncheck / Vulncheck (push) Successful in 1m2s
Pre-commit hooks / Pre-commit (push) Successful in 1m39s
Build / Build Components (push) Successful in 1m45s
Tests and linters / Staticcheck (push) Successful in 2m18s
Tests and linters / Run gofumpt (push) Successful in 2m46s
Tests and linters / Lint (push) Successful in 3m5s
Tests and linters / Tests with -race (push) Successful in 3m23s
Tests and linters / Tests (push) Successful in 3m52s
Tests and linters / gopls check (push) Successful in 4m18s
Signed-off-by: Alexander Chuprov <a.chuprov@yadro.com>
57 lines
1.4 KiB
Go
57 lines
1.4 KiB
Go
package netmap
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/pkg/morph/client"
|
|
)
|
|
|
|
// Epoch receives number of current FrostFS epoch
|
|
// through the Netmap contract call.
|
|
func (c *Client) Epoch(ctx context.Context) (uint64, error) {
|
|
prm := client.TestInvokePrm{}
|
|
prm.SetMethod(epochMethod)
|
|
|
|
items, err := c.client.TestInvoke(ctx, prm)
|
|
if err != nil {
|
|
return 0, fmt.Errorf("test invoke (%s): %w",
|
|
epochMethod, err)
|
|
}
|
|
|
|
if ln := len(items); ln != 1 {
|
|
return 0, fmt.Errorf("unexpected stack item count (%s): %d",
|
|
epochMethod, ln)
|
|
}
|
|
|
|
num, err := client.IntFromStackItem(items[0])
|
|
if err != nil {
|
|
return 0, fmt.Errorf("get number from stack item (%s): %w", epochMethod, err)
|
|
}
|
|
return uint64(num), nil
|
|
}
|
|
|
|
// LastEpochBlock receives block number of current FrostFS epoch
|
|
// through the Netmap contract call.
|
|
func (c *Client) LastEpochBlock(ctx context.Context) (uint32, error) {
|
|
prm := client.TestInvokePrm{}
|
|
prm.SetMethod(lastEpochBlockMethod)
|
|
|
|
items, err := c.client.TestInvoke(ctx, prm)
|
|
if err != nil {
|
|
return 0, fmt.Errorf("test invoke (%s): %w",
|
|
lastEpochBlockMethod, err)
|
|
}
|
|
|
|
if ln := len(items); ln != 1 {
|
|
return 0, fmt.Errorf("unexpected stack item count (%s): %d",
|
|
lastEpochBlockMethod, ln)
|
|
}
|
|
|
|
block, err := client.IntFromStackItem(items[0])
|
|
if err != nil {
|
|
return 0, fmt.Errorf("get number from stack item (%s): %w",
|
|
lastEpochBlockMethod, err)
|
|
}
|
|
return uint32(block), nil
|
|
}
|