package registry import ( "context" "crypto/tls" "time" "go-micro.dev/v4/logger" ) type Options struct { Addrs []string Timeout time.Duration Secure bool TLSConfig *tls.Config Logger logger.Logger // Other options for implementations of the interface // can be stored in a context Context context.Context } type RegisterOptions struct { TTL time.Duration // Other options for implementations of the interface // can be stored in a context Context context.Context } type WatchOptions struct { // Specify a service to watch // If blank, the watch is for all services Service string // Other options for implementations of the interface // can be stored in a context Context context.Context } type DeregisterOptions struct { Context context.Context } type GetOptions struct { Context context.Context } type ListOptions struct { Context context.Context } func NewOptions(opts ...Option) *Options { options := Options{ Context: context.Background(), Logger: logger.DefaultLogger, } for _, o := range opts { o(&options) } return &options } // Addrs is the registry addresses to use. func Addrs(addrs ...string) Option { return func(o *Options) { o.Addrs = addrs } } func Timeout(t time.Duration) Option { return func(o *Options) { o.Timeout = t } } // Secure communication with the registry. func Secure(b bool) Option { return func(o *Options) { o.Secure = b } } // Specify TLS Config. func TLSConfig(t *tls.Config) Option { return func(o *Options) { o.TLSConfig = t } } func RegisterTTL(t time.Duration) RegisterOption { return func(o *RegisterOptions) { o.TTL = t } } func RegisterContext(ctx context.Context) RegisterOption { return func(o *RegisterOptions) { o.Context = ctx } } // Watch a service. func WatchService(name string) WatchOption { return func(o *WatchOptions) { o.Service = name } } func WatchContext(ctx context.Context) WatchOption { return func(o *WatchOptions) { o.Context = ctx } } func DeregisterContext(ctx context.Context) DeregisterOption { return func(o *DeregisterOptions) { o.Context = ctx } } func GetContext(ctx context.Context) GetOption { return func(o *GetOptions) { o.Context = ctx } } func ListContext(ctx context.Context) ListOption { return func(o *ListOptions) { o.Context = ctx } } type servicesKey struct{} func getServiceRecords(ctx context.Context) map[string]map[string]*record { memServices, ok := ctx.Value(servicesKey{}).(map[string][]*Service) if !ok { return nil } services := make(map[string]map[string]*record) for name, svc := range memServices { if _, ok := services[name]; !ok { services[name] = make(map[string]*record) } // go through every version of the service for _, s := range svc { services[s.Name][s.Version] = serviceToRecord(s, 0) } } return services } // Services is an option that preloads service data. func Services(s map[string][]*Service) Option { return func(o *Options) { if o.Context == nil { o.Context = context.Background() } o.Context = context.WithValue(o.Context, servicesKey{}, s) } } // Logger sets the underline logger. func Logger(l logger.Logger) Option { return func(o *Options) { o.Logger = l } }