package control import ( "encoding/hex" "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/frostfs-cli/internal/key" commonCmd "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/internal/common" apecmd "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/internal/common/ape" "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/control" "git.frostfs.info/TrueCloudLab/frostfs-sdk-go/api/rpc/client" apechain "git.frostfs.info/TrueCloudLab/policy-engine/pkg/chain" "github.com/spf13/cobra" ) var getRuleCmd = &cobra.Command{ Use: "get-rule", Short: "Get local override", Long: "Get local APE override of the node", Run: getRule, } func getRule(cmd *cobra.Command, _ []string) { pk := key.Get(cmd) target := parseTarget(cmd) chainID, _ := cmd.Flags().GetString(apecmd.ChainIDFlag) hexEncoded, _ := cmd.Flags().GetBool(apecmd.ChainIDHexFlag) if hexEncoded { chainIDBytes, err := hex.DecodeString(chainID) commonCmd.ExitOnErr(cmd, "can't decode chain ID as hex: %w", err) chainID = string(chainIDBytes) } req := &control.GetChainLocalOverrideRequest{ Body: &control.GetChainLocalOverrideRequest_Body{ Target: target, ChainId: []byte(chainID), }, } signRequest(cmd, pk, req) cli := getClient(cmd, pk) var resp *control.GetChainLocalOverrideResponse var err error err = cli.ExecRaw(func(client *client.Client) error { resp, err = control.GetChainLocalOverride(client, req) return err }) commonCmd.ExitOnErr(cmd, "rpc error: %w", err) verifyResponse(cmd, resp.GetSignature(), resp.GetBody()) var chain apechain.Chain commonCmd.ExitOnErr(cmd, "decode error: %w", chain.DecodeBytes(resp.GetBody().GetChain())) apecmd.PrintHumanReadableAPEChain(cmd, &chain) } func initControGetRuleCmd() { initControlFlags(getRuleCmd) ff := getRuleCmd.Flags() ff.String(apecmd.TargetNameFlag, "", apecmd.TargetNameFlagDesc) ff.String(apecmd.TargetTypeFlag, "", apecmd.TargetTypeFlagDesc) _ = getRuleCmd.MarkFlagRequired(apecmd.TargetTypeFlag) ff.String(apecmd.ChainIDFlag, "", "Chain id") ff.Bool(apecmd.ChainIDHexFlag, false, "Flag to parse chain ID as hex") }