2021-02-17 11:14:47 +02:00
|
|
|
package transport
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2021-05-31 10:10:17 +02:00
|
|
|
"net/url"
|
2021-02-17 11:14:47 +02:00
|
|
|
|
|
|
|
// init encoding
|
|
|
|
_ "github.com/go-kratos/kratos/v2/encoding/json"
|
|
|
|
_ "github.com/go-kratos/kratos/v2/encoding/proto"
|
2021-05-11 05:36:20 +02:00
|
|
|
_ "github.com/go-kratos/kratos/v2/encoding/xml"
|
2021-05-17 15:52:23 +02:00
|
|
|
_ "github.com/go-kratos/kratos/v2/encoding/yaml"
|
2021-06-11 09:05:57 +02:00
|
|
|
"github.com/go-kratos/kratos/v2/metadata"
|
2021-02-17 11:14:47 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// Server is transport server.
|
|
|
|
type Server interface {
|
2021-05-29 17:52:05 +02:00
|
|
|
Start(context.Context) error
|
|
|
|
Stop(context.Context) error
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-05-28 09:30:55 +02:00
|
|
|
// Endpointer is registry endpoint.
|
|
|
|
type Endpointer interface {
|
2021-05-31 10:10:17 +02:00
|
|
|
Endpoint() (*url.URL, error)
|
2021-05-28 09:30:55 +02:00
|
|
|
}
|
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// Transporter is transport context value interface.
|
|
|
|
type Transporter interface {
|
|
|
|
Kind() string
|
|
|
|
Endpoint() string
|
|
|
|
|
2021-06-12 12:30:17 +02:00
|
|
|
Operation() string
|
|
|
|
SetOperation(string)
|
2021-06-11 09:05:57 +02:00
|
|
|
|
|
|
|
Metadata() metadata.Metadata
|
|
|
|
// WithMetadata merge new metadata into transport,
|
|
|
|
// it will override old metadata key value if key exists
|
|
|
|
WithMetadata(metadata.Metadata)
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
type serverTransportKey struct{}
|
|
|
|
type clientTransportKey struct{}
|
2021-03-05 15:09:02 +02:00
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// NewServerContext returns a new Context that carries value.
|
|
|
|
func NewServerContext(ctx context.Context, tr Transporter) context.Context {
|
|
|
|
return context.WithValue(ctx, serverTransportKey{}, tr)
|
|
|
|
}
|
2021-03-05 15:09:02 +02:00
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// FromServerContext returns the Transport value stored in ctx, if any.
|
|
|
|
func FromServerContext(ctx context.Context) (tr Transporter, ok bool) {
|
|
|
|
tr, ok = ctx.Value(serverTransportKey{}).(Transporter)
|
|
|
|
return
|
|
|
|
}
|
2021-02-17 11:14:47 +02:00
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// NewClientContext returns a new Context that carries value.
|
|
|
|
func NewClientContext(ctx context.Context, tr Transporter) context.Context {
|
|
|
|
return context.WithValue(ctx, clientTransportKey{}, tr)
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// FromClientContext returns the Transport value stored in ctx, if any.
|
|
|
|
func FromClientContext(ctx context.Context) (tr Transporter, ok bool) {
|
|
|
|
tr, ok = ctx.Value(clientTransportKey{}).(Transporter)
|
2021-02-17 11:14:47 +02:00
|
|
|
return
|
|
|
|
}
|
2021-06-11 09:05:57 +02:00
|
|
|
|
2021-06-12 12:30:17 +02:00
|
|
|
// SetOperation set operation into context transport.
|
|
|
|
func SetOperation(ctx context.Context, method string) {
|
2021-06-11 09:05:57 +02:00
|
|
|
if tr, ok := FromServerContext(ctx); ok {
|
2021-06-12 12:30:17 +02:00
|
|
|
tr.SetOperation(method)
|
2021-06-11 09:05:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-06-12 12:30:17 +02:00
|
|
|
// Operation returns the Transport operation from server context.
|
|
|
|
func Operation(ctx context.Context) string {
|
2021-06-11 09:05:57 +02:00
|
|
|
if tr, ok := FromServerContext(ctx); ok {
|
2021-06-12 12:30:17 +02:00
|
|
|
return tr.Operation()
|
2021-06-11 09:05:57 +02:00
|
|
|
}
|
2021-06-12 12:30:17 +02:00
|
|
|
return ""
|
2021-06-11 09:05:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Metadata returns incoming metadata from server transport.
|
|
|
|
func Metadata(ctx context.Context) metadata.Metadata {
|
|
|
|
if tr, ok := FromServerContext(ctx); ok {
|
|
|
|
return tr.Metadata()
|
|
|
|
}
|
|
|
|
return metadata.Metadata{}
|
|
|
|
}
|