2022-05-25 16:15:27 +00:00
|
|
|
package util
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
|
2023-03-07 13:38:26 +00:00
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/cmd/frostfs-cli/internal/common"
|
|
|
|
"git.frostfs.info/TrueCloudLab/frostfs-node/cmd/frostfs-cli/internal/commonflags"
|
|
|
|
commonCmd "git.frostfs.info/TrueCloudLab/frostfs-node/cmd/internal/common"
|
2024-11-15 12:05:37 +00:00
|
|
|
apeutil "git.frostfs.info/TrueCloudLab/frostfs-node/pkg/util/ape"
|
2024-06-18 15:29:56 +00:00
|
|
|
"git.frostfs.info/TrueCloudLab/policy-engine/pkg/chain"
|
2022-05-25 16:15:27 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
2024-06-18 15:29:56 +00:00
|
|
|
const (
|
|
|
|
fromFlagStr = "from"
|
|
|
|
toFlagStr = "to"
|
|
|
|
apeFlagStr = "ape"
|
|
|
|
)
|
|
|
|
|
2022-05-25 16:15:27 +00:00
|
|
|
var convertEACLCmd = &cobra.Command{
|
|
|
|
Use: "eacl",
|
|
|
|
Short: "Convert representation of extended ACL table",
|
|
|
|
Run: convertEACLTable,
|
|
|
|
}
|
|
|
|
|
|
|
|
func initConvertEACLCmd() {
|
|
|
|
flags := convertEACLCmd.Flags()
|
|
|
|
|
2024-06-18 15:29:56 +00:00
|
|
|
flags.String(fromFlagStr, "", "File with JSON or binary encoded extended ACL table")
|
|
|
|
_ = convertEACLCmd.MarkFlagFilename(fromFlagStr)
|
|
|
|
_ = convertEACLCmd.MarkFlagRequired(fromFlagStr)
|
2022-05-25 16:15:27 +00:00
|
|
|
|
2024-06-18 15:29:56 +00:00
|
|
|
flags.String(toFlagStr, "", "File to dump extended ACL table (default: binary encoded)")
|
2022-06-23 13:52:47 +00:00
|
|
|
flags.Bool(commonflags.JSON, false, "Dump extended ACL table in JSON encoding")
|
2024-06-18 15:29:56 +00:00
|
|
|
|
|
|
|
flags.Bool(apeFlagStr, false, "Dump converted eACL table to APE chain format")
|
|
|
|
|
|
|
|
convertEACLCmd.MarkFlagsMutuallyExclusive(apeFlagStr, commonflags.JSON)
|
2022-05-25 16:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func convertEACLTable(cmd *cobra.Command, _ []string) {
|
2024-06-18 15:29:56 +00:00
|
|
|
pathFrom := cmd.Flag(fromFlagStr).Value.String()
|
|
|
|
to := cmd.Flag(toFlagStr).Value.String()
|
2022-06-23 13:52:47 +00:00
|
|
|
jsonFlag, _ := cmd.Flags().GetBool(commonflags.JSON)
|
2024-06-18 15:29:56 +00:00
|
|
|
apeFlag, _ := cmd.Flags().GetBool(apeFlagStr)
|
2022-05-25 16:15:27 +00:00
|
|
|
|
|
|
|
table := common.ReadEACL(cmd, pathFrom)
|
|
|
|
|
|
|
|
var data []byte
|
|
|
|
var err error
|
2024-06-18 15:29:56 +00:00
|
|
|
|
|
|
|
if apeFlag {
|
|
|
|
var ch *chain.Chain
|
|
|
|
ch, err = apeutil.ConvertEACLToAPE(table)
|
|
|
|
commonCmd.ExitOnErr(cmd, "convert eACL table to APE chain error: %w", err)
|
|
|
|
data = ch.Bytes()
|
|
|
|
} else if jsonFlag || len(to) == 0 {
|
2022-05-25 16:15:27 +00:00
|
|
|
data, err = table.MarshalJSON()
|
2023-01-16 09:20:16 +00:00
|
|
|
commonCmd.ExitOnErr(cmd, "can't JSON encode extended ACL table: %w", err)
|
2022-05-25 16:15:27 +00:00
|
|
|
} else {
|
|
|
|
data, err = table.Marshal()
|
2023-01-16 09:20:16 +00:00
|
|
|
commonCmd.ExitOnErr(cmd, "can't binary encode extended ACL table: %w", err)
|
2022-05-25 16:15:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(to) == 0 {
|
2022-12-27 09:36:30 +00:00
|
|
|
common.PrettyPrintJSON(cmd, table, "eACL")
|
2022-05-25 16:15:27 +00:00
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-10-31 11:56:55 +00:00
|
|
|
err = os.WriteFile(to, data, 0o644)
|
2023-01-16 09:20:16 +00:00
|
|
|
commonCmd.ExitOnErr(cmd, "can't write exteded ACL table to file: %w", err)
|
2022-05-25 16:15:27 +00:00
|
|
|
|
|
|
|
cmd.Printf("extended ACL table was successfully dumped to %s\n", to)
|
|
|
|
}
|