package mount import ( "errors" "fmt" "github.com/seaweedfs/seaweedfs/weed/filer" "github.com/seaweedfs/seaweedfs/weed/glog" "github.com/seaweedfs/seaweedfs/weed/mount/meta_cache" "github.com/seaweedfs/seaweedfs/weed/pb/filer_pb" "github.com/seaweedfs/seaweedfs/weed/util" "path/filepath" ) func (wfs *WFS) subscribeFilerConfEvents() (*meta_cache.MetadataFollower, error) { confDir := filer.DirectoryEtcSeaweedFS confName := filer.FilerConfName confFullName := filepath.Join(filer.DirectoryEtcSeaweedFS, filer.FilerConfName) // read current conf err := wfs.WithFilerClient(false, func(client filer_pb.SeaweedFilerClient) error { content, err := filer.ReadInsideFiler(client, confDir, confName) if err != nil { return err } fc := filer.NewFilerConf() if len(content) > 0 { if err := fc.LoadFromBytes(content); err != nil { return fmt.Errorf("parse %s: %v", confFullName, err) } } wfs.FilerConf = fc return nil }) if err != nil { if errors.Is(err, filer_pb.ErrNotFound) { glog.V(0).Infof("fuse filer conf %s not found", confFullName) } else { return nil, err } } processEventFn := func(resp *filer_pb.SubscribeMetadataResponse) error { message := resp.EventNotification if message.NewEntry == nil { return nil } dir := resp.Directory name := resp.EventNotification.NewEntry.Name if dir != confDir || name != confName { return nil } content := message.NewEntry.Content fc := filer.NewFilerConf() if len(content) > 0 { if err = fc.LoadFromBytes(content); err != nil { return fmt.Errorf("parse %s: %v", confFullName, err) } } wfs.FilerConf = fc return nil } return &meta_cache.MetadataFollower{ PathPrefixToWatch: confFullName, ProcessEventFn: processEventFn, }, nil } func (wfs *WFS) wormEnabledForEntry(path util.FullPath, entry *filer_pb.Entry) bool { if entry == nil || entry.Attributes == nil { return false } if wfs.FilerConf == nil { return false } rule := wfs.FilerConf.MatchStorageRule(string(path)) if !rule.Worm { return false } return entry.Attributes.FileSize > 0 || entry.Attributes.Crtime != entry.Attributes.Mtime }