FileHub 1.0.0
dotnet add package FileHub --version 1.0.0
NuGet\Install-Package FileHub -Version 1.0.0
<PackageReference Include="FileHub" Version="1.0.0" />
<PackageVersion Include="FileHub" Version="1.0.0" />
<PackageReference Include="FileHub" />
paket add FileHub --version 1.0.0
#r "nuget: FileHub, 1.0.0"
#:package FileHub@1.0.0
#addin nuget:?package=FileHub&version=1.0.0
#tool nuget:?package=FileHub&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. |
-
.NETStandard 2.0
- No dependencies.
-
net8.0
- No dependencies.
NuGet packages (4)
Showing the top 4 NuGet packages that depend on FileHub:
| Package | Downloads |
|---|---|
|
FileHub.Ftp
FTP driver for FileHub (built on FluentFTP) — exposes any FTP / FTPS server as an IFileHub with the same API as the Local and Memory drivers. Supports atomic rename inside the same connection, lazy connect with idle-timeout reconnect, and stream-based read/write. |
|
|
FileHub.AmazonS3
Amazon S3 driver for FileHub — exposes any S3 bucket as an IFileHub with the same API as the Local and Memory drivers. Supports server-side copy/move, multipart uploads, presigned URLs, and cross-region operations. |
|
|
FileHub.OracleObjectStorage
Oracle Cloud Object Storage driver for FileHub — exposes any OCI Object Storage bucket as an IFileHub with the same API as the Local and Memory drivers. Supports server-side rename/copy, pre-authenticated read URLs, and cross-region copy. |
|
|
FileHub.DependencyInjection
Microsoft.Extensions.DependencyInjection integration for FileHub — register named hubs (IFileHub) on IServiceCollection and resolve them by name at runtime, with sane defaults for service lifetimes. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0 | 296 | 4/25/2026 |