| | | 1 | | namespace AsiBackbone.Signing.LocalDevelopment; |
| | | 2 | | |
| | | 3 | | /// <summary> |
| | | 4 | | /// Configures the local-development signing provider. |
| | | 5 | | /// </summary> |
| | | 6 | | /// <remarks> |
| | | 7 | | /// This provider is intended for local development, samples, and tests. It is not a production managed-key provider and |
| | | 8 | | /// </remarks> |
| | | 9 | | public sealed class LocalDevelopmentSigningOptions |
| | | 10 | | { |
| | | 11 | | /// <summary> |
| | | 12 | | /// Gets the default provider descriptor returned in signing metadata. |
| | | 13 | | /// </summary> |
| | | 14 | | public const string DefaultProviderName = "local-development"; |
| | | 15 | | |
| | | 16 | | /// <summary> |
| | | 17 | | /// Gets the default local-development key identifier. |
| | | 18 | | /// </summary> |
| | | 19 | | public const string DefaultKeyId = "local-dev-key"; |
| | | 20 | | |
| | | 21 | | /// <summary> |
| | | 22 | | /// Gets the default local-development key version. |
| | | 23 | | /// </summary> |
| | | 24 | | public const string DefaultKeyVersion = "dev"; |
| | | 25 | | |
| | | 26 | | /// <summary> |
| | | 27 | | /// Gets the default provider-neutral signature algorithm descriptor. |
| | | 28 | | /// </summary> |
| | | 29 | | public const string DefaultSignatureAlgorithm = "RSASSA-PKCS1-v1_5-SHA256-LOCAL-DEV"; |
| | | 30 | | |
| | | 31 | | /// <summary> |
| | | 32 | | /// Gets the default RSA key size for generated local-development keys. |
| | | 33 | | /// </summary> |
| | | 34 | | public const int DefaultKeySizeBits = 2048; |
| | | 35 | | |
| | | 36 | | /// <summary> |
| | | 37 | | /// Gets or sets the provider descriptor returned in signing metadata. |
| | | 38 | | /// </summary> |
| | 15 | 39 | | public string ProviderName { get; set; } = DefaultProviderName; |
| | | 40 | | |
| | | 41 | | /// <summary> |
| | | 42 | | /// Gets or sets the local-development key identifier returned in signing metadata. |
| | | 43 | | /// </summary> |
| | 21 | 44 | | public string KeyId { get; set; } = DefaultKeyId; |
| | | 45 | | |
| | | 46 | | /// <summary> |
| | | 47 | | /// Gets or sets the local-development key version returned in signing metadata. |
| | | 48 | | /// </summary> |
| | 21 | 49 | | public string KeyVersion { get; set; } = DefaultKeyVersion; |
| | | 50 | | |
| | | 51 | | /// <summary> |
| | | 52 | | /// Gets or sets the signature algorithm descriptor returned in signing metadata. |
| | | 53 | | /// </summary> |
| | 16 | 54 | | public string SignatureAlgorithm { get; set; } = DefaultSignatureAlgorithm; |
| | | 55 | | |
| | | 56 | | /// <summary> |
| | | 57 | | /// Gets or sets the generated RSA key size in bits. |
| | | 58 | | /// </summary> |
| | 15 | 59 | | public int KeySizeBits { get; set; } = DefaultKeySizeBits; |
| | | 60 | | |
| | | 61 | | /// <summary> |
| | | 62 | | /// Gets or sets a value indicating whether signing failures should return unsigned metadata with explicit failure d |
| | | 63 | | /// </summary> |
| | 10 | 64 | | public bool ReturnUnsignedOnFailure { get; set; } = true; |
| | | 65 | | |
| | | 66 | | /// <summary> |
| | | 67 | | /// Creates options for the local-development signing provider. |
| | | 68 | | /// </summary> |
| | | 69 | | public static LocalDevelopmentSigningOptions Create( |
| | | 70 | | string? providerName = null, |
| | | 71 | | string? keyId = null, |
| | | 72 | | string? keyVersion = null, |
| | | 73 | | string? signatureAlgorithm = null, |
| | | 74 | | int keySizeBits = DefaultKeySizeBits, |
| | | 75 | | bool returnUnsignedOnFailure = true) |
| | | 76 | | { |
| | 5 | 77 | | return new LocalDevelopmentSigningOptions |
| | 5 | 78 | | { |
| | 5 | 79 | | ProviderName = string.IsNullOrWhiteSpace(providerName) |
| | 5 | 80 | | ? DefaultProviderName |
| | 5 | 81 | | : providerName.Trim(), |
| | 5 | 82 | | KeyId = string.IsNullOrWhiteSpace(keyId) |
| | 5 | 83 | | ? DefaultKeyId |
| | 5 | 84 | | : keyId.Trim(), |
| | 5 | 85 | | KeyVersion = string.IsNullOrWhiteSpace(keyVersion) |
| | 5 | 86 | | ? DefaultKeyVersion |
| | 5 | 87 | | : keyVersion.Trim(), |
| | 5 | 88 | | SignatureAlgorithm = string.IsNullOrWhiteSpace(signatureAlgorithm) |
| | 5 | 89 | | ? DefaultSignatureAlgorithm |
| | 5 | 90 | | : signatureAlgorithm.Trim(), |
| | 5 | 91 | | KeySizeBits = keySizeBits, |
| | 5 | 92 | | ReturnUnsignedOnFailure = returnUnsignedOnFailure |
| | 5 | 93 | | }; |
| | | 94 | | } |
| | | 95 | | } |