1
0
mirror of https://github.com/ceph/ceph-csi.git synced 2025-01-01 17:55:32 +00:00
ceph-csi/vendor/github.com/aws/smithy-go/middleware/logging.go
Rakshith R 4f0bb2315b rbd: add aws-sts-metdata encryption type
With Amazon STS and kubernetes cluster is configured with
OIDC identity provider, credentials to access Amazon KMS
can be fetched using oidc-token(serviceaccount token).
Each tenant/namespace needs to create a secret with aws region,
role and CMK ARN.
Ceph-CSI will assume the given role with oidc token and access
aws KMS, with given CMK to encrypt/decrypt DEK which will stored
in the image metdata.

Refer: https://docs.aws.amazon.com/STS/latest/APIReference/welcome.html
Resolves: 

Signed-off-by: Rakshith R <rar@redhat.com>
2022-03-16 07:29:56 +00:00

47 lines
1.5 KiB
Go

package middleware
import (
"context"
"github.com/aws/smithy-go/logging"
)
// loggerKey is the context value key for which the logger is associated with.
type loggerKey struct{}
// GetLogger takes a context to retrieve a Logger from. If no logger is present on the context a logging.Nop logger
// is returned. If the logger retrieved from context supports the ContextLogger interface, the context will be passed
// to the WithContext method and the resulting logger will be returned. Otherwise the stored logger is returned as is.
func GetLogger(ctx context.Context) logging.Logger {
logger, ok := ctx.Value(loggerKey{}).(logging.Logger)
if !ok || logger == nil {
return logging.Nop{}
}
return logging.WithContext(ctx, logger)
}
// SetLogger sets the provided logger value on the provided ctx.
func SetLogger(ctx context.Context, logger logging.Logger) context.Context {
return context.WithValue(ctx, loggerKey{}, logger)
}
type setLogger struct {
Logger logging.Logger
}
// AddSetLoggerMiddleware adds a middleware that will add the provided logger to the middleware context.
func AddSetLoggerMiddleware(stack *Stack, logger logging.Logger) error {
return stack.Initialize.Add(&setLogger{Logger: logger}, After)
}
func (a *setLogger) ID() string {
return "SetLogger"
}
func (a *setLogger) HandleInitialize(ctx context.Context, in InitializeInput, next InitializeHandler) (
out InitializeOutput, metadata Metadata, err error,
) {
return next.HandleInitialize(SetLogger(ctx, a.Logger), in)
}