mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-26 16:25:51 +00:00 
			
		
		
		
	Import code from previous AssetBuilder version
This commit is contained in:
		
							
								
								
									
										103
									
								
								thirdparty/libtomcrypt/pk/katja/katja_decrypt_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										103
									
								
								thirdparty/libtomcrypt/pk/katja/katja_decrypt_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,103 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_decrypt_key.c | ||||
|   Katja PKCS #1 OAEP Decryption, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|    (PKCS #1 v2.0) decrypt then OAEP depad | ||||
|    @param in          The ciphertext | ||||
|    @param inlen       The length of the ciphertext (octets) | ||||
|    @param out         [out] The plaintext | ||||
|    @param outlen      [in/out] The max size and resulting size of the plaintext (octets) | ||||
|    @param lparam      The system "lparam" value | ||||
|    @param lparamlen   The length of the lparam value (octets) | ||||
|    @param hash_idx    The index of the hash desired | ||||
|    @param stat        [out] Result of the decryption, 1==valid, 0==invalid | ||||
|    @param key         The corresponding private Katja key | ||||
|    @return CRYPT_OK if succcessul (even if invalid) | ||||
| */ | ||||
| int katja_decrypt_key(const unsigned char *in,       unsigned long  inlen, | ||||
|                           unsigned char *out,      unsigned long *outlen, | ||||
|                     const unsigned char *lparam,   unsigned long  lparamlen, | ||||
|                           int            hash_idx, int           *stat, | ||||
|                           katja_key       *key) | ||||
| { | ||||
|   unsigned long modulus_bitlen, modulus_bytelen, x; | ||||
|   int           err; | ||||
|   unsigned char *tmp; | ||||
|  | ||||
|   LTC_ARGCHK(out    != NULL); | ||||
|   LTC_ARGCHK(outlen != NULL); | ||||
|   LTC_ARGCHK(key    != NULL); | ||||
|   LTC_ARGCHK(stat   != NULL); | ||||
|  | ||||
|   /* default to invalid */ | ||||
|   *stat = 0; | ||||
|  | ||||
|   /* valid hash ? */ | ||||
|   if ((err = hash_is_valid(hash_idx)) != CRYPT_OK) { | ||||
|      return err; | ||||
|   } | ||||
|  | ||||
|   /* get modulus len in bits */ | ||||
|   modulus_bitlen = mp_count_bits( (key->N)); | ||||
|  | ||||
|   /* payload is upto pq, so we know q is 1/3rd the size of N and therefore pq is 2/3th the size */ | ||||
|  modulus_bitlen = ((modulus_bitlen << 1) / 3); | ||||
|  | ||||
|   /* round down to next byte */ | ||||
|   modulus_bitlen -= (modulus_bitlen & 7) + 8; | ||||
|  | ||||
|   /* outlen must be at least the size of the modulus */ | ||||
|   modulus_bytelen = mp_unsigned_bin_size( (key->N)); | ||||
|   if (modulus_bytelen != inlen) { | ||||
|      return CRYPT_INVALID_PACKET; | ||||
|   } | ||||
|  | ||||
|   /* allocate ram */ | ||||
|   tmp = XMALLOC(inlen); | ||||
|   if (tmp == NULL) { | ||||
|      return CRYPT_MEM; | ||||
|   } | ||||
|  | ||||
|   /* rsa decode the packet */ | ||||
|   x = inlen; | ||||
|   if ((err = katja_exptmod(in, inlen, tmp, &x, PK_PRIVATE, key)) != CRYPT_OK) { | ||||
|      XFREE(tmp); | ||||
|      return err; | ||||
|   } | ||||
|  | ||||
|   /* shift right by modulus_bytelen - modulus_bitlen/8  bytes */ | ||||
|   for (x = 0; x < (modulus_bitlen >> 3); x++) { | ||||
|      tmp[x] = tmp[x+(modulus_bytelen-(modulus_bitlen>>3))]; | ||||
|   } | ||||
|  | ||||
|   /* now OAEP decode the packet */ | ||||
|   err = pkcs_1_oaep_decode(tmp, x, lparam, lparamlen, modulus_bitlen, hash_idx, | ||||
|                            out, outlen, stat); | ||||
|  | ||||
|   XFREE(tmp); | ||||
|   return err; | ||||
| } | ||||
|  | ||||
| #endif /* LTC_MRSA */ | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										85
									
								
								thirdparty/libtomcrypt/pk/katja/katja_encrypt_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										85
									
								
								thirdparty/libtomcrypt/pk/katja/katja_encrypt_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,85 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_encrypt_key.c | ||||
|   Katja PKCS-style OAEP encryption, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|     (PKCS #1 v2.0) OAEP pad then encrypt | ||||
|     @param in          The plaintext | ||||
|     @param inlen       The length of the plaintext (octets) | ||||
|     @param out         [out] The ciphertext | ||||
|     @param outlen      [in/out] The max size and resulting size of the ciphertext | ||||
|     @param lparam      The system "lparam" for the encryption | ||||
|     @param lparamlen   The length of lparam (octets) | ||||
|     @param prng        An active PRNG | ||||
|     @param prng_idx    The index of the desired prng | ||||
|     @param hash_idx    The index of the desired hash | ||||
|     @param key         The Katja key to encrypt to | ||||
|     @return CRYPT_OK if successful | ||||
| */ | ||||
| int katja_encrypt_key(const unsigned char *in,     unsigned long inlen, | ||||
|                           unsigned char *out,    unsigned long *outlen, | ||||
|                     const unsigned char *lparam, unsigned long lparamlen, | ||||
|                     prng_state *prng, int prng_idx, int hash_idx, katja_key *key) | ||||
| { | ||||
|   unsigned long modulus_bitlen, modulus_bytelen, x; | ||||
|   int           err; | ||||
|  | ||||
|   LTC_ARGCHK(in     != NULL); | ||||
|   LTC_ARGCHK(out    != NULL); | ||||
|   LTC_ARGCHK(outlen != NULL); | ||||
|   LTC_ARGCHK(key    != NULL); | ||||
|  | ||||
|   /* valid prng and hash ? */ | ||||
|   if ((err = prng_is_valid(prng_idx)) != CRYPT_OK) { | ||||
|      return err; | ||||
|   } | ||||
|   if ((err = hash_is_valid(hash_idx)) != CRYPT_OK) { | ||||
|      return err; | ||||
|   } | ||||
|  | ||||
|   /* get modulus len in bits */ | ||||
|   modulus_bitlen = mp_count_bits((key->N)); | ||||
|  | ||||
|   /* payload is upto pq, so we know q is 1/3rd the size of N and therefore pq is 2/3th the size */ | ||||
|   modulus_bitlen = ((modulus_bitlen << 1) / 3); | ||||
|  | ||||
|   /* round down to next byte */ | ||||
|   modulus_bitlen -= (modulus_bitlen & 7) + 8; | ||||
|  | ||||
|   /* outlen must be at least the size of the modulus */ | ||||
|   modulus_bytelen = mp_unsigned_bin_size((key->N)); | ||||
|   if (modulus_bytelen > *outlen) { | ||||
|      *outlen = modulus_bytelen; | ||||
|      return CRYPT_BUFFER_OVERFLOW; | ||||
|   } | ||||
|  | ||||
|   /* OAEP pad the key */ | ||||
|   x = *outlen; | ||||
|   if ((err = pkcs_1_oaep_encode(in, inlen, lparam, | ||||
|                                 lparamlen, modulus_bitlen, prng, prng_idx, hash_idx, | ||||
|                                 out, &x)) != CRYPT_OK) { | ||||
|      return err; | ||||
|   } | ||||
|  | ||||
|   /* Katja exptmod the OAEP pad */ | ||||
|   return katja_exptmod(out, x, out, outlen, PK_PUBLIC, key); | ||||
| } | ||||
|  | ||||
| #endif /* LTC_MRSA */ | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										73
									
								
								thirdparty/libtomcrypt/pk/katja/katja_export.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								thirdparty/libtomcrypt/pk/katja/katja_export.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_export.c | ||||
|   Export Katja PKCS-style keys, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|     This will export either an KatjaPublicKey or KatjaPrivateKey | ||||
|     @param out       [out] Destination of the packet | ||||
|     @param outlen    [in/out] The max size and resulting size of the packet | ||||
|     @param type      The type of exported key (PK_PRIVATE or PK_PUBLIC) | ||||
|     @param key       The Katja key to export | ||||
|     @return CRYPT_OK if successful | ||||
| */ | ||||
| int katja_export(unsigned char *out, unsigned long *outlen, int type, katja_key *key) | ||||
| { | ||||
|    int           err; | ||||
|    unsigned long zero=0; | ||||
|  | ||||
|    LTC_ARGCHK(out    != NULL); | ||||
|    LTC_ARGCHK(outlen != NULL); | ||||
|    LTC_ARGCHK(key    != NULL); | ||||
|  | ||||
|    /* type valid? */ | ||||
|    if (!(key->type == PK_PRIVATE) && (type == PK_PRIVATE)) { | ||||
|       return CRYPT_PK_INVALID_TYPE; | ||||
|    } | ||||
|  | ||||
|    if (type == PK_PRIVATE) { | ||||
|       /* private key */ | ||||
|       /* output is | ||||
|             Version, n, d, p, q, d mod (p-1), d mod (q - 1), 1/q mod p, pq | ||||
|        */ | ||||
|       if ((err = der_encode_sequence_multi(out, outlen, | ||||
|                           LTC_ASN1_SHORT_INTEGER, 1UL, &zero, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->N, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->d, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->p, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->q, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->dP, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->dQ, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->qP, | ||||
|                           LTC_ASN1_INTEGER, 1UL,  key->pq, | ||||
|                           LTC_ASN1_EOL,     0UL, NULL)) != CRYPT_OK) { | ||||
|          return err; | ||||
|       } | ||||
|  | ||||
|       /* clear zero and return */ | ||||
|       return CRYPT_OK; | ||||
|    } else { | ||||
|       /* public key */ | ||||
|       return der_encode_sequence_multi(out, outlen, | ||||
|                                  LTC_ASN1_INTEGER, 1UL, key->N, | ||||
|                                  LTC_ASN1_EOL,     0UL, NULL); | ||||
|    } | ||||
| } | ||||
|  | ||||
| #endif /* LTC_MRSA */ | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										113
									
								
								thirdparty/libtomcrypt/pk/katja/katja_exptmod.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										113
									
								
								thirdparty/libtomcrypt/pk/katja/katja_exptmod.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,113 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_exptmod.c | ||||
|   Katja PKCS-style exptmod, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|    Compute an RSA modular exponentiation | ||||
|    @param in         The input data to send into RSA | ||||
|    @param inlen      The length of the input (octets) | ||||
|    @param out        [out] The destination | ||||
|    @param outlen     [in/out] The max size and resulting size of the output | ||||
|    @param which      Which exponent to use, e.g. PK_PRIVATE or PK_PUBLIC | ||||
|    @param key        The RSA key to use | ||||
|    @return CRYPT_OK if successful | ||||
| */ | ||||
| int katja_exptmod(const unsigned char *in,   unsigned long inlen, | ||||
|                         unsigned char *out,  unsigned long *outlen, int which, | ||||
|                         katja_key *key) | ||||
| { | ||||
|    void         *tmp, *tmpa, *tmpb; | ||||
|    unsigned long x; | ||||
|    int           err; | ||||
|  | ||||
|    LTC_ARGCHK(in     != NULL); | ||||
|    LTC_ARGCHK(out    != NULL); | ||||
|    LTC_ARGCHK(outlen != NULL); | ||||
|    LTC_ARGCHK(key    != NULL); | ||||
|  | ||||
|    /* is the key of the right type for the operation? */ | ||||
|    if (which == PK_PRIVATE && (key->type != PK_PRIVATE)) { | ||||
|       return CRYPT_PK_NOT_PRIVATE; | ||||
|    } | ||||
|  | ||||
|    /* must be a private or public operation */ | ||||
|    if (which != PK_PRIVATE && which != PK_PUBLIC) { | ||||
|       return CRYPT_PK_INVALID_TYPE; | ||||
|    } | ||||
|  | ||||
|    /* init and copy into tmp */ | ||||
|    if ((err = mp_init_multi(&tmp, &tmpa, &tmpb, NULL)) != CRYPT_OK)                                    { return err; } | ||||
|    if ((err = mp_read_unsigned_bin(tmp, (unsigned char *)in, (int)inlen)) != CRYPT_OK)                 { goto error; } | ||||
|  | ||||
|    /* sanity check on the input */ | ||||
|    if (mp_cmp(key->N, tmp) == LTC_MP_LT) { | ||||
|       err = CRYPT_PK_INVALID_SIZE; | ||||
|       goto done; | ||||
|    } | ||||
|  | ||||
|    /* are we using the private exponent and is the key optimized? */ | ||||
|    if (which == PK_PRIVATE) { | ||||
|       /* tmpa = tmp^dP mod p */ | ||||
|       if ((err = mp_exptmod(tmp, key->dP, key->p, tmpa)) != CRYPT_OK)                               { goto error; } | ||||
|  | ||||
|       /* tmpb = tmp^dQ mod q */ | ||||
|       if ((err = mp_exptmod(tmp, key->dQ, key->q, tmpb)) != CRYPT_OK)                               { goto error; } | ||||
|  | ||||
|       /* tmp = (tmpa - tmpb) * qInv (mod p) */ | ||||
|       if ((err = mp_sub(tmpa, tmpb, tmp)) != CRYPT_OK)                                              { goto error; } | ||||
|       if ((err = mp_mulmod(tmp, key->qP, key->p, tmp)) != CRYPT_OK)                                 { goto error; } | ||||
|  | ||||
|       /* tmp = tmpb + q * tmp */ | ||||
|       if ((err = mp_mul(tmp, key->q, tmp)) != CRYPT_OK)                                             { goto error; } | ||||
|       if ((err = mp_add(tmp, tmpb, tmp)) != CRYPT_OK)                                               { goto error; } | ||||
|    } else { | ||||
|       /* exptmod it */ | ||||
|       if ((err = mp_exptmod(tmp, key->N, key->N, tmp)) != CRYPT_OK)                                 { goto error; } | ||||
|    } | ||||
|  | ||||
|    /* read it back */ | ||||
|    x = (unsigned long)mp_unsigned_bin_size(key->N); | ||||
|    if (x > *outlen) { | ||||
|       *outlen = x; | ||||
|       err = CRYPT_BUFFER_OVERFLOW; | ||||
|       goto done; | ||||
|    } | ||||
|  | ||||
|    /* this should never happen ... */ | ||||
|    if (mp_unsigned_bin_size(tmp) > mp_unsigned_bin_size(key->N)) { | ||||
|       err = CRYPT_ERROR; | ||||
|       goto done; | ||||
|    } | ||||
|    *outlen = x; | ||||
|  | ||||
|    /* convert it */ | ||||
|    zeromem(out, x); | ||||
|    if ((err = mp_to_unsigned_bin(tmp, out+(x-mp_unsigned_bin_size(tmp)))) != CRYPT_OK)               { goto error; } | ||||
|  | ||||
|    /* clean up and return */ | ||||
|    err = CRYPT_OK; | ||||
|    goto done; | ||||
| error: | ||||
| done: | ||||
|    mp_clear_multi(tmp, tmpa, tmpb, NULL); | ||||
|    return err; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										33
									
								
								thirdparty/libtomcrypt/pk/katja/katja_free.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								thirdparty/libtomcrypt/pk/katja/katja_free.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,33 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_free.c | ||||
|   Free an Katja key, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|   Free an Katja key from memory | ||||
|   @param key   The RSA key to free | ||||
| */ | ||||
| void katja_free(katja_key *key) | ||||
| { | ||||
|    LTC_ARGCHK(key != NULL); | ||||
|    mp_clear_multi( key->d,  key->N,  key->dQ,  key->dP, | ||||
|                    key->qP,  key->p,  key->q, key->pq, NULL); | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										79
									
								
								thirdparty/libtomcrypt/pk/katja/katja_import.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										79
									
								
								thirdparty/libtomcrypt/pk/katja/katja_import.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,79 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_import.c | ||||
|   Import a PKCS-style Katja key, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|   Import an KatjaPublicKey or KatjaPrivateKey [two-prime only, only support >= 1024-bit keys, defined in PKCS #1 v2.1] | ||||
|   @param in      The packet to import from | ||||
|   @param inlen   It's length (octets) | ||||
|   @param key     [out] Destination for newly imported key | ||||
|   @return CRYPT_OK if successful, upon error allocated memory is freed | ||||
| */ | ||||
| int katja_import(const unsigned char *in, unsigned long inlen, katja_key *key) | ||||
| { | ||||
|    int           err; | ||||
|    void         *zero; | ||||
|  | ||||
|    LTC_ARGCHK(in  != NULL); | ||||
|    LTC_ARGCHK(key != NULL); | ||||
|    LTC_ARGCHK(ltc_mp.name != NULL); | ||||
|  | ||||
|    /* init key */ | ||||
|    if ((err = mp_init_multi(&zero, &key->d, &key->N, &key->dQ, | ||||
|                             &key->dP, &key->qP, &key->p, &key->q, &key->pq, NULL)) != CRYPT_OK) { | ||||
|       return err; | ||||
|    } | ||||
|  | ||||
|    if ((err = der_decode_sequence_multi(in, inlen, | ||||
|                                   LTC_ASN1_INTEGER, 1UL, key->N, | ||||
|                                   LTC_ASN1_EOL,     0UL, NULL)) != CRYPT_OK) { | ||||
|       goto LBL_ERR; | ||||
|    } | ||||
|  | ||||
|    if (mp_cmp_d(key->N, 0) == LTC_MP_EQ) { | ||||
|       /* it's a private key */ | ||||
|       if ((err = der_decode_sequence_multi(in, inlen, | ||||
|                           LTC_ASN1_INTEGER, 1UL, zero, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->N, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->d, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->p, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->q, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->dP, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->dQ, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->qP, | ||||
|                           LTC_ASN1_INTEGER, 1UL, key->pq, | ||||
|                           LTC_ASN1_EOL,     0UL, NULL)) != CRYPT_OK) { | ||||
|          goto LBL_ERR; | ||||
|       } | ||||
|       key->type = PK_PRIVATE; | ||||
|    } else { | ||||
|       /* public we have N */ | ||||
|       key->type = PK_PUBLIC; | ||||
|    } | ||||
|    mp_clear(zero); | ||||
|    return CRYPT_OK; | ||||
| LBL_ERR: | ||||
|    mp_clear_multi(zero,    key->d, key->N, key->dQ, key->dP, | ||||
|                   key->qP, key->p, key->q, key->pq, NULL); | ||||
|    return err; | ||||
| } | ||||
|  | ||||
| #endif /* LTC_MRSA */ | ||||
|  | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
							
								
								
									
										99
									
								
								thirdparty/libtomcrypt/pk/katja/katja_make_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										99
									
								
								thirdparty/libtomcrypt/pk/katja/katja_make_key.c
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,99 @@ | ||||
| /* LibTomCrypt, modular cryptographic library -- Tom St Denis | ||||
|  * | ||||
|  * LibTomCrypt is a library that provides various cryptographic | ||||
|  * algorithms in a highly modular and flexible manner. | ||||
|  * | ||||
|  * The library is free for all purposes without any express | ||||
|  * guarantee it works. | ||||
|  */ | ||||
| #include "tomcrypt.h" | ||||
|  | ||||
| /** | ||||
|   @file katja_make_key.c | ||||
|   Katja key generation, Tom St Denis | ||||
| */ | ||||
|  | ||||
| #ifdef LTC_MKAT | ||||
|  | ||||
| /** | ||||
|    Create a Katja key | ||||
|    @param prng     An active PRNG state | ||||
|    @param wprng    The index of the PRNG desired | ||||
|    @param size     The size of the modulus (key size) desired (octets) | ||||
|    @param key      [out] Destination of a newly created private key pair | ||||
|    @return CRYPT_OK if successful, upon error all allocated ram is freed | ||||
| */ | ||||
| int katja_make_key(prng_state *prng, int wprng, int size, katja_key *key) | ||||
| { | ||||
|    void *p, *q, *tmp1, *tmp2; | ||||
|    int    err; | ||||
|  | ||||
|    LTC_ARGCHK(key != NULL); | ||||
|    LTC_ARGCHK(ltc_mp.name != NULL); | ||||
|  | ||||
|    if ((size < (MIN_KAT_SIZE/8)) || (size > (MAX_KAT_SIZE/8))) { | ||||
|       return CRYPT_INVALID_KEYSIZE; | ||||
|    } | ||||
|  | ||||
|    if ((err = prng_is_valid(wprng)) != CRYPT_OK) { | ||||
|       return err; | ||||
|    } | ||||
|  | ||||
|    if ((err = mp_init_multi(&p, &q, &tmp1, &tmp2, NULL)) != CRYPT_OK) { | ||||
|       return err; | ||||
|    } | ||||
|  | ||||
|    /* divide size by three  */ | ||||
|    size   = (((size << 3) / 3) + 7) >> 3; | ||||
|  | ||||
|    /* make prime "q" (we negate size to make q == 3 mod 4) */ | ||||
|    if ((err = rand_prime(q, -size, prng, wprng)) != CRYPT_OK)      { goto done; } | ||||
|    if ((err = mp_sub_d(q, 1, tmp1)) != CRYPT_OK)                   { goto done; } | ||||
|  | ||||
|    /* make prime "p" */ | ||||
|    do { | ||||
|       if ((err = rand_prime(p, size+1, prng, wprng)) != CRYPT_OK)  { goto done; } | ||||
|       if ((err = mp_gcd(p, tmp1, tmp2)) != CRYPT_OK)               { goto done; } | ||||
|    } while (mp_cmp_d(tmp2, 1) != LTC_MP_EQ); | ||||
|  | ||||
|    /* make key */ | ||||
|    if ((err = mp_init_multi(&key->d, &key->N, &key->dQ, &key->dP, | ||||
|                      &key->qP, &key->p, &key->q, &key->pq, NULL)) != CRYPT_OK) { | ||||
|       goto error; | ||||
|    } | ||||
|  | ||||
|    /* n=p^2q and 1/n mod pq */ | ||||
|    if ((err = mp_copy( p,  key->p)) != CRYPT_OK)                       { goto error2; } | ||||
|    if ((err = mp_copy( q,  key->q)) != CRYPT_OK)                       { goto error2; } | ||||
|    if ((err = mp_mul(key->p, key->q, key->pq)) != CRYPT_OK)            { goto error2; } /* tmp1 = pq  */ | ||||
|    if ((err = mp_mul(key->pq, key->p, key->N)) != CRYPT_OK)            { goto error2; } /* N = p^2q   */ | ||||
|    if ((err = mp_sub_d( p, 1,  tmp1)) != CRYPT_OK)                     { goto error2; } /* tmp1 = q-1 */ | ||||
|    if ((err = mp_sub_d( q, 1,  tmp2)) != CRYPT_OK)                     { goto error2; } /* tmp2 = p-1 */ | ||||
|    if ((err = mp_lcm(tmp1, tmp2, key->d)) != CRYPT_OK)                 { goto error2; } /* tmp1 = lcd(p-1,q-1) */ | ||||
|    if ((err = mp_invmod( key->N,  key->d,  key->d)) != CRYPT_OK)       { goto error2; } /* key->d = 1/N mod pq */ | ||||
|  | ||||
|    /* optimize for CRT now */ | ||||
|    /* find d mod q-1 and d mod p-1 */ | ||||
|    if ((err = mp_mod( key->d,  tmp1,  key->dP)) != CRYPT_OK)           { goto error2; } /* dP = d mod p-1 */ | ||||
|    if ((err = mp_mod( key->d,  tmp2,  key->dQ)) != CRYPT_OK)           { goto error2; } /* dQ = d mod q-1 */ | ||||
|    if ((err = mp_invmod( q,  p,  key->qP)) != CRYPT_OK)                { goto error2; } /* qP = 1/q mod p */ | ||||
|  | ||||
|    /* set key type (in this case it's CRT optimized) */ | ||||
|    key->type = PK_PRIVATE; | ||||
|  | ||||
|    /* return ok and free temps */ | ||||
|    err       = CRYPT_OK; | ||||
|    goto done; | ||||
| error2: | ||||
|    mp_clear_multi( key->d,  key->N,  key->dQ,  key->dP,  key->qP,  key->p,  key->q, key->pq, NULL); | ||||
| error: | ||||
| done: | ||||
|    mp_clear_multi( tmp2,  tmp1,  p,  q, NULL); | ||||
|    return err; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* ref:         HEAD -> master, tag: v1.18.2 */ | ||||
| /* git commit:  7e7eb695d581782f04b24dc444cbfde86af59853 */ | ||||
| /* commit time: 2018-07-01 22:49:01 +0200 */ | ||||
		Reference in New Issue
	
	Block a user