tusdotnet.Stores.S3
1.0.2
dotnet add package tusdotnet.Stores.S3 --version 1.0.2
NuGet\Install-Package tusdotnet.Stores.S3 -Version 1.0.2
<PackageReference Include="tusdotnet.Stores.S3" Version="1.0.2" />
paket add tusdotnet.Stores.S3 --version 1.0.2
#r "nuget: tusdotnet.Stores.S3, 1.0.2"
// Install tusdotnet.Stores.S3 as a Cake Addin #addin nuget:?package=tusdotnet.Stores.S3&version=1.0.2 // Install tusdotnet.Stores.S3 as a Cake Tool #tool nuget:?package=tusdotnet.Stores.S3&version=1.0.2
tusdotnet.Stores.S3
The Package tusdotnet.Stores.S3 implements all necessary interfaces to use S3 as a file storage backend. The Implementation is put into the TusS3Store class
What is tus?
Tus is a web based protocol for resumable uploads. Implementations and client libraries exist for many platforms.
What is tusdotnet?
tusdotnet is a popular implementation of the tus protocol for .net.
Why do I need tusdotnet.Stores.S3?
Tusdotnet only comes with a disk storage implementation. This extension allows you to use s3 blobstorage instead of local (or network attached) disk.
Implemented Extensions
The tus protocol offers a few extensions. The following extensions are implemented:
- Termination - Allows for deletion of completed and incomplete uploads.
- Expiration - Server will consider uploads past a certain time expired and ready for deletion.
- Pipelines - more efficient than handling plain streams
Configuration
In order to allow this backend to function properly, the user accessing the bucket must have at least following AWS IAM policy permissions for the bucket and all of its subresources:
s3:AbortMultipartUpload
s3:DeleteObject
s3:GetObject
s3:ListMultipartUploadParts
s3:PutObject
While this package uses the official AWS SDK for Go, S3Store is able
to work with any S3-compatible service such as MinIO. In order to change
the HTTP endpoint used for sending requests to, adjust the BaseEndpoint
option in the AWSSDK.S3 nuget package (https://aws.amazon.com/sdk-for-net/).
Implementation
Once a new tus upload is initiated, multiple objects in S3 are created:
First of all, a new info object is stored which contains a JSON-encoded blob of general information about the upload including its size and meta data. This kind of objects have the suffix ".info" in their key.
In addition a new multipart upload (http://docs.aws.amazon.com/AmazonS3/latest/dev/uploadobjusingmpu.html) is created. Whenever a new chunk is uploaded to tus using a PATCH request, a new part is pushed to the multipart upload on S3.
If meta data is associated with the upload during creation, it will be added to the multipart upload and after finishing it, the meta data will be passed to the final object.
Once the upload is finished, the multipart upload is completed, resulting in the entire file being stored in the bucket. The info object, containing meta data is not deleted. It is recommended to copy the finished upload to another bucket to avoid it being deleted by the Termination extension.
If an upload is about to being terminated, the multipart upload is aborted which removes all of the uploaded parts from the bucket. In addition, the info object is also deleted. If the upload has been finished already, the finished object containing the entire upload is also removed.
Considerations
In order to support tus' principle of resumable upload, S3's Multipart-Uploads are internally used.
In addition, it must be mentioned that AWS S3 only offers eventual consistency (https://docs.aws.amazon.com/AmazonS3/latest/dev/Introduction.html#ConsistencyModel). Therefore, it is required to build additional measurements in order to prevent concurrent access to the same upload resources which may result in data corruption.
Usage
ILogger<TusS3Store> logger;
var tusS3StoreConfig = new TusS3StoreConfiguration()
{
BucketName = options.Value.BucketName
};
var awsCredentials = new BasicAWSCredentials("myaccessKey", "mysecretkey");
AmazonS3Config s3Config = new AmazonS3Config
{
// MUST set this before setting ServiceURL and it should match the `MINIO_REGION` environment variable
AuthenticationRegion = "us-east-1",
// MUST be true to work correctly with MinIO server
ServiceURL = "https://mys3endpoint.com",
ForcePathStyle = true,
};
var tusStore = new TusS3Store(logger, tusS3StoreConfig, awsCredentials, s3Config);
var tusConfig = new DefaultTusConfiguration
{
Store = CreateTusS3Store(services),
MetadataParsingStrategy = MetadataParsingStrategy.AllowEmptyValues,
UsePipelinesIfAvailable = true,
// Set an expiration time, where incomplete files can no longer be updated.
// This value can either be absolute or sliding.
// Absolute expiration will be saved per file on create
// Sliding expiration will be saved per file on create and updated on each patch/update.
Expiration = new SlidingExpiration(TimeSpan.FromMinutes(1))
};
Special Thanks
- Bechtle A/V Software Solutions 360° for sponsoring the project
- Xtensible.TusDotNet.Azure for a boilerplate to create this extension
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. 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. |
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Release notes at https://github.com/bechtleav360/tusdotnet.Storage.S3/releases