HashiCorpVaultLib 1.0.5
dotnet add package HashiCorpVaultLib --version 1.0.5
NuGet\Install-Package HashiCorpVaultLib -Version 1.0.5
<PackageReference Include="HashiCorpVaultLib" Version="1.0.5" />
<PackageVersion Include="HashiCorpVaultLib" Version="1.0.5" />
<PackageReference Include="HashiCorpVaultLib" />
paket add HashiCorpVaultLib --version 1.0.5
#r "nuget: HashiCorpVaultLib, 1.0.5"
#:package HashiCorpVaultLib@1.0.5
#addin nuget:?package=HashiCorpVaultLib&version=1.0.5
#tool nuget:?package=HashiCorpVaultLib&version=1.0.5
HashiCorp Vault Library for .NET
A simple and secure .NET library for retrieving secrets from HashiCorp Vault using AppRole authentication. Compatible with both .NET Framework and .NET Core/.NET 5+.
Features
- AppRole Authentication: Secure authentication using Role ID and Secret ID
- KV v2 Support: Automatically handles Vault KV version 2 API paths
- SSL Certificate Validation: Verifies SSL certificates by default; optional bypass for development environments
- Simple API: Easy-to-use static methods for common use cases
- Environment Variable Security: Secret ID is read from environment variables
- Error Handling: Comprehensive error handling with descriptive messages
- Strict Field Validation: Ensures correct field names in Vault secrets for reliability
Installation
Install the package via NuGet Package Manager:
dotnet add package HashiCorpVaultLib
Or via Package Manager Console:
Install-Package HashiCorpVaultLib
Prerequisites
Before using this library, you must set the VAULT_SECRET_ID environment variable:
Windows (Command Prompt):
set VAULT_SECRET_ID=your-secret-id-here
Windows (PowerShell):
$env:VAULT_SECRET_ID = "your-secret-id-here"
Linux/macOS:
export VAULT_SECRET_ID=your-secret-id-here
Important: If VAULT_SECRET_ID is not set, the application will terminate with exit code 777.
Usage
Retrieving Username and Password
Use this method when your Vault secret contains username and password fields.
⚠️ Required Field Names: Your Vault secret MUST contain fields named exactly username and password. Other field names will not work.
using HashiCorpVaultLib;
// Retrieve credentials from Vault (production - SSL verification enabled)
var (username, password) = VaultLib.GetUsernamePassword(
vaultUrl: "https://vault.example.com:8200",
roleId: "your-role-id",
secretPath: "system_test/username_password",
ignoreSslErrors: false // Default - recommended for production
);
Console.WriteLine($"Username: {username}");
Console.WriteLine($"Password: {password}");
// Development mode - bypass SSL validation (use only for development!)
var (devUsername, devPassword) = VaultLib.GetUsernamePassword(
vaultUrl: "https://vault-dev.example.com:8200",
roleId: "dev-role-id",
secretPath: "dev/database",
ignoreSslErrors: true // Only for development environments
);
Vault Secret Structure (username/password):
{
"username": "admin",
"password": "secure-password-123"
}
⚠️ Important: Field names are case-sensitive and must be exactly username and password. Using different names (e.g., user, userName, pass) will cause an error.
Retrieving Secret Text
Use this method when your Vault secret contains a secret_text field.
⚠️ Required Field Name: Your Vault secret MUST contain a field named exactly secret_text. Other field names will not work.
using HashiCorpVaultLib;
// Retrieve secret text from Vault
string token = VaultLib.GetSecretText(
vaultUrl: "https://vault.example.com:8200",
roleId: "your-role-id",
secretPath: "system_test/username_password",
ignoreSslErrors: false // Default - recommended for production
);
Console.WriteLine($"Token: {token}");
Vault Secret Structure (secret text):
{
"secret_text": "my-api-token-or-other-secret"
}
⚠️ Important: Field name is case-sensitive and must be exactly secret_text. Using different names (e.g., secretText, secret, text) will cause an error.
SSL Certificate Handling
By default, the library verifies SSL certificates for production security. SSL certificate validation is enabled by default (ignoreSslErrors: false).
For development environments with self-signed certificates, you can optionally bypass SSL validation:
// Production (default) - SSL verification enabled
var (username, password) = VaultLib.GetUsernamePassword(
"https://vault.example.com:8200",
"role-id",
"app/database"
// ignoreSslErrors is false by default
);
// Development - SSL verification disabled
var (username, password) = VaultLib.GetUsernamePassword(
"https://vault-dev.local:8200",
"dev-role-id",
"dev/database",
ignoreSslErrors: true // Only for development!
);
⚠️ Warning: Never use ignoreSslErrors: true in production environments!
Path Transformation
The library automatically transforms simple paths to KV v2 API format:
| Input Path | Vault API Path |
|---|---|
system_test/username_password |
/v1/system_test/data/username_password |
app/config |
/v1/app/data/config |
database/credentials |
/v1/database/data/credentials |
Error Handling
The library throws exceptions in the following cases:
- Missing VAULT_SECRET_ID: Application exits with code 777
- Authentication failure: Invalid Role ID or Secret ID
- Secret not found: Invalid path or insufficient permissions
- Missing required fields: Secret doesn't contain expected fields (
username,password, orsecret_text) - Network errors: Connection issues or timeout
Example error handling:
try
{
var (username, password) = VaultLib.GetUsernamePassword(
"https://vault.example.com:8200",
"role-id",
"system_test/username_password",
ignoreSslErrors: false
);
// Use credentials...
}
catch (Exception ex)
{
Console.WriteLine($"Failed to retrieve credentials: {ex.Message}");
// Handle error appropriately
}
Security Considerations
- Never hardcode secrets: Always use environment variables for Secret ID
- SSL Verification: SSL certificate validation is enabled by default. Only bypass it in development with
ignoreSslErrors: true - Credentials Handling: Never log or expose retrieved credentials
- Environment Variables: Set
VAULT_SECRET_IDsecurely in your deployment environment - AppRole Permissions: Ensure your AppRole has minimal required permissions in Vault
Configuration for Production
For production environments, consider:
Setting
VAULT_SECRET_IDvia:- CI/CD pipeline secrets
- Kubernetes secrets
- Cloud provider secret management
- Secure configuration management tools
Updating your Vault policies to restrict access appropriately
Using proper SSL/TLS certificates and enabling certificate validation
Example Project
A complete working example is available in the examples/HashiCorpVaultLib.Example directory. The example demonstrates:
- Loading configuration from appsettings.json
- Retrieving username/password secrets
- Retrieving secret text
- SSL certificate handling
- Error handling
Running the Example:
Navigate to the example directory:
cd examples/HashiCorpVaultLib.ExampleCopy and configure settings:
cp appsettings.example.json appsettings.json # Edit appsettings.json with your Vault detailsSet environment variable:
export VAULT_SECRET_ID=your-secret-idRun the example:
dotnet run
See examples/HashiCorpVaultLib.Example/README.md for detailed instructions.
Vault Secret Field Requirements
⚠️ Critical: This library expects specific field names in your Vault secrets:
For Username/Password secrets:
- Field
username(exact case) - contains the username - Field
password(exact case) - contains the password
For Secret Text:
- Field
secret_text(exact case) - contains the secret value
These field names are mandatory and case-sensitive. Using different field names will result in errors. The library will throw an exception if the required fields are missing or empty.
Requirements
- .NET Standard 2.0 or higher
- .NET Framework 4.6.1+ or .NET Core 2.0+
- Vault server with AppRole authentication enabled
- KV v2 secrets engine
- Vault secrets must use exact field names:
username,password, orsecret_text
License
MIT
Contributing
Contributions are welcome! Please feel free to submit pull requests or open issues.
Support
For issues and questions, please use the GitHub issue tracker.
| 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. 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. |
| .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
- Newtonsoft.Json (>= 13.0.3)
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.5 | 337 | 10/15/2025 |