2019-08-06 19:53:14 +03:00
|
|
|
package service
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"time"
|
|
|
|
|
2020-07-27 15:22:00 +03:00
|
|
|
"github.com/micro/go-micro/v3/broker"
|
|
|
|
"github.com/micro/go-micro/v3/broker/http"
|
|
|
|
"github.com/micro/go-micro/v3/client"
|
|
|
|
mucpClient "github.com/micro/go-micro/v3/client/mucp"
|
|
|
|
"github.com/micro/go-micro/v3/model"
|
|
|
|
"github.com/micro/go-micro/v3/registry"
|
|
|
|
"github.com/micro/go-micro/v3/registry/mdns"
|
|
|
|
"github.com/micro/go-micro/v3/server"
|
|
|
|
mucpServer "github.com/micro/go-micro/v3/server/mucp"
|
|
|
|
"github.com/micro/go-micro/v3/transport"
|
|
|
|
thttp "github.com/micro/go-micro/v3/transport/http"
|
2019-08-06 19:53:14 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
type Options struct {
|
|
|
|
Broker broker.Broker
|
|
|
|
Client client.Client
|
|
|
|
Server server.Server
|
2020-07-11 23:15:59 +03:00
|
|
|
Model model.Model
|
2019-08-06 19:53:14 +03:00
|
|
|
Registry registry.Registry
|
|
|
|
Transport transport.Transport
|
|
|
|
|
|
|
|
// Before and After funcs
|
|
|
|
BeforeStart []func() error
|
|
|
|
BeforeStop []func() error
|
|
|
|
AfterStart []func() error
|
|
|
|
AfterStop []func() error
|
|
|
|
|
|
|
|
// Other options for implementations of the interface
|
|
|
|
// can be stored in a context
|
|
|
|
Context context.Context
|
|
|
|
}
|
|
|
|
|
|
|
|
type Option func(*Options)
|
|
|
|
|
2019-12-30 00:07:55 +03:00
|
|
|
func NewOptions(opts ...Option) Options {
|
2019-08-06 19:53:14 +03:00
|
|
|
opt := Options{
|
2020-07-27 15:22:00 +03:00
|
|
|
Broker: http.NewBroker(),
|
|
|
|
Client: mucpClient.NewClient(),
|
|
|
|
Server: mucpServer.NewServer(),
|
|
|
|
Registry: mdns.NewRegistry(),
|
|
|
|
Transport: thttp.NewTransport(),
|
2019-08-06 19:53:14 +03:00
|
|
|
Context: context.Background(),
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(&opt)
|
|
|
|
}
|
|
|
|
|
|
|
|
return opt
|
|
|
|
}
|
|
|
|
|
|
|
|
func Broker(b broker.Broker) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Broker = b
|
|
|
|
// Update Client and Server
|
|
|
|
o.Client.Init(client.Broker(b))
|
|
|
|
o.Server.Init(server.Broker(b))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Client(c client.Client) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Client = c
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Context specifies a context for the service.
|
|
|
|
// Can be used to signal shutdown of the service.
|
|
|
|
// Can be used for extra option values.
|
|
|
|
func Context(ctx context.Context) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Context = ctx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-11 23:15:59 +03:00
|
|
|
// Server sets the server for handling requests
|
2019-08-06 19:53:14 +03:00
|
|
|
func Server(s server.Server) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server = s
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-11 23:15:59 +03:00
|
|
|
// Model sets the model for data access
|
|
|
|
func Model(m model.Model) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Model = m
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-06 19:53:14 +03:00
|
|
|
// Registry sets the registry for the service
|
|
|
|
// and the underlying components
|
|
|
|
func Registry(r registry.Registry) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Registry = r
|
2020-07-01 19:06:59 +03:00
|
|
|
// Update server
|
2019-08-06 19:53:14 +03:00
|
|
|
o.Server.Init(server.Registry(r))
|
|
|
|
// Update Broker
|
|
|
|
o.Broker.Init(broker.Registry(r))
|
2020-07-01 19:06:59 +03:00
|
|
|
// Update router
|
|
|
|
o.Client.Init(client.Registry(r))
|
2019-08-06 19:53:14 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Transport sets the transport for the service
|
|
|
|
// and the underlying components
|
|
|
|
func Transport(t transport.Transport) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Transport = t
|
|
|
|
// Update Client and Server
|
|
|
|
o.Client.Init(client.Transport(t))
|
|
|
|
o.Server.Init(server.Transport(t))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Convenience options
|
|
|
|
|
|
|
|
// Address sets the address of the server
|
|
|
|
func Address(addr string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.Address(addr))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Name of the service
|
|
|
|
func Name(n string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.Name(n))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Version of the service
|
|
|
|
func Version(v string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.Version(v))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Metadata associated with the service
|
|
|
|
func Metadata(md map[string]string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.Metadata(md))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterTTL specifies the TTL to use when registering the service
|
|
|
|
func RegisterTTL(t time.Duration) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.RegisterTTL(t))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// RegisterInterval specifies the interval on which to re-register
|
|
|
|
func RegisterInterval(t time.Duration) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server.Init(server.RegisterInterval(t))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WrapClient is a convenience method for wrapping a Client with
|
|
|
|
// some middleware component. A list of wrappers can be provided.
|
|
|
|
// Wrappers are applied in reverse order so the last is executed first.
|
|
|
|
func WrapClient(w ...client.Wrapper) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
// apply in reverse
|
|
|
|
for i := len(w); i > 0; i-- {
|
|
|
|
o.Client = w[i-1](o.Client)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WrapCall is a convenience method for wrapping a Client CallFunc
|
|
|
|
func WrapCall(w ...client.CallWrapper) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Client.Init(client.WrapCall(w...))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WrapHandler adds a handler Wrapper to a list of options passed into the server
|
|
|
|
func WrapHandler(w ...server.HandlerWrapper) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
var wrappers []server.Option
|
|
|
|
|
|
|
|
for _, wrap := range w {
|
|
|
|
wrappers = append(wrappers, server.WrapHandler(wrap))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init once
|
|
|
|
o.Server.Init(wrappers...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// WrapSubscriber adds a subscriber Wrapper to a list of options passed into the server
|
|
|
|
func WrapSubscriber(w ...server.SubscriberWrapper) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
var wrappers []server.Option
|
|
|
|
|
|
|
|
for _, wrap := range w {
|
|
|
|
wrappers = append(wrappers, server.WrapSubscriber(wrap))
|
|
|
|
}
|
|
|
|
|
|
|
|
// Init once
|
|
|
|
o.Server.Init(wrappers...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Before and Afters
|
|
|
|
|
|
|
|
func BeforeStart(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.BeforeStart = append(o.BeforeStart, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func BeforeStop(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.BeforeStop = append(o.BeforeStop, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func AfterStart(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.AfterStart = append(o.AfterStart, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func AfterStop(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.AfterStop = append(o.AfterStop, fn)
|
|
|
|
}
|
|
|
|
}
|