123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using Utilities;
- namespace SMBLibrary.Server
- {
- public class FileSystemShare : ISMBShare
- {
- private string m_name;
- private INTFileStore m_fileSystem;
- private CachingPolicy m_cachingPolicy;
- public event EventHandler<AccessRequestArgs> AccessRequested;
- public FileSystemShare(string shareName, INTFileStore fileSystem) : this(shareName, fileSystem, CachingPolicy.ManualCaching)
- {
- }
- public FileSystemShare(string shareName, INTFileStore fileSystem, CachingPolicy cachingPolicy)
- {
- m_name = shareName;
- m_fileSystem = fileSystem;
- m_cachingPolicy = cachingPolicy;
- }
- public FileSystemShare(string shareName, IFileSystem fileSystem, CachingPolicy cachingPolicy)
- {
- m_name = shareName;
- m_fileSystem = new NTFileSystemAdapter(fileSystem);
- m_cachingPolicy = cachingPolicy;
- }
- public bool HasReadAccess(SecurityContext securityContext, string path)
- {
- return HasAccess(securityContext, path, FileAccess.Read);
- }
- public bool HasWriteAccess(SecurityContext securityContext, string path)
- {
- return HasAccess(securityContext, path, FileAccess.Write);
- }
- public bool HasAccess(SecurityContext securityContext, string path, FileAccess requestedAccess)
- {
-
- EventHandler<AccessRequestArgs> handler = AccessRequested;
- if (handler != null)
- {
- AccessRequestArgs args = new AccessRequestArgs(securityContext.UserName, path, requestedAccess, securityContext.MachineName, securityContext.ClientEndPoint);
- handler(this, args);
- return args.Allow;
- }
- return true;
- }
- public string Name
- {
- get
- {
- return m_name;
- }
- }
- public INTFileStore FileStore
- {
- get
- {
- return m_fileSystem;
- }
- }
- public CachingPolicy CachingPolicy
- {
- get
- {
- return m_cachingPolicy;
- }
- }
- }
- }
|