Amazon.Lambda.Annotations
0.4.3-preview
Prefix Reserved
See the version list below for details.
dotnet add package Amazon.Lambda.Annotations --version 0.4.3-preview
NuGet\Install-Package Amazon.Lambda.Annotations -Version 0.4.3-preview
<PackageReference Include="Amazon.Lambda.Annotations" Version="0.4.3-preview" />
paket add Amazon.Lambda.Annotations --version 0.4.3-preview
#r "nuget: Amazon.Lambda.Annotations, 0.4.3-preview"
// Install Amazon.Lambda.Annotations as a Cake Addin #addin nuget:?package=Amazon.Lambda.Annotations&version=0.4.3-preview&prerelease // Install Amazon.Lambda.Annotations as a Cake Tool #tool nuget:?package=Amazon.Lambda.Annotations&version=0.4.3-preview&prerelease
Amazon.Lambda.Annotations
The Lambda Annotations is a programming model for writing .NET Lambda function. At a high level the programming model allows idiomatic .NET coding patterns and uses C# Source Generators to bridge the gap between the Lambda programming model to the more idiomatic programming model.
For example here is a simplistic example of a .NET Lambda function that acts like a calculator plus method using the normal Lambda programming model. It respondes to an API Gateway REST API, pulls the operands from the resource paths, does the addition and returns back an API Gateway response.
public class Functions
{
public APIGatewayProxyResponse LambdaMathPlus(APIGatewayProxyRequest request, ILambdaContext context)
{
if (!request.PathParameters.TryGetValue("x", out var xs))
{
return new APIGatewayProxyResponse
{
StatusCode = (int)HttpStatusCode.BadRequest
};
}
if (!request.PathParameters.TryGetValue("y", out var ys))
{
return new APIGatewayProxyResponse
{
StatusCode = (int)HttpStatusCode.BadRequest
};
}
var x = int.Parse(xs);
var y = int.Parse(ys);
return new APIGatewayProxyResponse
{
StatusCode = (int)HttpStatusCode.OK,
Body = (x + y).ToString(),
Headers = new Dictionary<string, string> { { "Content-Type", "text/plain" } }
};
}
}
Using Amazon.Lambda.Annotations the same Lambda function can be written like this.
public class Functions
{
[LambdaFunction]
[RestApi("/plus/{x}/{y}")]
public int Plus(int x, int y)
{
return x + y;
}
}
Source Generator
To bridge the gap from Lambda Annotations programming model to the normal programming model a .NET source generator is included in this package. After adding the attributes to your .NET code the source generator will generate the translation code between the 2 programming models. It will also keep in sync the generated information including a new function handler string into the CloudFormation template. The usage of source generator is transparent to the user.
To see the code that is generated by the source generator turn the verbosity to detailed when executing a build. From the command this
is done by using the --verbosity
switch.
dotnet build --verbosity detailed
To change the verbosity in Visual Studio go to Tools → Options → Projects and Solutions and adjust the MSBuild verbosity drop down boxes.
Dependency Injection
Lambda Annotations supports using dependency injection. A class can be marked with a LambdaStartup
attribute. The class will
have a ConfigureServices
method for configuring services.
The services can be injected by either constructor injection or using the FromServices
attribute on a method parameter of
the function decorated with the LambdaFunction
attribute.
Services injected via the constructor have a lifecycle for the length of the Lambda compute container. For each Lambda
invocation a scope is created and the services injected using the FromServices
attribute are created within the scope.
Example startup class:
[LambdaStartup]
public class Startup
{
public void ConfigureServices(IServiceCollection services)
{
services.AddAWSService<Amazon.S3.IAmazonS3>();
services.AddScoped<ITracker, DefaultTracker>();
}
}
Example function using DI:
public class Functions
{
IAmazonS3 _s3Client;
public Functions(IAmazonS3 s3Client)
{
_s3Client = s3Client;
}
[LambdaFunction]
[HttpApi(HttpMethod.Put, HttpApiVersion.V2, "/process/{name}")]
public async Task Process([FromServices] ITracker tracker, string name, [FromBody] string data)
{
tracker.Record();
await _s3Client.PutObjectAsync(new PutObjectRequest
{
BucketName = "storage-bucket",
Key = name,
ContentBody = data
});
}
}
Lambda .NET Attributes
List of .NET attributes currently supported.
- LambdaFunction
- Placed on a method. Indicates this method should be exposed as a Lambda function.
- LambdaStartup
- Placed on a class. Indicates this type should be used as the startup class and is used to configure the dependency injection and middleware. There can only be one class in a Lambda project with this attribute.
Event Attributes
Event attributes configuring the source generator for the type of event to expect and setup the event source in the CloudFormation temlate. If an event attribute is not set the
parameter to the LambdaFunction
must be the event object and the event source must be configured outside of the code.
- RestApi
- Configures the Lambda function to be called from an API Gateway REST API. The HTTP method and resource path are required to be set on the attribute.
- HttpApi
- Configures the Lambda function to be called from an API Gateway HTTP API. The HTTP method, HTTP API payload version and resource path are required to be set on the attribute.
Parameter Attributes
- FromHeader
- Map method parameter to HTTP header value
- FromQuery
- Map method parameter to query string parameter
- FromRoute
- Map method parameter to resource path segment
- FromBody
- Map method parameter to HTTP request body. If parameter is a complex type then request body will be assumed to be JSON and deserialized into the type.
- FromServices
- Map method parameter to registered service in IServiceProvider
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 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. |
-
net6.0
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (4)
Showing the top 4 popular GitHub repositories that depend on Amazon.Lambda.Annotations:
Repository | Stars |
---|---|
aws/aws-lambda-dotnet
Libraries, samples and tools to help .NET Core developers develop AWS Lambda functions.
|
|
aws-samples/serverless-test-samples
This repository is designed to provide guidance for implementing comprehensive test suites for serverless applications.
|
|
hlaueriksson/CommandQuery
Command Query Separation for 🌐ASP.NET Core ⚡AWS Lambda ⚡Azure Functions ⚡Google Cloud Functions
|
|
Particular/docs.particular.net
All content for ParticularDocs
|
Version | Downloads | Last updated |
---|---|---|
1.6.2 | 11,822 | 12/10/2024 |
1.6.1 | 32,980 | 11/20/2024 |
1.6.0 | 14,794 | 11/13/2024 |
1.5.3 | 21,215 | 10/31/2024 |
1.5.2 | 52,707 | 9/29/2024 |
1.5.1 | 7,822 | 9/26/2024 |
1.5.0 | 167,514 | 6/18/2024 |
1.4.0 | 49,135 | 5/16/2024 |
1.3.1 | 56,370 | 4/25/2024 |
1.3.0 | 132,605 | 4/5/2024 |
1.2.0 | 176,443 | 2/16/2024 |
1.1.0 | 111,303 | 11/16/2023 |
1.0.0 | 207,395 | 7/14/2023 |
0.13.5 | 15,033 | 6/23/2023 |
0.13.4 | 3,143 | 6/19/2023 |
0.13.3 | 18,579 | 5/8/2023 |
0.13.2 | 12,473 | 4/24/2023 |
0.13.1 | 26,685 | 4/7/2023 |
0.13.0 | 30,451 | 3/1/2023 |
0.12.0 | 40,563 | 2/14/2023 |
0.11.0 | 2,299 | 2/8/2023 |
0.10.0-preview | 13,538 | 12/8/2022 |
0.9.0-preview | 4,897 | 10/26/2022 |
0.8.0-preview | 2,642 | 9/13/2022 |
0.7.0-preview | 274 | 8/29/2022 |
0.6.0-preview | 1,689 | 8/2/2022 |
0.5.1-preview | 2,188 | 5/3/2022 |
0.5.0-preview | 15,951 | 2/17/2022 |
0.4.3-preview | 934 | 1/22/2022 |
0.4.2-preview | 293 | 12/22/2021 |