Getting Started with Hubtel AWS S3 SDK
This SDK helps you to interact with AWS S3. Helpful methods include:
- Upload file to aws s3
- Delete file from aws s3
- Get metadata about a file
- Get file from aws s3
- Get profile image
- Check if object exists
In order to get started with Hubtel.AwsS3.Sdk, do the following activities
Install-Package Hubtel.AwsS3.Sdk
The provided code snippet is a command that is used to install Hubtel.AwsS3.Sdk
package in a .NET project.
Install-Package Hubtel.AwsS3.Sdk
Add to appsettings.json
The S3ServiceConfig
object contains several properties that are used to configure the Amazon S3 integration:
AccessKey
: This is the access key used for authentication with Amazon S3. You would replace_sample_key_here
with your actual access key.Secret
: This is the secret key used for authentication with Amazon S3. You would replace_secret_key_here
with your actual secret key.Url
: This is the URL of the Amazon S3 endpoint. In this case, it's set tohttps://s3.eu-west-1.amazonaws.com
, which is the endpoint for the EU (Ireland) region.BaseUrl
: This is the base URL of the CloudFront distribution associated with the S3 bucket. You would replace_cloudfront_base_url
with your actual CloudFront base URL.BucketName
: This is the name of the S3 bucket where files will be stored. You would replace_bucket_name
with your actual bucket name.FolderName
: This is the name of the folder within the S3 bucket where files will be stored. You would replace_folder_name
with your actual folder name.HasResizeFolders
: This is a boolean value that indicates whether images will be resized before upload. If you will be resizing your images, set this totrue
; otherwise, set it tofalse
.ImageSizes
: This is an array of strings that specify the sizes to which images will be resized. Each string should be in the format "widthxheight". This property can be omitted ifHasResizeFolders
isfalse
.
These values are typically sensitive and should not be hard-coded into your application's source code. Instead, they should be stored securely and retrieved from the configuration at runtime.
"S3ServiceConfig": {
"AccessKey": "_sample_key_here",
"Secret": "_secret_key_here",
"Url": "https://s3.eu-west-1.amazonaws.com",
"BaseUrl": "_cloudfront_base_url",
"BucketName": "_bucket_name",
"FolderName": "_folder_name",
"HasResizeFolders": false, // Set to true if you will be resizing your images before upload
"ImageSizes": ["300x300", "1024x1024"] // Can be ommited when there is no resizing
}
Add to IServiceCollection in Startup.cs
The
AddHubtelAwsS3Sdk
method takes a lambda expression as an argument, which is used to configure the options for theHubtelAwsS3Sdk
service. Theconfig
parameter in the lambda expression is an object that has properties corresponding to the configuration options for the service.Before this, the
S3ServiceConfig
section of the application's configuration is retrieved and bound to an instance of theS3ServiceConfig
class. This is done using theConfiguration.GetSection("S3ServiceConfig").Get<S3ServiceConfig>()
line. TheS3ServiceConfig
object contains the configuration options for the HubtelAwsS3Sdk service.Each property of the
config
object is then set to a corresponding property from thes3ServiceConfig
object as indicated by the code snippet below.
var s3ServiceConfig = Configuration.GetSection("S3ServiceConfig").Get<S3ServiceConfig>();
services.AddHubtelAwsS3Sdk(config =>
{
config.AccessKey = s3ServiceConfig.AccessKey;
config.Secret = s3ServiceConfig.Secret;
config.Url = s3ServiceConfig.Url;
config.BaseUrl = s3ServiceConfig.BaseUrl;
config.BucketName = s3ServiceConfig.BucketName;
config.FolderName = s3ServiceConfig.FolderName;
config.HasResizeFolders = s3ServiceConfig.HasResizeFolders;
config.ImageSizes = s3ServiceConfig.ImageSizes;
});
Inject and consume service methods
private readonly IS3Api _s3Api;
# Upload file to AWS S3
var response = await _s3Api.UploadFormBase64Async(base64String, folderName, filename);
NB: filename can be ommitted if you need an autogenerated filename
# Delete file from AWS S3
var response = await _s3Api.DeleteObject(folderName, fileName);
# Get metadata about a file
var response = await _s3Api.GetFileObjectMetadata(fileName, folderName);
# Get file from AWS S3
var response = await _s3Api.GetFileObject(fileName, folderName);
# Get profile image
var response = await _s3Api.GetProfileImageAsync(imageUrl, folderName);
# Check if object exists
var response = await _s3Api.ObjectExists(folderName, fileName);
Was this helpful? 📚
CHAT SAMMIAT