LodeKennes.Extensions.Scaleway.SecretManager
1.1.1
dotnet add package LodeKennes.Extensions.Scaleway.SecretManager --version 1.1.1
NuGet\Install-Package LodeKennes.Extensions.Scaleway.SecretManager -Version 1.1.1
<PackageReference Include="LodeKennes.Extensions.Scaleway.SecretManager" Version="1.1.1" />
<PackageVersion Include="LodeKennes.Extensions.Scaleway.SecretManager" Version="1.1.1" />
<PackageReference Include="LodeKennes.Extensions.Scaleway.SecretManager" />
paket add LodeKennes.Extensions.Scaleway.SecretManager --version 1.1.1
#r "nuget: LodeKennes.Extensions.Scaleway.SecretManager, 1.1.1"
#:package LodeKennes.Extensions.Scaleway.SecretManager@1.1.1
#addin nuget:?package=LodeKennes.Extensions.Scaleway.SecretManager&version=1.1.1
#tool nuget:?package=LodeKennes.Extensions.Scaleway.SecretManager&version=1.1.1
Scaleway Secret Manager Configuration Extension for .NET
This NuGet package provides an extension for integrating Scaleway Secret Manager secrets into your .NET application's configuration system. It allows seamless fetching and management of secrets stored in Scaleway using the Scaleway CLI or via self-defined credentials.
Features
- Integrate Scaleway secrets into the .NET
IConfigurationsystem. - Ensure Scaleway CLI is installed and functional when using
UseCli. - Customizable options for specifying the Scaleway credentials.
Installation
To install the package, use the following command in your terminal:
dotnet add package LodeKennes.Extensions.Scaleway.SecretManager
Usage
To use the extension, add it to your IConfigurationBuilder like so:
using LodeKennes.Extensions.Scaleway.SecretManager;
using Microsoft.Extensions.Configuration;
var configurationBuilder = new ConfigurationBuilder()
.AddScalewayCliSecrets(options =>
{
options.ProjectId = Guid.Parse("your-project-id-here");
options.Region = "your-region-here"; // Optional: specify the region if needed
options.EnableCaching(TimeSpan.FromMinutes(1)); // Optional: enable caching to reduce the number of calls to the Scaleway API
// Define the authentication strategy
options.UseCli(); // use the Scaleway CLI to fetch credentials
options.UseCredentials("<secretKey>", "<region>", "<organizationId>"); // use self-defined credentials
})
.Build();
var configuration = configurationBuilder.Build();
Example
An example unit test illustrates how to use the AddScalewayCliSecrets extension method:
[Fact]
public void ZoneVariableShouldLoad()
{
var configurationBuilder = new ConfigurationBuilder()
.AddScalewayCliSecrets(options =>
{
options.ProjectId = Guid.Parse("7C85EC8F-CAA2-4579-A6B9-FB6581A23E08");
options.UseCli();
options.FilterByTags("zone");
})
.Build();
Assert.NotNull(configurationBuilder);
var zone = configurationBuilder["zone"];
Assert.NotNull(zone);
Assert.True("intellua.com" == zone);
}
Requirements
- Scaleway CLI: Ensure that the Scaleway CLI is installed and accessible from your environment.
- .NET SDK: This package requires .NET 6.0 or later versions.
Exception Handling
ScalewayCliException: Thrown when Scaleway CLI is not installed.
Contributing
Feel free to open an issue or submit a pull request if you have any improvements or additional features you'd like to contribute.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. net9.0 is compatible. 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 is compatible. 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. |
| .NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
| .NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
| MonoAndroid | monoandroid was computed. |
| MonoMac | monomac was computed. |
| MonoTouch | monotouch was computed. |
| Tizen | tizen40 was computed. tizen60 was computed. |
| Xamarin.iOS | xamarinios was computed. |
| Xamarin.Mac | xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.AspNetCore.DataProtection (>= 10.0.1)
- Microsoft.Extensions.Configuration (>= 10.0.1)
- Microsoft.Extensions.DependencyInjection (>= 10.0.1)
- System.Text.Json (>= 10.0.1)
-
net10.0
- Microsoft.AspNetCore.DataProtection (>= 10.0.1)
- Microsoft.Extensions.Configuration (>= 10.0.1)
- Microsoft.Extensions.DependencyInjection (>= 10.0.1)
-
net8.0
- Microsoft.AspNetCore.DataProtection (>= 10.0.1)
- Microsoft.Extensions.Configuration (>= 10.0.1)
- Microsoft.Extensions.DependencyInjection (>= 10.0.1)
- System.Text.Json (>= 10.0.1)
-
net9.0
- Microsoft.AspNetCore.DataProtection (>= 10.0.1)
- Microsoft.Extensions.Configuration (>= 10.0.1)
- Microsoft.Extensions.DependencyInjection (>= 10.0.1)
- System.Text.Json (>= 10.0.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.