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 |
---|---|
.NET | net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows |
.NET Core | netcoreapp2.0 netcoreapp2.1 netcoreapp2.2 netcoreapp3.0 netcoreapp3.1 |
.NET Standard | netstandard2.0 netstandard2.1 |
.NET Framework | net461 net462 net463 net47 net471 net472 net48 net481 |
MonoAndroid | monoandroid |
MonoMac | monomac |
MonoTouch | monotouch |
Tizen | tizen40 tizen60 |
Xamarin.iOS | xamarinios |
Xamarin.Mac | xamarinmac |
Xamarin.TVOS | xamarintvos |
Xamarin.WatchOS | xamarinwatchos |
-
.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.