crypto/weakcrypto/test/tasymmetric/script_gen/gen_dsakey.c
author hgs
Thu, 24 Jun 2010 15:39:07 +0530
changeset 72 de46a57f75fb
permissions -rw-r--r--
201023_02
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
72
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     1
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2009 Nokia Corporation and/or its subsidiary(-ies).
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     3
* All rights reserved.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     5
* under the terms of the License "Eclipse Public License v1.0"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     8
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
     9
* Initial Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    11
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    12
* Contributors:
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    13
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    14
* Description: 
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    15
* Generate a DSA key.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    16
*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    17
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    18
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    19
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    20
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    21
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    22
/**
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    23
 @file
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    24
*/
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    25
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    26
#include <stdio.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    27
#include <openssl/crypto.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    28
#include <openssl/rand.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    29
#include <openssl/dsa.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    30
#include <openssl/bn.h>
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    31
#include "utils.h"
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    32
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    33
#ifndef BOOL
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    34
#define BOOL int
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    35
#define TRUE 1
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    36
#define FALSE 0
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    37
#endif
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    38
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    39
static void printDSAKey(DSA* key)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    40
    {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    41
    printf("static DSA* createDSAKey()\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    42
    printf("\t{\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    43
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    44
    printCBN("p_data", key->p);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    45
    printCBN("q_data", key->q);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    46
    printCBN("g_data", key->g);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    47
    printCBN("priv_key_data", key->priv_key);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    48
    printCBN("pub_key_data", key->pub_key);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    49
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    50
    printf("\tDSA* key = DSA_new();\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    51
    printf("\tkey->p = BN_new();\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    52
    printf("\tkey->q = BN_new();\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    53
    printf("\tkey->g = BN_new();\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    54
    printf("\tkey->priv_key = BN_new();\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    55
    printf("\tkey->pub_key = BN_new();\n\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    56
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    57
    printf("\tBN_bin2bn(p_data, p_data_len, key->p);\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    58
    printf("\tBN_bin2bn(q_data, q_data_len, key->q);\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    59
    printf("\tBN_bin2bn(g_data, g_data_len, key->g);\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    60
    printf("\tBN_bin2bn(pub_key_data, pub_key_data_len, key->pub_key);\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    61
    printf("\tBN_bin2bn(priv_key_data, priv_key_data_len, key->priv_key);\n\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    62
     
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    63
    printf("\treturn key;\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    64
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    65
    printf("\t}\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    66
    }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    67
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    68
/*
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    69
 * This is the seed used in the openssl test code.  Using it (by
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    70
 * specifying the -use_seed option) makes this program generate the
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    71
 * same key used in the openssl test code
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    72
 *
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    73
 * It comes from the updated Appendix 5 to FIPS PUB 186.
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    74
 */
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    75
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    76
static unsigned char seed[20]={
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    77
	0xd5,0x01,0x4e,0x4b,0x60,0xef,0x2b,0xa8,0xb6,0x21,0x1b,0x40,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    78
	0x62,0xba,0x32,0x24,0xe0,0x42,0x7d,0xd3,
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    79
	};
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    80
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    81
static const char rnd_seed[] = "string to make the random number generator think it has entropy";
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    82
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    83
static void badUsage()
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    84
    {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    85
    printf("usage: gen_dsakey [ -use_seed ]\n");
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    86
    exit(1);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    87
    }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    88
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    89
int main(int argc, char **argv)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    90
	{
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    91
	DSA *dsa=NULL;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    92
	int counter,ret=0,i,j;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    93
	unsigned char buf[256];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    94
	unsigned long h;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    95
	unsigned char sig[256];
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    96
	unsigned int siglen;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    97
    BOOL useSeed = FALSE;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    98
de46a57f75fb 201023_02
hgs
parents:
diff changeset
    99
    if (argc > 2)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   100
        badUsage();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   101
    else if (argc == 2)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   102
        {
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   103
        if (strcmp(argv[1], "-use_seed") != 0)
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   104
            badUsage();
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   105
        useSeed = TRUE;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   106
        }
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   107
    
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   108
	RAND_seed(rnd_seed, sizeof rnd_seed);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   109
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   110
	dsa=DSA_generate_parameters(512,useSeed ? seed : NULL,20,&counter,&h,NULL,NULL);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   111
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   112
	DSA_generate_key(dsa);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   113
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   114
    printDSAKey(dsa);
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   115
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   116
	return 0;
de46a57f75fb 201023_02
hgs
parents:
diff changeset
   117
	}