SharpGrip.FileSystem
                             
                            
                                1.0.0-beta1
                            
                        
                            
                                
                                
                                    Prefix Reserved
                                
                            
                    See the version list below for details.
dotnet add package SharpGrip.FileSystem --version 1.0.0-beta1
NuGet\Install-Package SharpGrip.FileSystem -Version 1.0.0-beta1
<PackageReference Include="SharpGrip.FileSystem" Version="1.0.0-beta1" />
<PackageVersion Include="SharpGrip.FileSystem" Version="1.0.0-beta1" />
<PackageReference Include="SharpGrip.FileSystem" />
paket add SharpGrip.FileSystem --version 1.0.0-beta1
#r "nuget: SharpGrip.FileSystem, 1.0.0-beta1"
#:package SharpGrip.FileSystem@1.0.0-beta1
#addin nuget:?package=SharpGrip.FileSystem&version=1.0.0-beta1&prerelease
#tool nuget:?package=SharpGrip.FileSystem&version=1.0.0-beta1&prerelease
SharpGrip FileSystem 
Builds
Introduction
SharpGrip FileSystem is a file system abstraction supporting multiple adapters.
Installation
Reference NuGet package SharpGrip.FileSystem (https://www.nuget.org/packages/SharpGrip.FileSystem).
For adapters other than the local file system (included in the SharpGrip.FileSystem package) please see the Supported adapters section.
Supported adapters
| Adapter | Package | NuGet | 
|---|---|---|
| Local adapter | SharpGrip.FileSystem | |
| AmazonS3 | SharpGrip.FileSystem.Adapters.AmazonS3 | |
| AzureBlobStorage | SharpGrip.FileSystem.Adapters.AzureBlobStorage | |
| AzureFileStorage | SharpGrip.FileSystem.Adapters.AzureFileStorage | |
| Dropbox | SharpGrip.FileSystem.Adapters.Dropbox | |
| MicrosoftOneDrive | SharpGrip.FileSystem.Adapters.MicrosoftOneDrive | |
| SFTP | SharpGrip.FileSystem.Adapters.Sftp | 
Supported operations
For a full list of the supported operations please see the IFileSystem interface.
Usage
Instantiation
var adapters = new List<IAdapter>
{
    new LocalAdapter("adapterPrefix", "adapterRootPath")
};
// Instantiation option 1.
var fileSystem = new FileSystem(adapters);
// Instantiation option 2.
var fileSystem = new FileSystem();
fileSystem.Adapters = adapters;
Local adapter
var adapters = new List<IAdapter>
{
    new LocalAdapter("local1", "/var/files"),
    new LocalAdapter("local2", "D:\\Files")
};
var fileSystem = new FileSystem(adapters);
AmazonS3 adapter
// Amazon connection.
var amazonClient = new AmazonS3Client("awsAccessKeyId", "awsSecretAccessKey", RegionEndpoint.USEast2);
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new AmazonS3Adapter("amazon", "/Files", amazonClient, "bucketName")
};
var fileSystem = new FileSystem(adapters);
AzureBlobStorage adapter
// Azure connection.
var blobServiceClient = new BlobServiceClient("connectionString");
var azureClient = blobServiceClient.GetBlobContainerClient("blobContainerName");
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new AzureBlobStorageAdapter("azure", "/Files", azureClient)
};
var fileSystem = new FileSystem(adapters);
AzureFileStorage adapter
// Azure connection.
var azureClient = new ShareClient("connectionString", "shareName");
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new AzureFileStorageAdapter("azure", "/Files", azureClient)
};
var fileSystem = new FileSystem(adapters);
Dropbox adapter
// Dropbox connection.
var dropboxClient = new DropboxClient("oAuth2AccessToken");
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new DropboxAdapter("dropbox", "/Files", dropboxClient)
};
var fileSystem = new FileSystem(adapters);
MicrosoftOneDrive adapter
// Microsoft connection.
var scopes = new[] {"https://graph.microsoft.com/.default"};
var tenantId = "tenantId";
var confidentialClient = ConfidentialClientApplicationBuilder
    .Create("clientId")
    .WithAuthority($"https://login.microsoftonline.com/{tenantId}/v2.0")
    .WithClientSecret("clientSecret")
    .Build();
var oneDriveClient = new GraphServiceClient(new DelegateAuthenticationProvider(async requestMessage =>
    {
        var authResult = await confidentialClient.AcquireTokenForClient(scopes).ExecuteAsync();
        requestMessage.Headers.Authorization = new AuthenticationHeaderValue("Bearer", authResult.AccessToken);
    })
);
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new MicrosoftOneDriveAdapter("onedrive", "/Files", oneDriveClient, "driveId")
};
var fileSystem = new FileSystem(adapters);
SFTP adapter
// SFTP connection.
var privateKeyFile = new PrivateKeyFile("/home/userName/.ssh/id_rsa");
var privateKeyAuthenticationMethod = new PrivateKeyAuthenticationMethod("userName", privateKeyFile);
var sftpConnectionInfo = new ConnectionInfo("hostName", "userName", privateKeyAuthenticationMethod);
var sftpClient = new SftpClient(sftpConnectionInfo);
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new SftpAdapter("sftp", "/var/files", sftpClient)
};
var fileSystem = new FileSystem(adapters);
Example operations
// Azure connection.
var azureClient = new ShareClient("connectionString", "shareName");
// Dropbox connection.
var dropboxClient = new DropboxClient("oAuth2AccessToken");
var adapters = new List<IAdapter>
{
    new LocalAdapter("local", "/var/files"),
    new AzureFileStorageAdapter("azure", "/Files", azureClient),
    new DropboxAdapter("dropbox", "/Files", dropboxClient)
};
// Copies a file from the `local` adapter to the `azure` adapter.
await fileSystem.CopyFileAsync("local://foo/bar.txt", "azure://bar/foo.txt");
// Moves a file from the `azure` adapter to the `dropbox` adapter.
await fileSystem.MoveFileAsync("azure://Foo/Bar.txt", "dropbox://Bar/Foo.txt");
// Writes string contents to the `azure` adapter.
await fileSystem.WriteFileAsync("azure://Foo.txt", "Bar!");
// Reads a text file from the `dropbox` adapter.
var contents = fileSystem.ReadTextFileAsync("dropbox://Foo.txt");
| Product | Versions Compatible and additional computed target framework versions. | 
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. | 
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. | 
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. | 
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. | 
| MonoAndroid | monoandroid was computed. | 
| MonoMac | monomac was computed. | 
| MonoTouch | monotouch was computed. | 
| Tizen | tizen40 was computed. tizen60 was computed. | 
| Xamarin.iOS | xamarinios was computed. | 
| Xamarin.Mac | xamarinmac was computed. | 
| Xamarin.TVOS | xamarintvos was computed. | 
| Xamarin.WatchOS | xamarinwatchos was computed. | 
- 
                                                    .NETStandard 2.0- No dependencies.
 
- 
                                                    .NETStandard 2.1- No dependencies.
 
NuGet packages (9)
Showing the top 5 NuGet packages that depend on SharpGrip.FileSystem:
| Package | Downloads | 
|---|---|
| SharpGrip.FileSystem.Adapters.AzureBlobStorage The SharpGrip FileSystem AzureBlobStorage adapter. | |
| SharpGrip.FileSystem.Adapters.AzureFileStorage The SharpGrip FileSystem AzureFileStorage adapter. | |
| SharpGrip.FileSystem.Adapters.AmazonS3 The SharpGrip FileSystem AmazonS3 adapter. | |
| SharpGrip.FileSystem.Adapters.Sftp The SharpGrip FileSystem SFTP adapter. | |
| SharpGrip.FileSystem.Adapters.Dropbox The SharpGrip FileSystem Dropbox adapter. | 
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated | 
|---|---|---|
| 1.2.1 | 4,985 | 8/31/2024 | 
| 1.2.0 | 2,214 | 5/23/2024 | 
| 1.1.0 | 3,503 | 12/31/2023 | 
| 1.0.0 | 4,104 | 8/5/2023 | 
| 1.0.0-beta3 | 653 | 7/25/2023 | 
| 1.0.0-beta2 | 732 | 5/9/2023 | 
| 1.0.0-beta1 | 34,074 | 5/14/2022 | 
| 1.0.0-alpha6 | 14,780 | 7/7/2020 | 
| 1.0.0-alpha5 | 6,740 | 5/28/2020 | 
| 1.0.0-alpha4 | 8,879 | 4/21/2020 | 
| 1.0.0-alpha3 | 1,465 | 3/10/2020 | 
| 1.0.0-alpha2 | 1,229 | 2/15/2020 | 
| 1.0.0-alpha1 | 1,185 | 12/27/2019 |