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
|
2021-07-01 14:36:12 +02:00
|
|
|
_ "github.com/go-kratos/kratos/v2/encoding/form"
|
2021-02-17 11:14:47 +02:00
|
|
|
_ "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-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-13 18:59:07 +02:00
|
|
|
// Header is the storage medium used by a Header.
|
|
|
|
type Header interface {
|
|
|
|
Get(key string) string
|
|
|
|
Set(key string, value string)
|
|
|
|
Keys() []string
|
|
|
|
}
|
|
|
|
|
2021-06-11 09:05:57 +02:00
|
|
|
// Transporter is transport context value interface.
|
|
|
|
type Transporter interface {
|
2021-08-16 04:35:08 +02:00
|
|
|
// Kind transporter
|
2021-06-17 04:26:45 +02:00
|
|
|
// grpc
|
|
|
|
// http
|
2021-06-15 05:05:13 +02:00
|
|
|
Kind() Kind
|
2021-08-16 04:35:08 +02:00
|
|
|
// Endpoint return server or client endpoint
|
2021-06-17 04:26:45 +02:00
|
|
|
// Server Transport: grpc://127.0.0.1:9000
|
|
|
|
// Client Transport: discovery:///provider-demo
|
2021-06-11 09:05:57 +02:00
|
|
|
Endpoint() string
|
2021-08-16 04:35:08 +02:00
|
|
|
// Operation Service full method selector generated by protobuf
|
2021-06-17 04:26:45 +02:00
|
|
|
// example: /helloworld.Greeter/SayHello
|
2021-06-12 12:30:17 +02:00
|
|
|
Operation() string
|
2021-08-16 04:35:08 +02:00
|
|
|
// RequestHeader return transport request header
|
2021-06-17 04:26:45 +02:00
|
|
|
// http: http.Header
|
|
|
|
// grpc: metadata.MD
|
2021-06-29 09:33:18 +02:00
|
|
|
RequestHeader() Header
|
2021-08-16 04:35:08 +02:00
|
|
|
// ReplyHeader return transport reply/response header
|
2021-06-29 09:33:18 +02:00
|
|
|
// only valid for server transport
|
|
|
|
// http: http.Header
|
|
|
|
// grpc: metadata.MD
|
|
|
|
ReplyHeader() Header
|
2021-02-17 11:14:47 +02:00
|
|
|
}
|
|
|
|
|
2021-06-15 05:05:13 +02:00
|
|
|
// Kind defines the type of Transport
|
|
|
|
type Kind string
|
|
|
|
|
2021-06-29 09:33:18 +02:00
|
|
|
func (k Kind) String() string { return string(k) }
|
2021-06-15 05:05:13 +02:00
|
|
|
|
|
|
|
// Defines a set of transport kind
|
|
|
|
const (
|
|
|
|
KindGRPC Kind = "grpc"
|
|
|
|
KindHTTP Kind = "http"
|
|
|
|
)
|
|
|
|
|
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
|
|
|
|
}
|