2019-06-03 20:30:43 +02:00
|
|
|
package web
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"crypto/tls"
|
|
|
|
"net/http"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/micro/cli"
|
|
|
|
"github.com/micro/go-micro"
|
|
|
|
"github.com/micro/go-micro/registry"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Options struct {
|
|
|
|
Name string
|
|
|
|
Version string
|
|
|
|
Id string
|
|
|
|
Metadata map[string]string
|
|
|
|
Address string
|
|
|
|
Advertise string
|
|
|
|
|
|
|
|
Action func(*cli.Context)
|
|
|
|
Flags []cli.Flag
|
|
|
|
|
|
|
|
RegisterTTL time.Duration
|
|
|
|
RegisterInterval time.Duration
|
|
|
|
|
2019-12-05 16:15:35 +02:00
|
|
|
// RegisterCheck runs a check function before registering the service
|
|
|
|
RegisterCheck func(context.Context) error
|
|
|
|
|
2019-06-03 20:30:43 +02:00
|
|
|
Server *http.Server
|
|
|
|
Handler http.Handler
|
|
|
|
|
|
|
|
// Alternative Options
|
|
|
|
Context context.Context
|
|
|
|
|
|
|
|
Registry registry.Registry
|
|
|
|
Service micro.Service
|
|
|
|
|
|
|
|
Secure bool
|
|
|
|
TLSConfig *tls.Config
|
|
|
|
BeforeStart []func() error
|
|
|
|
BeforeStop []func() error
|
|
|
|
AfterStart []func() error
|
|
|
|
AfterStop []func() error
|
|
|
|
|
|
|
|
// Static directory
|
|
|
|
StaticDir string
|
|
|
|
}
|
|
|
|
|
|
|
|
func newOptions(opts ...Option) Options {
|
|
|
|
opt := Options{
|
|
|
|
Name: DefaultName,
|
|
|
|
Version: DefaultVersion,
|
|
|
|
Id: DefaultId,
|
|
|
|
Address: DefaultAddress,
|
|
|
|
RegisterTTL: DefaultRegisterTTL,
|
|
|
|
RegisterInterval: DefaultRegisterInterval,
|
|
|
|
StaticDir: DefaultStaticDir,
|
|
|
|
Service: micro.NewService(),
|
|
|
|
Context: context.TODO(),
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(&opt)
|
|
|
|
}
|
|
|
|
|
2019-12-05 16:15:35 +02:00
|
|
|
if opt.RegisterCheck == nil {
|
|
|
|
opt.RegisterCheck = DefaultRegisterCheck
|
|
|
|
}
|
|
|
|
|
2019-06-03 20:30:43 +02:00
|
|
|
return opt
|
|
|
|
}
|
|
|
|
|
|
|
|
// Server name
|
|
|
|
func Name(n string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Name = n
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-20 14:43:43 +02:00
|
|
|
// Icon specifies an icon url to load in the UI
|
|
|
|
func Icon(ico string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
if o.Metadata == nil {
|
|
|
|
o.Metadata = make(map[string]string)
|
|
|
|
}
|
|
|
|
o.Metadata["icon"] = ico
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-03 20:30:43 +02:00
|
|
|
// Unique server id
|
|
|
|
func Id(id string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Id = id
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Version of the service
|
|
|
|
func Version(v string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Version = v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Metadata associated with the service
|
|
|
|
func Metadata(md map[string]string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Metadata = md
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Address to bind to - host:port
|
|
|
|
func Address(a string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Address = a
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The address to advertise for discovery - host:port
|
|
|
|
func Advertise(a string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Advertise = a
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// 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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-05 18:37:03 +02:00
|
|
|
// Registry used for discovery
|
2019-06-03 20:30:43 +02:00
|
|
|
func Registry(r registry.Registry) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Registry = r
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-05 18:37:03 +02:00
|
|
|
// Register the service with a TTL
|
2019-06-03 20:30:43 +02:00
|
|
|
func RegisterTTL(t time.Duration) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.RegisterTTL = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-12-05 18:37:03 +02:00
|
|
|
// Register the service with at interval
|
2019-06-03 20:30:43 +02:00
|
|
|
func RegisterInterval(t time.Duration) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.RegisterInterval = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Handler(h http.Handler) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Handler = h
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func Server(srv *http.Server) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Server = srv
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// MicroService sets the micro.Service used internally
|
|
|
|
func MicroService(s micro.Service) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Service = s
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Flags sets the command flags.
|
|
|
|
func Flags(flags ...cli.Flag) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Flags = append(o.Flags, flags...)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Action sets the command action.
|
|
|
|
func Action(a func(*cli.Context)) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Action = a
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// BeforeStart is executed before the server starts.
|
|
|
|
func BeforeStart(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.BeforeStart = append(o.BeforeStart, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// BeforeStop is executed before the server stops.
|
|
|
|
func BeforeStop(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.BeforeStop = append(o.BeforeStop, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// AfterStart is executed after server start.
|
|
|
|
func AfterStart(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.AfterStart = append(o.AfterStart, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// AfterStop is executed after server stop.
|
|
|
|
func AfterStop(fn func() error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.AfterStop = append(o.AfterStop, fn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Secure Use secure communication. If TLSConfig is not specified we use InsecureSkipVerify and generate a self signed cert
|
|
|
|
func Secure(b bool) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.Secure = b
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TLSConfig to be used for the transport.
|
|
|
|
func TLSConfig(t *tls.Config) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.TLSConfig = t
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// StaticDir sets the static file directory. This defaults to ./html
|
|
|
|
func StaticDir(d string) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.StaticDir = d
|
|
|
|
}
|
|
|
|
}
|
2019-12-05 16:15:35 +02:00
|
|
|
|
|
|
|
// RegisterCheck run func before registry service
|
|
|
|
func RegisterCheck(fn func(context.Context) error) Option {
|
|
|
|
return func(o *Options) {
|
|
|
|
o.RegisterCheck = fn
|
|
|
|
}
|
|
|
|
}
|