feat: Implement DefaultCryptoHmac for compliance-aware HMAC operations
- Added DefaultCryptoHmac class implementing ICryptoHmac interface. - Introduced purpose-based HMAC computation methods. - Implemented verification methods for HMACs with constant-time comparison. - Created HmacAlgorithms and HmacPurpose classes for well-known identifiers. - Added compliance profile support for HMAC algorithms. - Included asynchronous methods for HMAC computation from streams.
This commit is contained in:
@@ -9,6 +9,8 @@ public sealed class ConcelierOptions
|
||||
{
|
||||
public StorageOptions Storage { get; set; } = new();
|
||||
|
||||
public PostgresStorageOptions? PostgresStorage { get; set; }
|
||||
|
||||
public PluginOptions Plugins { get; set; } = new();
|
||||
|
||||
public TelemetryOptions Telemetry { get; set; } = new();
|
||||
@@ -36,6 +38,63 @@ public sealed class ConcelierOptions
|
||||
public int CommandTimeoutSeconds { get; set; } = 30;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// PostgreSQL storage options for the LNM linkset cache.
|
||||
/// </summary>
|
||||
public sealed class PostgresStorageOptions
|
||||
{
|
||||
/// <summary>
|
||||
/// Enable PostgreSQL storage for LNM linkset cache.
|
||||
/// When true, the linkset cache is stored in PostgreSQL instead of MongoDB.
|
||||
/// </summary>
|
||||
public bool Enabled { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// PostgreSQL connection string.
|
||||
/// </summary>
|
||||
public string ConnectionString { get; set; } = string.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Command timeout in seconds. Default is 30 seconds.
|
||||
/// </summary>
|
||||
public int CommandTimeoutSeconds { get; set; } = 30;
|
||||
|
||||
/// <summary>
|
||||
/// Maximum number of connections in the pool. Default is 100.
|
||||
/// </summary>
|
||||
public int MaxPoolSize { get; set; } = 100;
|
||||
|
||||
/// <summary>
|
||||
/// Minimum number of connections in the pool. Default is 1.
|
||||
/// </summary>
|
||||
public int MinPoolSize { get; set; } = 1;
|
||||
|
||||
/// <summary>
|
||||
/// Connection idle lifetime in seconds. Default is 300 seconds (5 minutes).
|
||||
/// </summary>
|
||||
public int ConnectionIdleLifetimeSeconds { get; set; } = 300;
|
||||
|
||||
/// <summary>
|
||||
/// Enable connection pooling. Default is true.
|
||||
/// </summary>
|
||||
public bool Pooling { get; set; } = true;
|
||||
|
||||
/// <summary>
|
||||
/// Schema name for LNM tables. Default is "vuln".
|
||||
/// </summary>
|
||||
public string SchemaName { get; set; } = "vuln";
|
||||
|
||||
/// <summary>
|
||||
/// Enable automatic migration on startup. Default is false for production safety.
|
||||
/// </summary>
|
||||
public bool AutoMigrate { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Path to SQL migration files. Required if AutoMigrate is true.
|
||||
/// </summary>
|
||||
public string? MigrationsPath { get; set; }
|
||||
}
|
||||
|
||||
public sealed class PluginOptions
|
||||
{
|
||||
public string? BaseDirectory { get; set; }
|
||||
|
||||
Reference in New Issue
Block a user