forked from TrueCloudLab/frostfs-node
0decb95591
In some places we panic, in some we return error, in some (audit) just return a client. However in all of the places static client is created immediately before the sugared-client creation. This commit makes all constructors to just return a client for the sake of code simplification and unification. Signed-off-by: Evgenii Stratonikov <evgeniy@nspcc.ru>
49 lines
1.3 KiB
Go
49 lines
1.3 KiB
Go
package netmap
|
|
|
|
import (
|
|
"github.com/nspcc-dev/neofs-node/pkg/morph/client"
|
|
"github.com/nspcc-dev/neofs-sdk-go/netmap"
|
|
)
|
|
|
|
type NodeInfo = netmap.NodeInfo
|
|
|
|
// Client is a wrapper over StaticClient
|
|
// which makes calls with the names and arguments
|
|
// of the NeoFS Netmap contract.
|
|
//
|
|
// Working client must be created via constructor New.
|
|
// Using the Client that has been created with new(Client)
|
|
// expression (or just declaring a Client variable) is unsafe
|
|
// and can lead to panic.
|
|
type Client struct {
|
|
client *client.StaticClient // static Netmap contract client
|
|
}
|
|
|
|
const (
|
|
addPeerMethod = "addPeer"
|
|
configMethod = "config"
|
|
epochMethod = "epoch"
|
|
lastEpochBlockMethod = "lastEpochBlock"
|
|
innerRingListMethod = "innerRingList"
|
|
netMapCandidatesMethod = "netmapCandidates"
|
|
netMapMethod = "netmap"
|
|
newEpochMethod = "newEpoch"
|
|
setConfigMethod = "setConfig"
|
|
updateInnerRingMethod = "updateInnerRing"
|
|
snapshotMethod = "snapshot"
|
|
updateStateMethod = "updateState"
|
|
|
|
epochSnapshotMethod = "snapshotByEpoch"
|
|
|
|
configListMethod = "listConfig"
|
|
)
|
|
|
|
// New creates, initializes and returns the Client instance.
|
|
func New(c *client.StaticClient) *Client {
|
|
return &Client{client: c}
|
|
}
|
|
|
|
// Morph returns raw morph client.
|
|
func (c Client) Morph() *client.Client {
|
|
return c.client.Morph()
|
|
}
|