39 lines
		
	
	
		
			774 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
		
			774 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;
 | |
| }
 | 
