mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2026-06-01 14:36:22 +00:00
When jwt.filer_signing.key is set, the filer's IamGrpcServer requires a Bearer token on every IAM RPC. The shell's s3.* IAM commands dialed without that header and failed with Unauthenticated. Route them through a small helper that mints a token from the same key viper-loaded from security.toml and appends it as outgoing metadata, matching the credential grpc_store pattern.
84 lines
2.2 KiB
Go
84 lines
2.2 KiB
Go
package shell
|
|
|
|
import (
|
|
"context"
|
|
"flag"
|
|
"fmt"
|
|
"io"
|
|
"os"
|
|
|
|
"github.com/seaweedfs/seaweedfs/weed/filer"
|
|
"github.com/seaweedfs/seaweedfs/weed/pb/iam_pb"
|
|
"github.com/seaweedfs/seaweedfs/weed/util"
|
|
)
|
|
|
|
func init() {
|
|
Commands = append(Commands, &commandS3IAMImport{})
|
|
}
|
|
|
|
type commandS3IAMImport struct {
|
|
}
|
|
|
|
func (c *commandS3IAMImport) Name() string {
|
|
return "s3.iam.import"
|
|
}
|
|
|
|
func (c *commandS3IAMImport) Help() string {
|
|
return `import S3 IAM configuration from a JSON file
|
|
|
|
s3.iam.import -file backup.json -apply
|
|
|
|
Replaces the entire IAM configuration (users, credentials, policies,
|
|
service accounts, groups) with the contents of the file.
|
|
|
|
Requires -apply to confirm, since this overwrites the current configuration.
|
|
`
|
|
}
|
|
|
|
func (c *commandS3IAMImport) HasTag(CommandTag) bool {
|
|
return false
|
|
}
|
|
|
|
func (c *commandS3IAMImport) Do(args []string, commandEnv *CommandEnv, writer io.Writer) error {
|
|
f := flag.NewFlagSet(c.Name(), flag.ContinueOnError)
|
|
file := f.String("file", "", "input JSON file")
|
|
apply := f.Bool("apply", false, "confirm overwrite of the entire IAM configuration")
|
|
if err := f.Parse(args); err != nil {
|
|
return err
|
|
}
|
|
|
|
if *file == "" {
|
|
return fmt.Errorf("-file is required")
|
|
}
|
|
if !*apply {
|
|
return fmt.Errorf("this overwrites the entire IAM configuration; use -apply to confirm")
|
|
}
|
|
|
|
data, err := os.ReadFile(util.ResolvePath(*file))
|
|
if err != nil {
|
|
return fmt.Errorf("read file: %w", err)
|
|
}
|
|
|
|
config := &iam_pb.S3ApiConfiguration{}
|
|
if err := filer.ParseS3ConfigurationFromBytes(data, config); err != nil {
|
|
return fmt.Errorf("parse configuration: %w", err)
|
|
}
|
|
|
|
err = commandEnv.withIamClient(func(ctx context.Context, client iam_pb.SeaweedIdentityAccessManagementClient) error {
|
|
_, err := client.PutConfiguration(ctx, &iam_pb.PutConfigurationRequest{
|
|
Configuration: config,
|
|
})
|
|
return err
|
|
})
|
|
if err != nil {
|
|
return fmt.Errorf("put IAM configuration: %w", err)
|
|
}
|
|
|
|
fmt.Fprintf(writer, "Imported IAM configuration from %s\n", *file)
|
|
fmt.Fprintf(writer, " Users: %d\n", len(config.Identities))
|
|
fmt.Fprintf(writer, " Policies: %d\n", len(config.Policies))
|
|
fmt.Fprintf(writer, " Service Accounts: %d\n", len(config.ServiceAccounts))
|
|
fmt.Fprintf(writer, " Groups: %d\n", len(config.Groups))
|
|
return nil
|
|
}
|