docs consolidation and others
This commit is contained in:
@@ -11,25 +11,27 @@ public sealed class EcdsaP256Signer : IContentSigner
|
||||
{
|
||||
private readonly ECDsa _ecdsa;
|
||||
private readonly string _keyId;
|
||||
private readonly TimeProvider _timeProvider;
|
||||
private bool _disposed;
|
||||
|
||||
public string KeyId => _keyId;
|
||||
public SignatureProfile Profile => SignatureProfile.EcdsaP256;
|
||||
public string Algorithm => "ES256";
|
||||
|
||||
public EcdsaP256Signer(string keyId, ECDsa ecdsa)
|
||||
public EcdsaP256Signer(string keyId, ECDsa ecdsa, TimeProvider? timeProvider = null)
|
||||
{
|
||||
_keyId = keyId ?? throw new ArgumentNullException(nameof(keyId));
|
||||
_ecdsa = ecdsa ?? throw new ArgumentNullException(nameof(ecdsa));
|
||||
_timeProvider = timeProvider ?? TimeProvider.System;
|
||||
|
||||
if (_ecdsa.KeySize != 256)
|
||||
throw new ArgumentException("ECDSA key must be P-256 (256 bits)", nameof(ecdsa));
|
||||
}
|
||||
|
||||
public static EcdsaP256Signer Generate(string keyId)
|
||||
public static EcdsaP256Signer Generate(string keyId, TimeProvider? timeProvider = null)
|
||||
{
|
||||
var ecdsa = ECDsa.Create(ECCurve.NamedCurves.nistP256);
|
||||
return new EcdsaP256Signer(keyId, ecdsa);
|
||||
return new EcdsaP256Signer(keyId, ecdsa, timeProvider);
|
||||
}
|
||||
|
||||
public Task<SignatureResult> SignAsync(ReadOnlyMemory<byte> payload, CancellationToken ct = default)
|
||||
@@ -45,7 +47,7 @@ public sealed class EcdsaP256Signer : IContentSigner
|
||||
Profile = Profile,
|
||||
Algorithm = Algorithm,
|
||||
Signature = signature,
|
||||
SignedAt = DateTimeOffset.UtcNow
|
||||
SignedAt = _timeProvider.GetUtcNow()
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user