]> git.sesse.net Git - rdpsrv/blobdiff - secure.c
Generate the encryption and decryption keys!
[rdpsrv] / secure.c
index 10fc91692fdb72684f7526c242bfa009d9c9edcd..47d5e80ecd9d9a37077cf3413ae64270601cf611 100644 (file)
--- a/secure.c
+++ b/secure.c
@@ -156,6 +156,19 @@ sec_generate_keys(uint8 * client_key, uint8 * server_key, int rc4_key_size)
        /* Initialise RC4 state arrays */
        RC4_set_key(&rc4_decrypt_key, rc4_key_len, sec_decrypt_key);
        RC4_set_key(&rc4_encrypt_key, rc4_key_len, sec_encrypt_key);
+
+       {
+               int i;
+               printf("sec_decrypt_key: ");
+               for (i = 0; i < 16; ++i)
+                       printf("0x%02x ", sec_decrypt_key[i]);
+               printf("\n");
+               
+               printf("sec_encrypt_key: ");
+               for (i = 0; i < 16; ++i)
+                       printf("0x%02x ", sec_encrypt_key[i]);
+               printf("\n");
+       }
 }
 
 static uint8 pad_54[40] = {
@@ -715,6 +728,8 @@ sec_process_mcs_data(STREAM s)
        }
 }
 
+extern unsigned char cacert[];
+
 /* Receive secure transport packet */
 STREAM
 sec_recv(void)
@@ -752,6 +767,8 @@ sec_recv(void)
 
                        if (sec_flags & SEC_CLIENT_RANDOM) {
                                uint32 length;
+                               uint8 inr[SEC_MODULUS_SIZE];
+                               int i;
                                
                                printf("Receiving the client random!\n");
                                in_uint32_le(s, length);
@@ -763,6 +780,22 @@ sec_recv(void)
                                if (!s_check_end(s)) {
                                        error("Junk after client random\n");
                                }
+                               
+                               reverse(sec_crypted_random, SEC_MODULUS_SIZE);
+
+                               RSA_private_decrypt(SEC_MODULUS_SIZE, sec_crypted_random, inr, privkey, RSA_NO_PADDING);
+                       
+                               reverse(inr + SEC_RANDOM_SIZE, SEC_RANDOM_SIZE);
+                               
+                               printf("Unencrypted client random: ");
+                               for (i = 0; i < SEC_RANDOM_SIZE; ++i) {
+                                       printf("0x%x ", inr[i + SEC_RANDOM_SIZE]);
+                               }
+                               printf("\n");
+
+                               // now we can generate the keys
+                               sec_generate_keys(inr + SEC_RANDOM_SIZE, cacert, 8);
+                               continue;
                        }
                }