123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- #if !BESTHTTP_DISABLE_ALTERNATE_SSL && (!UNITY_WEBGL || UNITY_EDITOR)
- #pragma warning disable
- using System;
- using System.Collections.Generic;
- using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1;
- using Best.HTTP.SecureProtocol.Org.BouncyCastle.Asn1.Cms;
- namespace Best.HTTP.SecureProtocol.Org.BouncyCastle.Cms
- {
- /**
- * Default signed attributes generator.
- */
- public class DefaultSignedAttributeTableGenerator
- : CmsAttributeTableGenerator
- {
- private readonly IDictionary<DerObjectIdentifier, object> m_table;
- /**
- * Initialise to use all defaults
- */
- public DefaultSignedAttributeTableGenerator()
- {
- m_table = new Dictionary<DerObjectIdentifier, object>();
- }
- /**
- * Initialise with some extra attributes or overrides.
- *
- * @param attributeTable initial attribute table to use.
- */
- public DefaultSignedAttributeTableGenerator(AttributeTable attributeTable)
- {
- if (attributeTable != null)
- {
- m_table = attributeTable.ToDictionary();
- }
- else
- {
- m_table = new Dictionary<DerObjectIdentifier, object>();
- }
- }
- /**
- * Create a standard attribute table from the passed in parameters - this will
- * normally include contentType, signingTime, and messageDigest. If the constructor
- * using an AttributeTable was used, entries in it for contentType, signingTime, and
- * messageDigest will override the generated ones.
- *
- * @param parameters source parameters for table generation.
- *
- * @return a filled in Dictionary of attributes.
- */
- protected virtual IDictionary<DerObjectIdentifier, object> CreateStandardAttributeTable(
- IDictionary<CmsAttributeTableParameter, object> parameters)
- {
- var std = new Dictionary<DerObjectIdentifier, object>(m_table);
- DoCreateStandardAttributeTable(parameters, std);
- return std;
- }
- private void DoCreateStandardAttributeTable(IDictionary<CmsAttributeTableParameter, object> parameters,
- IDictionary<DerObjectIdentifier, object> std)
- {
- // contentType will be absent if we're trying to generate a counter signature.
- if (parameters.ContainsKey(CmsAttributeTableParameter.ContentType))
- {
- if (!std.ContainsKey(CmsAttributes.ContentType))
- {
- DerObjectIdentifier contentType = (DerObjectIdentifier)
- parameters[CmsAttributeTableParameter.ContentType];
- Asn1.Cms.Attribute attr = new Asn1.Cms.Attribute(CmsAttributes.ContentType,
- new DerSet(contentType));
- std[attr.AttrType] = attr;
- }
- }
- if (!std.ContainsKey(CmsAttributes.SigningTime))
- {
- Asn1.Cms.Attribute attr = new Asn1.Cms.Attribute(CmsAttributes.SigningTime,
- new DerSet(new Time(DateTime.UtcNow)));
- std[attr.AttrType] = attr;
- }
- if (!std.ContainsKey(CmsAttributes.MessageDigest))
- {
- byte[] messageDigest = (byte[])parameters[CmsAttributeTableParameter.Digest];
- Asn1.Cms.Attribute attr = new Asn1.Cms.Attribute(CmsAttributes.MessageDigest,
- new DerSet(new DerOctetString(messageDigest)));
- std[attr.AttrType] = attr;
- }
- }
- /**
- * @param parameters source parameters
- * @return the populated attribute table
- */
- public virtual AttributeTable GetAttributes(IDictionary<CmsAttributeTableParameter, object> parameters)
- {
- var table = CreateStandardAttributeTable(parameters);
- return new AttributeTable(table);
- }
- }
- }
- #pragma warning restore
- #endif
|