summaryrefslogtreecommitdiffstats
path: root/keygen/keygen.c
diff options
context:
space:
mode:
authorjsorg71 <jsorg71>2008-04-15 05:37:30 +0000
committerjsorg71 <jsorg71>2008-04-15 05:37:30 +0000
commitcc464bbd04bc51f257c2366b89415d89c80f8eed (patch)
tree6f0c1c3678ee021953098e540a544a28c0bf9a22 /keygen/keygen.c
parent2363bd373b0797132f4957d3e6a512a462cf7490 (diff)
downloadxrdp-proprietary-cc464bbd04bc51f257c2366b89415d89c80f8eed.tar.gz
xrdp-proprietary-cc464bbd04bc51f257c2366b89415d89c80f8eed.zip
added comments and changed executable name to xrdp-keygen
Diffstat (limited to 'keygen/keygen.c')
-rwxr-xr-xkeygen/keygen.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/keygen/keygen.c b/keygen/keygen.c
index 8651694a..99e0bd01 100755
--- a/keygen/keygen.c
+++ b/keygen/keygen.c
@@ -106,17 +106,18 @@ static int APP_CC
out_params(void)
{
g_writeln("");
- g_writeln("key gen utility examples");
- g_writeln(" './keygen xrdp'");
- g_writeln(" './keygen test'");
+ g_writeln("xrdp rsa key gen utility examples");
+ g_writeln(" './xrdp-keygen xrdp'");
+ g_writeln(" './xrdp-keygen test'");
g_writeln("");
return 0;
}
/*****************************************************************************/
+/* this is the special key signing algorithm */
static int APP_CC
sign_key(char* e_data, int e_len, char* n_data, int n_len,
- char* d_data, int d_len, char* sign_data, int sign_len)
+ char* sign_data, int sign_len)
{
char* key;
char* md5_final;
@@ -129,18 +130,26 @@ sign_key(char* e_data, int e_len, char* n_data, int n_len,
key = (char*)g_malloc(176, 0);
md5_final = (char*)g_malloc(64, 0);
md5 = ssl_md5_info_create();
+ /* copy the test key */
g_memcpy(key, g_testkey, 176);
+ /* replace e and n */
g_memcpy(key + 32, e_data, 4);
g_memcpy(key + 36, n_data, 64);
ssl_md5_clear(md5);
+ /* the first 108 bytes */
ssl_md5_transform(md5, key, 108);
+ /* set the whole thing with 0xff */
g_memset(md5_final, 0xff, 64);
+ /* digest 16 bytes */
ssl_md5_complete(md5, md5_final);
+ /* set non 0xff array items */
md5_final[16] = 0;
md5_final[62] = 1;
md5_final[63] = 0;
+ /* encrypt */
ssl_mod_exp(sign_data, 64, md5_final, 64, (char*)g_ppk_n, 64,
(char*)g_ppk_d, 64);
+ /* cleanup */
ssl_md5_info_delete(md5);
g_free(key);
g_free(md5_final);
@@ -260,8 +269,7 @@ key_gen(void)
{
g_writeln("ssl_gen_key_xrdp1 ok");
g_writeln("");
- error = sign_key(e_data, e_len, n_data, n_len, d_data, d_len,
- sign_data, sign_len);
+ error = sign_key(e_data, e_len, n_data, n_len, sign_data, sign_len);
if (error != 0)
{
g_writeln("error %d in key_gen, sign_key", error);