mirror of
https://github.com/linka-cloud/grpc.git
synced 2024-11-27 05:16:25 +00:00
26 lines
1.1 KiB
Go
26 lines
1.1 KiB
Go
|
// Copyright 2017 Michal Witkowski. All Rights Reserved.
|
||
|
// See LICENSE for licensing terms.
|
||
|
|
||
|
package proxy
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
|
||
|
"google.golang.org/grpc"
|
||
|
)
|
||
|
|
||
|
// StreamDirector returns a gRPC ClientConn to be used to forward the call to.
|
||
|
//
|
||
|
// The presence of the `Context` allows for rich filtering, e.g. based on Metadata (headers).
|
||
|
// If no handling is meant to be done, a `codes.NotImplemented` gRPC error should be returned.
|
||
|
//
|
||
|
// The context returned from this function should be the context for the *outgoing* (to backend) call. In case you want
|
||
|
// to forward any Metadata between the inbound request and outbound requests, you should do it manually. However, you
|
||
|
// *must* propagate the cancel function (`context.WithCancel`) of the inbound context to the one returned.
|
||
|
//
|
||
|
// It is worth noting that the StreamDirector will be fired *after* all server-side stream interceptors
|
||
|
// are invoked. So decisions around authorization, monitoring etc. are better to be handled there.
|
||
|
//
|
||
|
// See the rather rich example.
|
||
|
type StreamDirector func(ctx context.Context, fullMethodName string) (context.Context, grpc.ClientConnInterface, error)
|