forked from mirrors/nixpkgs
38 lines
773 B
C
38 lines
773 B
C
|
#include <stdint.h>
|
||
|
#include <string.h>
|
||
|
#include <stdio.h>
|
||
|
#include <openssl/evp.h>
|
||
|
|
||
|
void hextorb(uint8_t* hex, uint8_t* rb)
|
||
|
{
|
||
|
while(sscanf(hex, "%2x", rb) == 1)
|
||
|
{
|
||
|
hex += 2;
|
||
|
rb += 1;
|
||
|
}
|
||
|
*rb = '\0';
|
||
|
}
|
||
|
|
||
|
int main(int argc, char** argv)
|
||
|
{
|
||
|
uint8_t k_user[2048];
|
||
|
uint8_t salt[2048];
|
||
|
uint8_t key[4096];
|
||
|
|
||
|
uint32_t key_length = atoi(argv[1]);
|
||
|
uint32_t iteration_count = atoi(argv[2]);
|
||
|
|
||
|
hextorb(argv[3], salt);
|
||
|
uint32_t salt_length = strlen(argv[3]) / 2;
|
||
|
|
||
|
fgets(k_user, 2048, stdin);
|
||
|
uint32_t k_user_length = strlen(k_user);
|
||
|
if(k_user[k_user_length - 1] == '\n') {
|
||
|
k_user[k_user_length - 1] = '\0';
|
||
|
}
|
||
|
|
||
|
PKCS5_PBKDF2_HMAC(k_user, k_user_length, salt, salt_length, iteration_count, EVP_sha512(), key_length, key);
|
||
|
fwrite(key, 1, key_length, stdout);
|
||
|
|
||
|
return 0;
|
||
|
}
|