Fix file watcher

This commit is contained in:
Julien Salleyron 2024-02-09 11:08:05 +01:00 committed by GitHub
parent d5cb9b50f4
commit 676de5fb68
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -6,6 +6,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"os" "os"
"path"
"path/filepath" "path/filepath"
"strings" "strings"
"text/template" "text/template"
@ -47,18 +48,31 @@ func (p *Provider) Init() error {
// using the given configuration channel. // using the given configuration channel.
func (p *Provider) Provide(configurationChan chan<- dynamic.Message, pool *safe.Pool) error { func (p *Provider) Provide(configurationChan chan<- dynamic.Message, pool *safe.Pool) error {
if p.Watch { if p.Watch {
var watchItem string var watchItems []string
switch { switch {
case len(p.Directory) > 0: case len(p.Directory) > 0:
watchItem = p.Directory watchItems = append(watchItems, p.Directory)
fileList, err := os.ReadDir(p.Directory)
if err != nil {
return fmt.Errorf("unable to read directory %s: %w", p.Directory, err)
}
for _, entry := range fileList {
if entry.IsDir() {
// ignore sub-dir
continue
}
watchItems = append(watchItems, path.Join(p.Directory, entry.Name()))
}
case len(p.Filename) > 0: case len(p.Filename) > 0:
watchItem = filepath.Dir(p.Filename) watchItems = append(watchItems, filepath.Dir(p.Filename), p.Filename)
default: default:
return errors.New("error using file configuration provider, neither filename or directory defined") return errors.New("error using file configuration provider, neither filename or directory defined")
} }
if err := p.addWatcher(pool, watchItem, configurationChan, p.watcherCallback); err != nil { if err := p.addWatcher(pool, watchItems, configurationChan, p.watcherCallback); err != nil {
return err return err
} }
} }
@ -92,15 +106,18 @@ func (p *Provider) BuildConfiguration() (*dynamic.Configuration, error) {
return nil, errors.New("error using file configuration provider, neither filename or directory defined") return nil, errors.New("error using file configuration provider, neither filename or directory defined")
} }
func (p *Provider) addWatcher(pool *safe.Pool, directory string, configurationChan chan<- dynamic.Message, callback func(chan<- dynamic.Message, fsnotify.Event)) error { func (p *Provider) addWatcher(pool *safe.Pool, items []string, configurationChan chan<- dynamic.Message, callback func(chan<- dynamic.Message, fsnotify.Event)) error {
watcher, err := fsnotify.NewWatcher() watcher, err := fsnotify.NewWatcher()
if err != nil { if err != nil {
return fmt.Errorf("error creating file watcher: %w", err) return fmt.Errorf("error creating file watcher: %w", err)
} }
err = watcher.Add(directory) for _, item := range items {
if err != nil { log.WithoutContext().Debugf("add watcher on: %s", item)
return fmt.Errorf("error adding file watcher: %w", err) err = watcher.Add(item)
if err != nil {
return fmt.Errorf("error adding file watcher: %w", err)
}
} }
// Process events // Process events