FileHub.Ftp
1.0.0
dotnet add package FileHub.Ftp --version 1.0.0
NuGet\Install-Package FileHub.Ftp -Version 1.0.0
<PackageReference Include="FileHub.Ftp" Version="1.0.0" />
<PackageVersion Include="FileHub.Ftp" Version="1.0.0" />
<PackageReference Include="FileHub.Ftp" />
paket add FileHub.Ftp --version 1.0.0
#r "nuget: FileHub.Ftp, 1.0.0"
#:package FileHub.Ftp@1.0.0
#addin nuget:?package=FileHub.Ftp&version=1.0.0
#tool nuget:?package=FileHub.Ftp&version=1.0.0
FileHub
A .NET storage abstraction. One API (IFileHub → FileDirectory → FileEntry) across local disk, in-memory, and cloud object storage — swap the driver, keep the code.
using FileHub.Local;
var hub = new LocalFileHub(@"C:\data"); // or: new MemoryFileHub();
var file = hub.Root.CreateFile("hello.txt"); // anywhere under the sandbox root
file.SetText("hi");
Console.WriteLine(file.ReadAllText());
Why
Most .NET apps end up with System.IO.File scattered across services, or coupled to a cloud SDK whose types leak into every layer. When the storage backend has to change — "move uploads to S3", "keep tests off the disk", "sandbox per-tenant data" — the refactor hurts because the boundary was never drawn.
FileHub draws it once. A service like ReportService(IFileHub hub) is written once, unit-tested against memory, run locally against disk, and deployed to the cloud against an object store — without a single line changing in the service.
What's in the box
- Drivers:
FileHub.Local(disk),FileHub.Memory(in-process),FileHub.OracleObjectStorage(OCI),FileHub.Ftp(FTP server). Custom drivers implement two abstract classes. - Sync + async on the same types. Async is the source of truth; sync delegates.
- Sandboxed by default — every hub has a root.
.., absolute paths, and symlink escapes are rejected. - Read-only on demand —
dir.AsReadOnly()/file.AsReadOnly()wraps anything and blocks writes at runtime. - DI integration —
FileHub.DependencyInjectionshipsAddFileHub/AddNamedFileHubswith lifetime +IServiceProvidersupport for tenant scoping. - Nested paths —
CreateDirectory("a/b/c")andTryOpenDirectory("a/b/c", out _)work on every driver.DirectoryPathMode.Direct(default on cloud drivers) collapses it to a single API call. - Zero external deps in core. Multi-targets
netstandard2.0;net8.0.
Install
dotnet add package FileHub
dotnet add package FileHub.DependencyInjection # optional
dotnet add package FileHub.OracleObjectStorage # optional
dotnet add package FileHub.Ftp # optional
Named hubs (tenant, multi-backend)
services.AddNamedFileHubs(b => b
.Register("reports", new MemoryFileHub())
.Register(
"tenant",
sp => new LocalFileHub($@"C:\tenants\{sp.GetRequiredService<ITenantContext>().Id}"),
ServiceLifetime.Scoped));
Inject INamedFileHubs and call GetByName("tenant").
Documentation
Full docs live in the wiki:
- Quick Start — install, hubs, files, directories
- API reference —
IFileHub,FileDirectory,FileEntry, exceptions - Drivers — Local, Memory, OCI, FTP
- Usage patterns — sync/async, streams, pagination
- Security — sandbox and read-only mode
- Dependency injection · Custom drivers · Testing
License
MIT — see LICENSE.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 is compatible. 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 was computed. |
| .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. |
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0 | 153 | 4/25/2026 |