mirror of
https://github.com/yusing/godoxy.git
synced 2026-04-24 09:18:31 +02:00
routes in loadbalance pool no longer listed in ls-route and its API, the loadbalancer is listed instead. improved context handling and grateful shutdown
This commit is contained in:
@@ -1,7 +1,6 @@
|
||||
package config
|
||||
|
||||
import (
|
||||
"context"
|
||||
"os"
|
||||
|
||||
"github.com/sirupsen/logrus"
|
||||
@@ -25,10 +24,9 @@ type Config struct {
|
||||
|
||||
l logrus.FieldLogger
|
||||
|
||||
watcher W.Watcher
|
||||
watcherCtx context.Context
|
||||
watcherCancel context.CancelFunc
|
||||
reloadReq chan struct{}
|
||||
watcher W.Watcher
|
||||
|
||||
reloadReq chan struct{}
|
||||
}
|
||||
|
||||
var instance *Config
|
||||
@@ -76,14 +74,6 @@ func (cfg *Config) GetAutoCertProvider() *autocert.Provider {
|
||||
return cfg.autocertProvider
|
||||
}
|
||||
|
||||
func (cfg *Config) Dispose() {
|
||||
if cfg.watcherCancel != nil {
|
||||
cfg.watcherCancel()
|
||||
cfg.l.Debug("stopped watcher")
|
||||
}
|
||||
cfg.stopProviders()
|
||||
}
|
||||
|
||||
func (cfg *Config) Reload() (err E.NestedError) {
|
||||
cfg.stopProviders()
|
||||
err = cfg.load()
|
||||
@@ -96,11 +86,13 @@ func (cfg *Config) StartProxyProviders() {
|
||||
}
|
||||
|
||||
func (cfg *Config) WatchChanges() {
|
||||
cfg.watcherCtx, cfg.watcherCancel = context.WithCancel(context.Background())
|
||||
task := common.NewTask("Config watcher")
|
||||
defer task.Finished()
|
||||
|
||||
go func() {
|
||||
for {
|
||||
select {
|
||||
case <-cfg.watcherCtx.Done():
|
||||
case <-task.Context().Done():
|
||||
return
|
||||
case <-cfg.reloadReq:
|
||||
if err := cfg.Reload(); err != nil {
|
||||
@@ -110,10 +102,10 @@ func (cfg *Config) WatchChanges() {
|
||||
}
|
||||
}()
|
||||
go func() {
|
||||
eventCh, errCh := cfg.watcher.Events(cfg.watcherCtx)
|
||||
eventCh, errCh := cfg.watcher.Events(task.Context())
|
||||
for {
|
||||
select {
|
||||
case <-cfg.watcherCtx.Done():
|
||||
case <-task.Context().Done():
|
||||
return
|
||||
case event := <-eventCh:
|
||||
if event.Action == events.ActionFileDeleted || event.Action == events.ActionFileRenamed {
|
||||
|
||||
@@ -97,23 +97,31 @@ func (cfg *Config) HomepageConfig() homepage.Config {
|
||||
return hpCfg
|
||||
}
|
||||
|
||||
func (cfg *Config) RoutesByAlias() map[string]U.SerializedObject {
|
||||
func (cfg *Config) RoutesByAlias(typeFilter ...R.RouteType) map[string]U.SerializedObject {
|
||||
routes := make(map[string]U.SerializedObject)
|
||||
cfg.forEachRoute(func(alias string, r *R.Route, p *PR.Provider) {
|
||||
if !r.Started() {
|
||||
return
|
||||
if len(typeFilter) == 0 {
|
||||
typeFilter = []R.RouteType{R.RouteTypeReverseProxy, R.RouteTypeStream}
|
||||
}
|
||||
for _, t := range typeFilter {
|
||||
switch t {
|
||||
case R.RouteTypeReverseProxy:
|
||||
R.GetReverseProxies().RangeAll(func(alias string, r *R.HTTPRoute) {
|
||||
obj, err := U.Serialize(r)
|
||||
if err != nil {
|
||||
panic(err) // should not happen
|
||||
}
|
||||
routes[alias] = obj
|
||||
})
|
||||
case R.RouteTypeStream:
|
||||
R.GetStreamProxies().RangeAll(func(alias string, r *R.StreamRoute) {
|
||||
obj, err := U.Serialize(r)
|
||||
if err != nil {
|
||||
panic(err) // should not happen
|
||||
}
|
||||
routes[alias] = obj
|
||||
})
|
||||
}
|
||||
obj, err := U.Serialize(r)
|
||||
if err != nil {
|
||||
cfg.l.Error(err)
|
||||
return
|
||||
}
|
||||
obj["provider"] = p.GetName()
|
||||
obj["type"] = string(r.Type)
|
||||
obj["started"] = r.Started()
|
||||
obj["raw"] = r.Entry
|
||||
routes[alias] = obj
|
||||
})
|
||||
}
|
||||
return routes
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user