mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 09:58:01 +00:00
5b30e6f7a6
Similarly to 'utils', I've moved all the stuff in the crypto build-time library into a source directory of its own, and while I'm at it, split up the monolithic sshauxcrypt.c into its various unrelated parts. This is also an opportunity to remove the annoying 'ssh' prefix from the front of the file names, and give several of them less cryptic names.
39 lines
957 B
C
39 lines
957 B
C
/*
|
|
* Convenience functions to encrypt and decrypt the standard format
|
|
* for SSH-1 private key files. This uses triple-DES in SSH-1 style
|
|
* (three separate CBC layers), but the same key is used for the first
|
|
* and third layers.CBC mode.
|
|
*/
|
|
|
|
#include "ssh.h"
|
|
|
|
static ssh_cipher *des3_pubkey_cipher(const void *vkey)
|
|
{
|
|
ssh_cipher *c = ssh_cipher_new(&ssh_3des_ssh1);
|
|
uint8_t keys3[24], iv[8];
|
|
|
|
memcpy(keys3, vkey, 16);
|
|
memcpy(keys3 + 16, vkey, 8);
|
|
ssh_cipher_setkey(c, keys3);
|
|
smemclr(keys3, sizeof(keys3));
|
|
|
|
memset(iv, 0, 8);
|
|
ssh_cipher_setiv(c, iv);
|
|
|
|
return c;
|
|
}
|
|
|
|
void des3_decrypt_pubkey(const void *vkey, void *vblk, int len)
|
|
{
|
|
ssh_cipher *c = des3_pubkey_cipher(vkey);
|
|
ssh_cipher_decrypt(c, vblk, len);
|
|
ssh_cipher_free(c);
|
|
}
|
|
|
|
void des3_encrypt_pubkey(const void *vkey, void *vblk, int len)
|
|
{
|
|
ssh_cipher *c = des3_pubkey_cipher(vkey);
|
|
ssh_cipher_encrypt(c, vblk, len);
|
|
ssh_cipher_free(c);
|
|
}
|