2016-12-14 18:41:48 +03:00
|
|
|
// Package metadata is a way of defining message headers
|
2016-01-28 20:55:28 +03:00
|
|
|
package metadata
|
|
|
|
|
|
|
|
import (
|
2018-03-03 14:53:52 +03:00
|
|
|
"context"
|
2016-01-28 20:55:28 +03:00
|
|
|
)
|
|
|
|
|
2016-01-28 21:24:56 +03:00
|
|
|
type metaKey struct{}
|
2016-01-28 20:55:28 +03:00
|
|
|
|
2016-01-31 00:17:44 +03:00
|
|
|
// Metadata is our way of representing request headers internally.
|
|
|
|
// They're used at the RPC level and translate back and forth
|
|
|
|
// from Transport headers.
|
2016-01-28 20:55:28 +03:00
|
|
|
type Metadata map[string]string
|
|
|
|
|
2019-01-17 12:40:49 +03:00
|
|
|
func Copy(md Metadata) Metadata {
|
|
|
|
cmd := make(Metadata)
|
|
|
|
for k, v := range md {
|
|
|
|
cmd[k] = v
|
|
|
|
}
|
|
|
|
return cmd
|
|
|
|
}
|
|
|
|
|
2016-01-28 20:55:28 +03:00
|
|
|
func FromContext(ctx context.Context) (Metadata, bool) {
|
2016-01-28 21:24:56 +03:00
|
|
|
md, ok := ctx.Value(metaKey{}).(Metadata)
|
2016-01-28 20:55:28 +03:00
|
|
|
return md, ok
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewContext(ctx context.Context, md Metadata) context.Context {
|
2016-01-28 21:24:56 +03:00
|
|
|
return context.WithValue(ctx, metaKey{}, md)
|
2016-01-28 20:55:28 +03:00
|
|
|
}
|
2019-10-25 03:51:54 +03:00
|
|
|
|
|
|
|
// PatchContext : will add/replace source metadata fields with given patch metadata fields
|
|
|
|
func PatchContext(ctx context.Context, patchMd Metadata) context.Context {
|
|
|
|
md, _ := ctx.Value(metaKey{}).(Metadata)
|
|
|
|
cmd := make(Metadata)
|
|
|
|
for k, v := range md {
|
|
|
|
cmd[k] = v
|
|
|
|
}
|
|
|
|
for k, v := range patchMd {
|
|
|
|
cmd[k] = v
|
|
|
|
}
|
|
|
|
return context.WithValue(ctx, metaKey{}, cmd)
|
|
|
|
|
|
|
|
}
|