You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
boundary/internal/daemon/worker/addressreceiver.go

69 lines
1.7 KiB

package worker
import (
"context"
"google.golang.org/grpc/resolver"
"google.golang.org/grpc/resolver/manual"
)
var extraAddressReceivers = noopAddressReceivers
func noopAddressReceivers(context.Context, *Worker) ([]addressReceiver, error) {
return nil, nil
}
type receiverType uint
const (
UnknownReceiverType receiverType = 0
grpcResolverReceiverType receiverType = 1
dialingListenerReceiverType receiverType = 2
)
// String returns a string representation of the receiverType
func (s receiverType) String() string {
return [...]string{
"unknown",
"grpcResolver",
"dialingListener",
}[s]
}
// addressReceiver allows the initializing and setting of addresses. Since a
// main use case of this interface is to use it in grpc dialing it satisfies
// a grpc resolver.Builder interface as well.
type addressReceiver interface {
InitialAddresses([]string)
SetAddresses([]string)
Type() receiverType
}
// grpcResolverReceiver is an addressReceiver which wraps a grpc manual.Resolver
// InitialAddresses is passed onto the Resolver's InitialState method and
// SetAddresses is passed onto the Resolver's UpdateState call.
type grpcResolverReceiver struct {
*manual.Resolver
}
// IsDialingListener always returns
func (_ *grpcResolverReceiver) Type() receiverType {
return grpcResolverReceiverType
}
func (r grpcResolverReceiver) getState(addrs []string) resolver.State {
var rAddrs []resolver.Address
for _, a := range addrs {
rAddrs = append(rAddrs, resolver.Address{Addr: a})
}
return resolver.State{Addresses: rAddrs}
}
func (r *grpcResolverReceiver) InitialAddresses(addrs []string) {
r.Resolver.InitialState(r.getState(addrs))
}
func (r *grpcResolverReceiver) SetAddresses(addrs []string) {
r.Resolver.UpdateState(r.getState(addrs))
}