Browse Source

adjust logs and errors

pull/8142/head
Chris Lu 2 days ago
parent
commit
92800c31a2
  1. 2
      weed/s3api/auth_credentials.go
  2. 47
      weed/s3api/s3api_server_grpc.go

2
weed/s3api/auth_credentials.go

@ -1384,7 +1384,7 @@ func (iam *IdentityAccessManagement) GetCredentialManager() *credential.Credenti
// LoadS3ApiConfigurationFromCredentialManager loads configuration using the credential manager // LoadS3ApiConfigurationFromCredentialManager loads configuration using the credential manager
func (iam *IdentityAccessManagement) LoadS3ApiConfigurationFromCredentialManager() error { func (iam *IdentityAccessManagement) LoadS3ApiConfigurationFromCredentialManager() error {
glog.V(0).Infof("IAM: reloading configuration from credential manager")
glog.V(1).Infof("IAM: reloading configuration from credential manager")
glog.V(1).Infof("Loading S3 API configuration from credential manager") glog.V(1).Infof("Loading S3 API configuration from credential manager")
s3ApiConfiguration, err := iam.credentialManager.LoadConfiguration(context.Background()) s3ApiConfiguration, err := iam.credentialManager.LoadConfiguration(context.Background())

47
weed/s3api/s3api_server_grpc.go

@ -3,10 +3,10 @@ package s3api
import ( import (
"context" "context"
"fmt"
"github.com/seaweedfs/seaweedfs/weed/glog" "github.com/seaweedfs/seaweedfs/weed/glog"
"github.com/seaweedfs/seaweedfs/weed/pb/iam_pb" "github.com/seaweedfs/seaweedfs/weed/pb/iam_pb"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"
) )
// SeaweedS3IamCacheServer Implementation // SeaweedS3IamCacheServer Implementation
@ -15,20 +15,20 @@ import (
func (s3a *S3ApiServer) PutIdentity(ctx context.Context, req *iam_pb.PutIdentityRequest) (*iam_pb.PutIdentityResponse, error) { func (s3a *S3ApiServer) PutIdentity(ctx context.Context, req *iam_pb.PutIdentityRequest) (*iam_pb.PutIdentityResponse, error) {
if req.Identity == nil { if req.Identity == nil {
return nil, fmt.Errorf("identity is required")
return nil, status.Errorf(codes.InvalidArgument, "identity is required")
} }
// Direct in-memory cache update // Direct in-memory cache update
glog.V(1).Infof("IAM: received identity update for %s", req.Identity.Name) glog.V(1).Infof("IAM: received identity update for %s", req.Identity.Name)
if err := s3a.iam.UpsertIdentity(req.Identity); err != nil { if err := s3a.iam.UpsertIdentity(req.Identity); err != nil {
glog.Errorf("failed to update identity cache for %s: %v", req.Identity.Name, err) glog.Errorf("failed to update identity cache for %s: %v", req.Identity.Name, err)
return nil, err
return nil, status.Errorf(codes.Internal, "failed to update identity cache: %v", err)
} }
return &iam_pb.PutIdentityResponse{}, nil return &iam_pb.PutIdentityResponse{}, nil
} }
func (s3a *S3ApiServer) RemoveIdentity(ctx context.Context, req *iam_pb.RemoveIdentityRequest) (*iam_pb.RemoveIdentityResponse, error) { func (s3a *S3ApiServer) RemoveIdentity(ctx context.Context, req *iam_pb.RemoveIdentityRequest) (*iam_pb.RemoveIdentityResponse, error) {
if req.Username == "" { if req.Username == "" {
return nil, fmt.Errorf("username is required")
return nil, status.Errorf(codes.InvalidArgument, "username is required")
} }
// Direct in-memory cache update // Direct in-memory cache update
glog.V(1).Infof("IAM: received identity removal for %s", req.Username) glog.V(1).Infof("IAM: received identity removal for %s", req.Username)
@ -38,42 +38,49 @@ func (s3a *S3ApiServer) RemoveIdentity(ctx context.Context, req *iam_pb.RemoveId
func (s3a *S3ApiServer) PutPolicy(ctx context.Context, req *iam_pb.PutPolicyRequest) (*iam_pb.PutPolicyResponse, error) { func (s3a *S3ApiServer) PutPolicy(ctx context.Context, req *iam_pb.PutPolicyRequest) (*iam_pb.PutPolicyResponse, error) {
if req.Name == "" { if req.Name == "" {
return nil, fmt.Errorf("policy name is required")
return nil, status.Errorf(codes.InvalidArgument, "policy name is required")
}
if req.Content == "" {
return nil, status.Errorf(codes.InvalidArgument, "policy content is required")
} }
// Update IAM policy cache // Update IAM policy cache
glog.V(1).Infof("IAM: received policy update for %s", req.Name) glog.V(1).Infof("IAM: received policy update for %s", req.Name)
if s3a.iam != nil {
if err := s3a.iam.PutPolicy(req.Name, req.Content); err != nil {
glog.Errorf("failed to update policy cache for %s: %v", req.Name, err)
return nil, err
}
if s3a.iam == nil {
return nil, status.Errorf(codes.Internal, "IAM not initialized")
}
if err := s3a.iam.PutPolicy(req.Name, req.Content); err != nil {
glog.Errorf("failed to update policy cache for %s: %v", req.Name, err)
return nil, status.Errorf(codes.Internal, "failed to update policy cache: %v", err)
} }
return &iam_pb.PutPolicyResponse{}, nil return &iam_pb.PutPolicyResponse{}, nil
} }
func (s3a *S3ApiServer) DeletePolicy(ctx context.Context, req *iam_pb.DeletePolicyRequest) (*iam_pb.DeletePolicyResponse, error) { func (s3a *S3ApiServer) DeletePolicy(ctx context.Context, req *iam_pb.DeletePolicyRequest) (*iam_pb.DeletePolicyResponse, error) {
if req.Name == "" { if req.Name == "" {
return nil, fmt.Errorf("policy name is required")
return nil, status.Errorf(codes.InvalidArgument, "policy name is required")
} }
// Delete from IAM policy cache // Delete from IAM policy cache
glog.V(1).Infof("IAM: received policy removal for %s", req.Name) glog.V(1).Infof("IAM: received policy removal for %s", req.Name)
if s3a.iam != nil {
if err := s3a.iam.DeletePolicy(req.Name); err != nil {
glog.Errorf("failed to delete policy cache for %s: %v", req.Name, err)
return nil, err
}
if s3a.iam == nil {
return nil, status.Errorf(codes.Internal, "IAM not initialized")
}
if err := s3a.iam.DeletePolicy(req.Name); err != nil {
glog.Errorf("failed to delete policy cache for %s: %v", req.Name, err)
return nil, status.Errorf(codes.Internal, "failed to delete policy cache: %v", err)
} }
return &iam_pb.DeletePolicyResponse{}, nil return &iam_pb.DeletePolicyResponse{}, nil
} }
func (s3a *S3ApiServer) GetPolicy(ctx context.Context, req *iam_pb.GetPolicyRequest) (*iam_pb.GetPolicyResponse, error) { func (s3a *S3ApiServer) GetPolicy(ctx context.Context, req *iam_pb.GetPolicyRequest) (*iam_pb.GetPolicyResponse, error) {
if req.Name == "" { if req.Name == "" {
return nil, fmt.Errorf("policy name is required")
return nil, status.Errorf(codes.InvalidArgument, "policy name is required")
} }
if s3a.iam == nil { if s3a.iam == nil {
return &iam_pb.GetPolicyResponse{}, nil
return nil, status.Errorf(codes.Internal, "IAM not initialized")
} }
policy, err := s3a.iam.GetPolicy(req.Name) policy, err := s3a.iam.GetPolicy(req.Name)
if err != nil { if err != nil {
@ -88,7 +95,7 @@ func (s3a *S3ApiServer) GetPolicy(ctx context.Context, req *iam_pb.GetPolicyRequ
func (s3a *S3ApiServer) ListPolicies(ctx context.Context, req *iam_pb.ListPoliciesRequest) (*iam_pb.ListPoliciesResponse, error) { func (s3a *S3ApiServer) ListPolicies(ctx context.Context, req *iam_pb.ListPoliciesRequest) (*iam_pb.ListPoliciesResponse, error) {
resp := &iam_pb.ListPoliciesResponse{} resp := &iam_pb.ListPoliciesResponse{}
if s3a.iam == nil { if s3a.iam == nil {
return resp, nil
return nil, status.Errorf(codes.Internal, "IAM not initialized")
} }
policies := s3a.iam.ListPolicies() policies := s3a.iam.ListPolicies()
for _, policy := range policies { for _, policy := range policies {

Loading…
Cancel
Save