SledGX.Tools.AWS 1.3.0

dotnet add package SledGX.Tools.AWS --version 1.3.0                
NuGet\Install-Package SledGX.Tools.AWS -Version 1.3.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="SledGX.Tools.AWS" Version="1.3.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add SledGX.Tools.AWS --version 1.3.0                
#r "nuget: SledGX.Tools.AWS, 1.3.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install SledGX.Tools.AWS as a Cake Addin
#addin nuget:?package=SledGX.Tools.AWS&version=1.3.0

// Install SledGX.Tools.AWS as a Cake Tool
#tool nuget:?package=SledGX.Tools.AWS&version=1.3.0                

SledGX AWS Tools

AWS Services Wrapper for .NET

  • Notification: implementation of the Amazon Simple Notification Service (SNS) API.
  • Queue Polling: implementation of the message listing service from the Amazon Simple Queue Service (SQS).
  • Queue: implementation of the Amazon Simple Queue Service (SQS) API.
  • Storage: implementation of the Amazon Simple Storage Service (S3) API.
  • Streamer: implementation of the Amazon Kinesis Data Firehose API.
  • Function: implementation of the Amazon Lambda API.

How to use

Eeach service requires an AWS account to authenticate, so first you need to instantiate the AwsCredentials object to define the account details.

Example.

var credetials = new AwsCredentials("<your access key id>", "<your secret access key>");

Notification Service

To initialize this service it's necessary to use the NotificationService object by passing in the AWS credentials, the region where the service was created and the ARN of the SNS topic.

Example.

var setting = new NotificationSetting(credetials, "<region>", "<topic arn>");
var service = new NotificationService(setting);

Below is a list of the available methods:

Method Description
PushMessage Sends a text message to an Amazon SNS topic.
PushObject<T> Sends an object to an Amazon SNS topic. The object is automatically transformed into json.
PushMessages Sends multiple text messages to an Amazon SNS topic.
PushObjects<T> Sends multiple objects to an Amazon SNS topic. Objects are automatically transformed into json.

Queue Polling Service

To initialize this service it's necessary to use the QueuePollingService<T> object by passing in the AWS credentials, the region where the service was created and the url of the SQS queue. There are further settings that can be optionally defined:

Setting Description
Sleep Duration of the pause in milliseconds between message retrievals.
IdleSleep Duration of the long pause in milliseconds between message retrievals.
IdleAfter Slows down the listing after the number of empty messages.
KillAfter Stops the listing after the number of failed processes.
AutoStop Stops the listing after IdleAfter empty messages.

Example.

var setting = new QueuePollingSetting(credetials, "<region>", "<queue url>")
{
    Sleep = 5000
};
var service = new QueuePollingService<Data>(setting);
service.OnMessageReceived += Queue_OnMessageReceived;

// ...

void Queue_OnMessageReceived(Data? data)
{
    // ...
}

Below is a list of the available methods:

Method Description
Start Starts listening to the Amazon SQS queue.
StartAndWait Starts listening to the Amazon SQS queue and waits.
Stop Stops listening to the Amazon SQS queue.
OnMessageReceived<T> Action to take when receiving a message from the Amazon SQS queue.
OnError Action to take when an error is received while processing the message from the Amazon SQS queue.

Queue Service

To initialize this service it's necessary to use the QueueService object by passing in the AWS credentials, the region where the service was created and the url of the SQS queue.

Example.

var setting = new QueueSetting(credetials, "<region>", "<queue url>");
var service = new QueueService(setting);

Below is a list of the available methods:

Method Description
CountMessages Counts the number of messages on an Amazon SQS queue.
PushMessage Sends a text message to an Amazon SQS queue.
PushObject<T> Sends an object to an Amazon SQS queue. The object is automatically transformed into json.
PushMessages Sends multiple text messages to an Amazon SQS queue.
PushObjects<T> Sends multiple objects to an Amazon SQS queue. Objects are automatically transformed into json.
ReceiveMessage Receives a message from the Amazon SQS queue.
DeleteMessage Deletes a message from the Amazon SQS queue.

Storage Service

To initialize this service it's necessary to use the StorageService object by passing in the AWS credentials, the region where the service was created and the name of the S3 bucket.

Example.

var setting = new StorageSetting(credetials, "<region>", "<bucket name>");
var service = new StorageService(setting);

Below is a list of the available methods:

Method Description
ObjectExists Checks if an object is present inside the Amazon S3 bucket.
GetObjectList Retrieve the list of objects inside the Amazon S3 bucket.
UploadText Writes a text into an Amazon S3 bucket.
UploadObject<T> Writes an object into an Amazon S3 bucket. The object is automatically transformed into json.
UploadFile Writes a file to an Amazon S3 bucket.
GetText Retrieves a text from Amazon S3 bucket.
GetObject<T> Retrieves an object from Amazon S3 bucket.
DownloadFile Downloads the file from Amazon S3 bucket.
DeleteObject Deletes an object from the Amazon S3 bucket.

Streamer Service

To initialize this service it's necessary to use the StreamerService object by passing in the AWS credentials, the region where the service was created and the name of Kinesis delivery stream.

Example.

var setting = new StreamerSetting(credetials, "<region>", "<stream name>");
var service = new StreamerService(setting);

Below is a list of the available methods:

Method Description
PutRecord<T> Writes a single data record into an Amazon Kinesis Data Firehose delivery stream.
PutRecords<T> Writes multiple data records into an Amazon Kinesis Data Firehose delivery stream.

Function Service

To initialize this service it's necessary to use the FunctionService object by passing in the AWS credentials, the region where the service was created and the name of Lambda function.

Example.

var setting = new FunctionService(credetials, "<region>", "<function name>");
var service = new FunctionService(setting);

Below is a list of the available methods:

Method Description
Invoke<T> Invoke a Lambda function.
InvokeWithResponse<TInput, TOutput> Invoke a Lambda function and wait for a response.

License

Released under the MIT License.

SledGX

Product 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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.3.0 354 12/24/2022
1.2.0 343 11/23/2022
1.1.0 339 11/2/2022
1.0.0 417 10/19/2022