Gcp.SecretManager.Provider
2.0.0
dotnet add package Gcp.SecretManager.Provider --version 2.0.0
NuGet\Install-Package Gcp.SecretManager.Provider -Version 2.0.0
<PackageReference Include="Gcp.SecretManager.Provider" Version="2.0.0" />
paket add Gcp.SecretManager.Provider --version 2.0.0
#r "nuget: Gcp.SecretManager.Provider, 2.0.0"
// Install Gcp.SecretManager.Provider as a Cake Addin #addin nuget:?package=Gcp.SecretManager.Provider&version=2.0.0 // Install Gcp.SecretManager.Provider as a Cake Tool #tool nuget:?package=Gcp.SecretManager.Provider&version=2.0.0
Google Secret Manager ConfigurationProvider
Provides access to Google Secret Manager trough ConfigurationProvider
dotnet add package Gcp.SecretManager.Provider
Before use
- Enable Secret Manager API from console
- Create new Service Account from console
- It is recommended to give Secret Manager Secret Accessor -role
- Save JSON key somewhere safe. We need it later.
- Add secrets to Secret Manager
How to use
- Add this package trough package manager
dotnet add package Gcp.SecretManager.Provider
- Configure secret manager as configuration source
config.AddGcpSecretManager(options => {
options.ProjectId = "ProjectId"; // Required
options.CredentialsPath = "/path/to/credentials"; // Optional
options.Loader = new DefaultSecretManagerConfigurationLoader() // Optional, see more info below
});
You can also provide CredentialsPath with GOOGLE_APPLICATION_CREDENTIALS environment variable
- Ready to go!
Loaders
Loaders handles if secret should be loaded and mapping from Secret Manager keys to application configuration values by implementing contract ISecretManagerConfigurationLoader
. This can be passed as an option during setup.
Contract exposes two method: Load
and GetKey
. Load
method determines if the key should be loaded or not and GetKey
handles mapping from secret to application configuration. You may access secret ID from secret.SecretName.SecretId
If no loader is specified then DefaultSecretManagerConfigurationLoader
will be used. It loads all keys and hierarcy is added by adding two underscores in the secret name. Eg. MultiLevel__Secret
maps to MultiLevel:Secret
key in application configuration.
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 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. |
.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
- Google.Cloud.SecretManager.V1 (>= 1.0.0)
- Microsoft.Extensions.Configuration (>= 3.1.22)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.