package control import ( "git.frostfs.info/TrueCloudLab/frostfs-api-go/v2/rpc/client" "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/frostfs-cli/internal/key" commonCmd "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/internal/common" "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/services/control" "github.com/spf13/cobra" ) const sealFlag = "seal" var flushCacheCmd = &cobra.Command{ Use: "flush-cache", Short: "Flush objects from the write-cache to the main storage", Long: "Flush objects from the write-cache to the main storage", Run: flushCache, } func flushCache(cmd *cobra.Command, _ []string) { pk := key.Get(cmd) seal, _ := cmd.Flags().GetBool(sealFlag) req := &control.FlushCacheRequest{Body: &control.FlushCacheRequest_Body{ Seal: seal, }} req.Body.Shard_ID = getShardIDList(cmd) signRequest(cmd, pk, req) cli := getClient(cmd, pk) var resp *control.FlushCacheResponse var err error err = cli.ExecRaw(func(client *client.Client) error { resp, err = control.FlushCache(client, req) return err }) commonCmd.ExitOnErr(cmd, "rpc error: %w", err) verifyResponse(cmd, resp.GetSignature(), resp.GetBody()) cmd.Println("Write-cache has been flushed.") } func initControlFlushCacheCmd() { initControlFlags(flushCacheCmd) ff := flushCacheCmd.Flags() ff.StringSlice(shardIDFlag, nil, "List of shard IDs in base58 encoding") ff.Bool(shardAllFlag, false, "Process all shards") ff.Bool(sealFlag, false, "Writecache will be left in read-only mode after flush completed") flushCacheCmd.MarkFlagsMutuallyExclusive(shardIDFlag, shardAllFlag) }