SecureRequest.AwsSecretsManager
1.0.0
dotnet add package SecureRequest.AwsSecretsManager --version 1.0.0
NuGet\Install-Package SecureRequest.AwsSecretsManager -Version 1.0.0
<PackageReference Include="SecureRequest.AwsSecretsManager" Version="1.0.0" />
<PackageVersion Include="SecureRequest.AwsSecretsManager" Version="1.0.0" />
<PackageReference Include="SecureRequest.AwsSecretsManager" />
paket add SecureRequest.AwsSecretsManager --version 1.0.0
#r "nuget: SecureRequest.AwsSecretsManager, 1.0.0"
#:package SecureRequest.AwsSecretsManager@1.0.0
#addin nuget:?package=SecureRequest.AwsSecretsManager&version=1.0.0
#tool nuget:?package=SecureRequest.AwsSecretsManager&version=1.0.0
SecureRequest.AwsSecretsManager
AWS Secrets Manager provider for the SecureRequest NuGet package.
Stores the RSA private key inside AWS Secrets Manager instead of Redis/IDistributedCache,
protected by IAM access control, CloudTrail audit logging, and KMS encryption at rest.
Installation
dotnet add package SecureRequest
dotnet add package SecureRequest.AwsSecretsManager
Usage
Chain .WithAwsSecretsManager() onto AddSecureRequest():
builder.Services
.AddSecureRequest(builder.Configuration)
.WithAwsSecretsManager(); // uses default AWS credential chain (IAM role, env vars, ~/.aws)
The AWS SDK default credential chain is used automatically — picks up IAM roles (EC2/ECS/Lambda/EKS), environment variables (AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY), and ~/.aws/credentials in development.
Custom secret ID and region
builder.Services
.AddSecureRequest(builder.Configuration)
.WithAwsSecretsManager(
secretId : "myapp/prod/rsa-key",
region : RegionEndpoint.EUWest1);
Bring your own client (already in DI)
// Register with custom credentials
builder.Services.AddSingleton<IAmazonSecretsManager>(
new AmazonSecretsManagerClient(new StoredProfileAWSCredentials("my-profile")));
builder.Services
.AddSecureRequest(builder.Configuration)
.WithAwsSecretsManager(
clientFactory: sp => sp.GetRequiredService<IAmazonSecretsManager>());
Required IAM permissions
The IAM role or user running the application needs the following policy:
{
"Effect": "Allow",
"Action": [
"secretsmanager:GetSecretValue",
"secretsmanager:CreateSecret",
"secretsmanager:PutSecretValue"
],
"Resource": "arn:aws:secretsmanager:REGION:ACCOUNT:secret:secure-request/rsa-private-key*"
}
On first startup the provider creates the secret (CreateSecret).
On every subsequent startup it reads it back (GetSecretValue).
On key rotation it updates the value (PutSecretValue).
appsettings.json
No changes needed — SecureRequest options are still bound from the same section:
"SecureRequest": {
"Enabled": true,
"EnableBodyEncryption": true,
"EnableHmacSigning": true,
"TimestampToleranceSeconds": 300,
"NonceCacheTtlSeconds": 700,
"SecuredMethods": ["POST", "PUT", "PATCH"],
"ExcludedPaths": []
}
Note:
IDistributedCacheis still required for nonce anti-replay storage. Only the RSA private key moves to Secrets Manager — nonces remain in Redis/in-memory cache.
Comparison
| Default (Redis) | AwsSecretsManagerKeyStorageProvider |
|
|---|---|---|
| Key stored in | Redis (plain Base64) | AWS Secrets Manager (KMS-encrypted) |
| Access control | Redis connection string | IAM roles and policies |
| Audit trail | None | AWS CloudTrail |
| Encryption at rest | Depends on Redis config | AES-256 via AWS KMS (automatic) |
| Compliance | Not sufficient for PCI-DSS / HIPAA | Satisfies requirements |
License
MIT
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | 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. |
-
net8.0
- AWSSDK.SecretsManager (>= 3.7.504.43)
- SecureRequest (>= 1.2.0)
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.0.0 | 21,640 | 6/12/2026 |