summary refs log tree commit diff
path: root/crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs
diff options
context:
space:
mode:
Diffstat (limited to 'crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs')
-rw-r--r--crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs65
1 files changed, 34 insertions, 31 deletions
diff --git a/crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs b/crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs
index 292aaafe6..9c4e84456 100644
--- a/crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs
+++ b/crypto/src/pqc/crypto/cmce/CmceKemExtractor.cs
@@ -1,44 +1,47 @@
+using System;
 
 using Org.BouncyCastle.Crypto;
-using Org.BouncyCastle.Pqc.Crypto.Cmce;
 
-public class CmceKemExtractor
-    : IEncapsulatedSecretExtractor
+namespace Org.BouncyCastle.Pqc.Crypto.Cmce
 {
-    private CmceEngine engine;
+    public class CmceKemExtractor
+        : IEncapsulatedSecretExtractor
+    {
+        private CmceEngine engine;
 
-    private CmceKeyParameters key;
+        private CmceKeyParameters key;
 
-    public CmceKemExtractor(CmcePrivateKeyParameters privParams)
-    {
-        this.key = privParams;
-        InitCipher(key.Parameters);
-    }
-    
-    private void InitCipher(CmceParameters param)
-    {
-        engine = param.Engine;
-        CmcePrivateKeyParameters privateParams = (CmcePrivateKeyParameters)key;
-        if(privateParams.PrivateKey.Length < engine.PrivateKeySize)
+        public CmceKemExtractor(CmcePrivateKeyParameters privParams)
         {
-            key = new CmcePrivateKeyParameters(privateParams.Parameters, engine.decompress_private_key(privateParams.PrivateKey));
+            this.key = privParams;
+            InitCipher(key.Parameters);
         }
-    }
 
-    public byte[] ExtractSecret(byte[] encapsulation)
-    {
-        return ExtractSecret(encapsulation, engine.DefaultSessionKeySize);
-    }
+        private void InitCipher(CmceParameters param)
+        {
+            engine = param.Engine;
+            CmcePrivateKeyParameters privateParams = (CmcePrivateKeyParameters)key;
+            if (privateParams.PrivateKey.Length < engine.PrivateKeySize)
+            {
+                key = new CmcePrivateKeyParameters(privateParams.Parameters, engine.decompress_private_key(privateParams.PrivateKey));
+            }
+        }
 
-    public byte[] ExtractSecret(byte[] encapsulation, int sessionKeySizeInBits)
-    {
-        byte[] session_key = new byte[sessionKeySizeInBits / 8];
-        engine.kem_dec(session_key, encapsulation, ((CmcePrivateKeyParameters)key).PrivateKey);
-        return session_key;
-    }
+        public byte[] ExtractSecret(byte[] encapsulation)
+        {
+            return ExtractSecret(encapsulation, engine.DefaultSessionKeySize);
+        }
 
-    public int GetInputSize()
-    {
-        return engine.CipherTextSize;
+        public byte[] ExtractSecret(byte[] encapsulation, int sessionKeySizeInBits)
+        {
+            byte[] session_key = new byte[sessionKeySizeInBits / 8];
+            engine.kem_dec(session_key, encapsulation, ((CmcePrivateKeyParameters)key).PrivateKey);
+            return session_key;
+        }
+
+        public int GetInputSize()
+        {
+            return engine.CipherTextSize;
+        }
     }
 }