Asn1KeyWrapper
using Org.BouncyCastle.Asn1;
using Org.BouncyCastle.Asn1.Pkcs;
using Org.BouncyCastle.Asn1.X509;
using Org.BouncyCastle.X509;
using System;
namespace Org.BouncyCastle.Crypto.Operators
{
    public class Asn1KeyWrapper : IKeyWrapper
    {
        private string algorithm;
        private IKeyWrapper wrapper;
        public object AlgorithmDetails => wrapper.AlgorithmDetails;
        public Asn1KeyWrapper(string algorithm, X509Certificate cert)
            : this(algorithm, cert.GetPublicKey())
        {
        }
        public Asn1KeyWrapper(string algorithm, ICipherParameters key)
        {
            this.algorithm = algorithm;
            wrapper = KeyWrapperUtil.WrapperForName(algorithm, key);
        }
        public Asn1KeyWrapper(DerObjectIdentifier algorithm, X509Certificate cert)
            : this(algorithm, null, cert.GetPublicKey())
        {
        }
        public Asn1KeyWrapper(DerObjectIdentifier algorithm, ICipherParameters key)
            : this(algorithm, null, key)
        {
        }
        public Asn1KeyWrapper(AlgorithmIdentifier algorithm, X509Certificate cert)
            : this(algorithm.Algorithm, algorithm.Parameters, cert.GetPublicKey())
        {
        }
        public Asn1KeyWrapper(DerObjectIdentifier algorithm, Asn1Encodable parameters, X509Certificate cert)
            : this(algorithm, parameters, cert.GetPublicKey())
        {
        }
        public Asn1KeyWrapper(AlgorithmIdentifier algorithm, ICipherParameters key)
            : this(algorithm.Algorithm, algorithm.Parameters, key)
        {
        }
        public Asn1KeyWrapper(DerObjectIdentifier algorithm, Asn1Encodable parameters, ICipherParameters key)
        {
            this.algorithm = algorithm.Id;
            if (algorithm.Equals(PkcsObjectIdentifiers.IdRsaesOaep)) {
                RsaesOaepParameters instance = RsaesOaepParameters.GetInstance(parameters);
                WrapperProvider wrapperProvider;
                if (instance.MaskGenAlgorithm.Algorithm.Equals(PkcsObjectIdentifiers.IdMgf1)) {
                    AlgorithmIdentifier instance2 = AlgorithmIdentifier.GetInstance(instance.MaskGenAlgorithm.Parameters);
                    wrapperProvider = new RsaOaepWrapperProvider(instance.HashAlgorithm.Algorithm, instance2.Algorithm);
                } else
                    wrapperProvider = new RsaOaepWrapperProvider(instance.HashAlgorithm.Algorithm, instance.MaskGenAlgorithm.Algorithm);
                wrapper = (IKeyWrapper)wrapperProvider.CreateWrapper(true, key);
            } else {
                if (!algorithm.Equals(PkcsObjectIdentifiers.RsaEncryption))
                    throw new ArgumentException("unknown algorithm: " + algorithm.Id);
                wrapper = new RsaPkcs1Wrapper(true, key);
            }
        }
        public IBlockResult Wrap(byte[] keyData)
        {
            return wrapper.Wrap(keyData);
        }
    }
}