123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- using System;
- using System.Collections.Generic;
- using System.IO;
- using Utilities;
- namespace SMBLibrary
- {
- public partial class NTFileStoreHelper
- {
- public static FileAccess ToCreateFileAccess(AccessMask desiredAccess, CreateDisposition createDisposition)
- {
- FileAccess result = 0;
- if (((FileAccessMask)desiredAccess & FileAccessMask.FILE_READ_DATA) > 0 ||
- ((FileAccessMask)desiredAccess & FileAccessMask.FILE_READ_EA) > 0 ||
- ((FileAccessMask)desiredAccess & FileAccessMask.FILE_READ_ATTRIBUTES) > 0 ||
- (desiredAccess & AccessMask.MAXIMUM_ALLOWED) > 0 ||
- (desiredAccess & AccessMask.GENERIC_ALL) > 0 ||
- (desiredAccess & AccessMask.GENERIC_READ) > 0)
- {
- result |= FileAccess.Read;
- }
- if (((FileAccessMask)desiredAccess & FileAccessMask.FILE_WRITE_DATA) > 0 ||
- ((FileAccessMask)desiredAccess & FileAccessMask.FILE_APPEND_DATA) > 0 ||
- ((FileAccessMask)desiredAccess & FileAccessMask.FILE_WRITE_EA) > 0 ||
- ((FileAccessMask)desiredAccess & FileAccessMask.FILE_WRITE_ATTRIBUTES) > 0 ||
- (desiredAccess & AccessMask.DELETE) > 0 ||
- (desiredAccess & AccessMask.WRITE_DAC) > 0 ||
- (desiredAccess & AccessMask.WRITE_OWNER) > 0 ||
- (desiredAccess & AccessMask.MAXIMUM_ALLOWED) > 0 ||
- (desiredAccess & AccessMask.GENERIC_ALL) > 0 ||
- (desiredAccess & AccessMask.GENERIC_WRITE) > 0)
- {
- result |= FileAccess.Write;
- }
- if (((DirectoryAccessMask)desiredAccess & DirectoryAccessMask.FILE_DELETE_CHILD) > 0)
- {
- result |= FileAccess.Write;
- }
-
-
-
-
- if (createDisposition == CreateDisposition.FILE_CREATE ||
- createDisposition == CreateDisposition.FILE_SUPERSEDE ||
- createDisposition == CreateDisposition.FILE_OPEN_IF ||
- createDisposition == CreateDisposition.FILE_OVERWRITE ||
- createDisposition == CreateDisposition.FILE_OVERWRITE_IF)
- {
- result |= FileAccess.Write;
- }
- return result;
- }
-
-
-
- public static FileAccess ToFileAccess(AccessMask desiredAccess)
- {
- return ToFileAccess((FileAccessMask)desiredAccess);
- }
-
-
-
- public static FileAccess ToFileAccess(FileAccessMask desiredAccess)
- {
- FileAccess result = 0;
- if ((desiredAccess & FileAccessMask.FILE_READ_DATA) > 0 ||
- (desiredAccess & FileAccessMask.MAXIMUM_ALLOWED) > 0 ||
- (desiredAccess & FileAccessMask.GENERIC_ALL) > 0 ||
- (desiredAccess & FileAccessMask.GENERIC_READ) > 0)
- {
- result |= FileAccess.Read;
- }
- if ((desiredAccess & FileAccessMask.FILE_WRITE_DATA) > 0 ||
- (desiredAccess & FileAccessMask.FILE_APPEND_DATA) > 0 ||
- (desiredAccess & FileAccessMask.MAXIMUM_ALLOWED) > 0 ||
- (desiredAccess & FileAccessMask.GENERIC_ALL) > 0 ||
- (desiredAccess & FileAccessMask.GENERIC_WRITE) > 0)
- {
- result |= FileAccess.Write;
- }
- return result;
- }
- public static FileShare ToFileShare(ShareAccess shareAccess)
- {
- FileShare result = FileShare.None;
- if ((shareAccess & ShareAccess.Read) > 0)
- {
- result |= FileShare.Read;
- }
- if ((shareAccess & ShareAccess.Write) > 0)
- {
- result |= FileShare.Write;
- }
- if ((shareAccess & ShareAccess.Delete) > 0)
- {
- result |= FileShare.Delete;
- }
- return result;
- }
- public static FileNetworkOpenInformation GetNetworkOpenInformation(INTFileStore fileStore, string path, SecurityContext securityContext)
- {
- object handle;
- FileStatus fileStatus;
- NTStatus openStatus = fileStore.CreateFile(out handle, out fileStatus, path, (AccessMask)FileAccessMask.FILE_READ_ATTRIBUTES, 0, ShareAccess.Read | ShareAccess.Write, CreateDisposition.FILE_OPEN, 0, securityContext);
- if (openStatus != NTStatus.STATUS_SUCCESS)
- {
- return null;
- }
- FileInformation fileInfo;
- NTStatus queryStatus = fileStore.GetFileInformation(out fileInfo, handle, FileInformationClass.FileNetworkOpenInformation);
- fileStore.CloseFile(handle);
- if (queryStatus != NTStatus.STATUS_SUCCESS)
- {
- return null;
- }
- return (FileNetworkOpenInformation)fileInfo;
- }
- public static FileNetworkOpenInformation GetNetworkOpenInformation(INTFileStore fileStore, object handle)
- {
- FileInformation fileInfo;
- NTStatus status = fileStore.GetFileInformation(out fileInfo, handle, FileInformationClass.FileNetworkOpenInformation);
- if (status != NTStatus.STATUS_SUCCESS)
- {
- return null;
- }
- return (FileNetworkOpenInformation)fileInfo;
- }
- }
- }
|