Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[API Proposal]: Microsoft.Extensions.FileProviders.Physical.PhysicalFilesWatcher should expose modified files (Alternative where standalone FilesystemWatcher won't work) #110969

Open
tradem opened this issue Dec 27, 2024 · 1 comment
Labels
api-suggestion Early API idea and discussion, it is NOT ready for implementation area-System.IO untriaged New issue has not been triaged by the area owner

Comments

@tradem
Copy link

tradem commented Dec 27, 2024

Background and motivation

Currently, PhysicalFileProvider provides a configurable file modification detector via PhysicalFilesWatcher wrapped by FilesystemWatcher and offers a polling feature on request (either by API or via environment variables).

Unfortunately, IChangeToken hides file path information of the actual file changes to API user/client code. While information hiding is a quite common design technique, file path information may become quite useful for API users, especially when polling is the only option available to achieve modification tracking/observation and a fallback to a custom implementation based on (good-old) FilesystemWatcher is not an option.

Please consider to either enhance IPollingChangeToken to expose (physical) FileInfo or provide an extra IChangeToken which exposes file paths for all behaviors implemented in PhysicalFilesWatcher.

API Proposal

namespace Microsoft.Extensions.FileProviders.Physical
{
  
    public class PollingFileChangeToken : IPollingChangeToken
    {
        private readonly FileInfo _fileInfo;
        private DateTime _previousWriteTimeUtc;
        private DateTime _lastCheckedTimeUtc;
        private bool _hasChanged;
        private CancellationTokenSource? _tokenSource;
        private CancellationChangeToken? _changeToken;

        public PollingFileChangeToken(FileInfo fileInfo)
        {
            _fileInfo = fileInfo;
            _previousWriteTimeUtc = GetLastWriteTimeUtc();
        }


      public IFileInfo FileInfo => __fileInfo ;

  }

API Usage

  PhysicalFileProviderfileProvider = new (Directory.GetCurrentDirectory());
  CompositeChangeToken token = fileProvider.Watch(_fileFilter) as CompositeChangeToken ;
  ConcurrentQueue<IFileInfo> changeList = new ();

   token.RegisterChangeCallback(state => 
   {
         IFileInfo[] modifcationList =  token.ChangeTokens
                                             .Cast<PollingFileChangeToken>()
                                             .Select(token => token.FileInfo )
                                             .ToArray();
   } , default);

Drawback: This approch might not be perfomant. Neither it provides an elegant solution.

Alternative Designs

Alternativly please consider to extract polling feature as an independent (refactored/extracted) PollingFilesystemWatcher which offfers either customized IChangeToken or Rx.NET support if changing information hiding policy here violates IChangeToken concept or any SOLID principle , I might have missed in my orginal propoals (due to lack of insight and/or overview of your orginal design consideration and usage).

namespace Microsoft.Extensions.FileProviders.Physical
{
    /// <summary>
    /// Watches a physical file system for changes and triggers events on
    /// <see cref="IChangeToken" /> when files are created, change, renamed, or deleted.
    /// </summary>
    public class PhysicalFilesWatcher : IDisposable
    {
        
          public IObserable<IFileInfo> WhenFileSystemEntryChange()  
        
    }

Or

namespace Microsoft.Extensions.FileProviders
{
    public interface IFileChangeToken : IChangeToken
    {

        public IFileInfo RootPath { get; }

        IDisposable RegisterChangeCallback(Action<IFileInfo?> callback, object? state);

    }
}
 


namespace Microsoft.Extensions.FileProviders.Physical
{
   

   /// <summary>
    /// Watches a physical file system for changes and triggers events on
    /// <see cref="IChangeToken" /> when files are created, change, renamed, or deleted.
    /// </summary>
    public class PhysicalFilesWatcher : IDisposable
    {
        
          public IFileChangeToken  Start()  
        
    }

MIght Pick up some ideas already discussed in #17111

Risks

  • Violation of information hiding policy or intended contracts
  • Violoation of even more SOLID principles by just exposing IFileInfo when extraction and adding another level of abstraction might offer a more plausbile and solid concept
  • API suggestion (currently) neither elegant nor performant
@tradem tradem added the api-suggestion Early API idea and discussion, it is NOT ready for implementation label Dec 27, 2024
@dotnet-policy-service dotnet-policy-service bot added the untriaged New issue has not been triaged by the area owner label Dec 27, 2024
Copy link
Contributor

Tagging subscribers to this area: @dotnet/area-system-io
See info in area-owners.md if you want to be subscribed.

@tradem tradem changed the title [API Proposal]: Microsoft.Extensions.FileProviders.Physical.PhysicalFilesWatcher should expose modfied files identifes (Alternative where standalone FilesystemWatcher won't work) [API Proposal]: Microsoft.Extensions.FileProviders.Physical.PhysicalFilesWatcher should expose modified files identifes (Alternative where standalone FilesystemWatcher won't work) Dec 27, 2024
@tradem tradem changed the title [API Proposal]: Microsoft.Extensions.FileProviders.Physical.PhysicalFilesWatcher should expose modified files identifes (Alternative where standalone FilesystemWatcher won't work) [API Proposal]: Microsoft.Extensions.FileProviders.Physical.PhysicalFilesWatcher should expose modified files (Alternative where standalone FilesystemWatcher won't work) Dec 27, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api-suggestion Early API idea and discussion, it is NOT ready for implementation area-System.IO untriaged New issue has not been triaged by the area owner
Projects
None yet
Development

No branches or pull requests

1 participant