2016-11-03 15:22:17 +00:00
|
|
|
/**
|
|
|
|
* an "Identity"
|
|
|
|
*/
|
2016-10-31 16:13:42 +00:00
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
2016-10-31 19:13:20 +00:00
|
|
|
#include <string.h>
|
2016-10-31 16:13:42 +00:00
|
|
|
|
|
|
|
#include "ipfs/repo/config/identity.h"
|
2016-11-03 15:22:17 +00:00
|
|
|
#include "libp2p/crypto/rsa.h"
|
2016-10-31 16:13:42 +00:00
|
|
|
|
|
|
|
/***
|
|
|
|
* public methods
|
|
|
|
*/
|
|
|
|
|
|
|
|
/***
|
2016-11-02 18:09:38 +00:00
|
|
|
* initializes a new Identity
|
2016-10-31 16:13:42 +00:00
|
|
|
* @param identity the identity to fill
|
|
|
|
* @param num_bits_for_keypair the number of bits for the keypair
|
|
|
|
* @returns true(1) on success, false(0) otherwise
|
|
|
|
*/
|
|
|
|
int repo_config_identity_new(struct Identity* identity, unsigned long num_bits_for_keypair) {
|
|
|
|
if (num_bits_for_keypair < 1024)
|
|
|
|
return 0;
|
2016-10-31 22:19:27 +00:00
|
|
|
// generate the private key (& public)
|
2016-11-14 02:01:51 +00:00
|
|
|
if (!libp2p_crypto_rsa_generate_keypair( &(identity->private_key), num_bits_for_keypair))
|
2016-10-31 16:13:42 +00:00
|
|
|
return 0;
|
2016-10-31 22:19:27 +00:00
|
|
|
|
2016-11-10 21:36:34 +00:00
|
|
|
// now the private key (in DER format) is in identity->private_key->der;
|
|
|
|
// and the public key (also in DER format) is in identity->private_key->public_key_der;
|
|
|
|
|
|
|
|
//TODO: the public key needs to be "pretty printed" and put in a multihash
|
|
|
|
|
2016-11-02 18:09:38 +00:00
|
|
|
return 1;
|
2016-10-31 16:13:42 +00:00
|
|
|
}
|
2016-11-10 13:28:51 +00:00
|
|
|
|
|
|
|
int repo_config_identity_free(struct Identity* identity) {
|
2016-11-10 21:36:34 +00:00
|
|
|
if (identity->private_key.public_key_der != NULL)
|
|
|
|
free(identity->private_key.public_key_der);
|
2016-11-10 13:28:51 +00:00
|
|
|
if (identity->private_key.der != NULL)
|
|
|
|
free(identity->private_key.der);
|
|
|
|
return 0;
|
|
|
|
}
|