Skip to main content
Version: Next

Command line secret provider

The command line secret provider transforms all your command line arguments in application secrets.

⚡ Supports synchronous secret retrieval.

Installation

Adding command line arguments into the secret store requires following package:

PM > Install-Package Arcus.Security.Providers.CommandLine

Configuration

After installing the package, the additional extensions becomes available when building the secret store.

using Arcus.Security.Core;
using Microsoft.Extensions.Hosting;

public class Program
{
public static void Main(string[] args)
{
CreateHostBuilder(args).Build().Run();
}

public static IHostBuilder CreateHostBuilder(string[] args)
{
return Host.CreateDefaultBuilder(args)
.ConfigureSecretStore((context, config, builder) =>
{
// Uses the passed-in command line arguments as secrets in the secret store.
builder.AddCommandLine(args);

// Uses the passed-in command lien arguments, using underscores and capitals for secret name structure.
// Example - When looking up Queue.Name it will be changed to ARCUS_QUEUE_NAME.
builder.AddCommandLine(args, mutateSecretName: secretName => secretName.Replace(".", "_").ToUppder());

// Providing an unique name to this secret provider so it can be looked up later.
// See: "Retrieve a specific secret provider from the secret store"
builder.AddCommandLine(args, name: "CommandLine");
})
.ConfigureWebHostDefaults(webBuilder => webBuilder.UseStartup<Startup>());
}
}