1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Rename all public/private key load/save functions.

Now they have names that are more consistent (no more userkey_this but
that_userkey); a bit shorter; and, most importantly, all the current
functions end in _f to indicate that they deal with keys stored in
disk files. I'm about to add a second set of entry points that deal
with keys via the more general BinarySource / BinarySink interface,
which will sit alongside these with a different suffix.
This commit is contained in:
Simon Tatham 2020-01-05 10:28:45 +00:00
parent 8a87f4509c
commit e5fbed7632
9 changed files with 78 additions and 87 deletions

View File

@ -750,9 +750,9 @@ int main(int argc, char **argv)
* Find out whether the input key is encrypted. * Find out whether the input key is encrypted.
*/ */
if (intype == SSH_KEYTYPE_SSH1) if (intype == SSH_KEYTYPE_SSH1)
encrypted = rsa_ssh1_encrypted(infilename, &origcomment); encrypted = rsa1_encrypted_f(infilename, &origcomment);
else if (intype == SSH_KEYTYPE_SSH2) else if (intype == SSH_KEYTYPE_SSH2)
encrypted = ssh2_userkey_encrypted(infilename, &origcomment); encrypted = ppk_encrypted_f(infilename, &origcomment);
else else
encrypted = import_encrypted(infilename, intype, &origcomment); encrypted = import_encrypted(infilename, intype, &origcomment);
@ -797,7 +797,7 @@ int main(int argc, char **argv)
blob = strbuf_new(); blob = strbuf_new();
ret = rsa_ssh1_loadpub(infilename, BinarySink_UPCAST(blob), ret = rsa1_loadpub_f(infilename, BinarySink_UPCAST(blob),
&origcomment, &error); &origcomment, &error);
BinarySource_BARE_INIT(src, blob->u, blob->len); BinarySource_BARE_INIT(src, blob->u, blob->len);
get_rsa_ssh1_pub(src, ssh1key, RSA_SSH1_EXPONENT_FIRST); get_rsa_ssh1_pub(src, ssh1key, RSA_SSH1_EXPONENT_FIRST);
@ -809,8 +809,7 @@ int main(int argc, char **argv)
ssh1key->q = NULL; ssh1key->q = NULL;
ssh1key->iqmp = NULL; ssh1key->iqmp = NULL;
} else { } else {
ret = rsa_ssh1_loadkey( ret = rsa1_load_f(infilename, ssh1key, old_passphrase, &error);
infilename, ssh1key, old_passphrase, &error);
} }
if (ret > 0) if (ret > 0)
error = NULL; error = NULL;
@ -825,7 +824,8 @@ int main(int argc, char **argv)
sfree(origcomment); sfree(origcomment);
origcomment = NULL; origcomment = NULL;
ssh2blob = strbuf_new(); ssh2blob = strbuf_new();
if (ssh2_userkey_loadpub(infilename, &ssh2alg, BinarySink_UPCAST(ssh2blob), if (ppk_loadpub_f(infilename, &ssh2alg,
BinarySink_UPCAST(ssh2blob),
&origcomment, &error)) { &origcomment, &error)) {
const ssh_keyalg *alg = find_pubkey_alg(ssh2alg); const ssh_keyalg *alg = find_pubkey_alg(ssh2alg);
if (alg) if (alg)
@ -839,8 +839,7 @@ int main(int argc, char **argv)
} }
sfree(ssh2alg); sfree(ssh2alg);
} else { } else {
ssh2key = ssh2_load_userkey(infilename, old_passphrase, ssh2key = ppk_load_f(infilename, old_passphrase, &error);
&error);
} }
if ((ssh2key && ssh2key != SSH2_WRONG_PASSPHRASE) || ssh2blob) if ((ssh2key && ssh2key != SSH2_WRONG_PASSPHRASE) || ssh2blob)
error = NULL; error = NULL;
@ -953,14 +952,14 @@ int main(int argc, char **argv)
random_ref(); /* we'll need a few random bytes in the save file */ random_ref(); /* we'll need a few random bytes in the save file */
if (sshver == 1) { if (sshver == 1) {
assert(ssh1key); assert(ssh1key);
ret = rsa_ssh1_savekey(outfilename, ssh1key, new_passphrase); ret = rsa1_save_f(outfilename, ssh1key, new_passphrase);
if (!ret) { if (!ret) {
fprintf(stderr, "puttygen: unable to save SSH-1 private key\n"); fprintf(stderr, "puttygen: unable to save SSH-1 private key\n");
return 1; return 1;
} }
} else { } else {
assert(ssh2key); assert(ssh2key);
ret = ssh2_save_userkey(outfilename, ssh2key, new_passphrase); ret = ppk_save_f(outfilename, ssh2key, new_passphrase);
if (!ret) { if (!ret) {
fprintf(stderr, "puttygen: unable to save SSH-2 private key\n"); fprintf(stderr, "puttygen: unable to save SSH-2 private key\n");
return 1; return 1;

View File

@ -1036,7 +1036,8 @@ int pageant_add_keyfile(Filename *filename, const char *passphrase,
int i, nkeys, keylistlen; int i, nkeys, keylistlen;
if (type == SSH_KEYTYPE_SSH1) { if (type == SSH_KEYTYPE_SSH1) {
if (!rsa_ssh1_loadpub(filename, BinarySink_UPCAST(blob), NULL, &error)) { if (!rsa1_loadpub_f(filename, BinarySink_UPCAST(blob),
NULL, &error)) {
*retstr = dupprintf("Couldn't load private key (%s)", error); *retstr = dupprintf("Couldn't load private key (%s)", error);
strbuf_free(blob); strbuf_free(blob);
return PAGEANT_ACTION_FAILURE; return PAGEANT_ACTION_FAILURE;
@ -1047,7 +1048,7 @@ int pageant_add_keyfile(Filename *filename, const char *passphrase,
* length, so add a placeholder here to fill in * length, so add a placeholder here to fill in
* afterwards */ * afterwards */
put_uint32(blob, 0); put_uint32(blob, 0);
if (!ssh2_userkey_loadpub(filename, NULL, BinarySink_UPCAST(blob), if (!ppk_loadpub_f(filename, NULL, BinarySink_UPCAST(blob),
NULL, &error)) { NULL, &error)) {
*retstr = dupprintf("Couldn't load private key (%s)", error); *retstr = dupprintf("Couldn't load private key (%s)", error);
strbuf_free(blob); strbuf_free(blob);
@ -1145,9 +1146,9 @@ int pageant_add_keyfile(Filename *filename, const char *passphrase,
error = NULL; error = NULL;
if (type == SSH_KEYTYPE_SSH1) if (type == SSH_KEYTYPE_SSH1)
needs_pass = rsa_ssh1_encrypted(filename, &comment); needs_pass = rsa1_encrypted_f(filename, &comment);
else else
needs_pass = ssh2_userkey_encrypted(filename, &comment); needs_pass = ppk_encrypted_f(filename, &comment);
attempts = 0; attempts = 0;
if (type == SSH_KEYTYPE_SSH1) if (type == SSH_KEYTYPE_SSH1)
rkey = snew(RSAKey); rkey = snew(RSAKey);
@ -1183,9 +1184,9 @@ int pageant_add_keyfile(Filename *filename, const char *passphrase,
this_passphrase = ""; this_passphrase = "";
if (type == SSH_KEYTYPE_SSH1) if (type == SSH_KEYTYPE_SSH1)
ret = rsa_ssh1_loadkey(filename, rkey, this_passphrase, &error); ret = rsa1_load_f(filename, rkey, this_passphrase, &error);
else { else {
skey = ssh2_load_userkey(filename, this_passphrase, &error); skey = ppk_load_f(filename, this_passphrase, &error);
if (skey == SSH2_WRONG_PASSPHRASE) if (skey == SSH2_WRONG_PASSPHRASE)
ret = -1; ret = -1;
else if (!skey) else if (!skey)

31
ssh.h
View File

@ -1147,13 +1147,6 @@ mp_int *dh_create_e(dh_ctx *, int nbits);
const char *dh_validate_f(dh_ctx *, mp_int *f); const char *dh_validate_f(dh_ctx *, mp_int *f);
mp_int *dh_find_K(dh_ctx *, mp_int *f); mp_int *dh_find_K(dh_ctx *, mp_int *f);
bool rsa_ssh1_encrypted(const Filename *filename, char **comment);
int rsa_ssh1_loadpub(const Filename *filename, BinarySink *bs,
char **commentptr, const char **errorstr);
int rsa_ssh1_loadkey(const Filename *filename, RSAKey *key,
const char *passphrase, const char **errorstr);
bool rsa_ssh1_savekey(const Filename *filename, RSAKey *key, char *passphrase);
static inline bool is_base64_char(char c) static inline bool is_base64_char(char c)
{ {
return ((c >= '0' && c <= '9') || return ((c >= '0' && c <= '9') ||
@ -1168,18 +1161,26 @@ extern void base64_encode_atom(const unsigned char *data, int n, char *out);
extern void base64_encode(FILE *fp, const unsigned char *data, int datalen, extern void base64_encode(FILE *fp, const unsigned char *data, int datalen,
int cpl); int cpl);
/* ssh2_load_userkey can return this as an error */ /* ppk_load_* can return this as an error */
extern ssh2_userkey ssh2_wrong_passphrase; extern ssh2_userkey ssh2_wrong_passphrase;
#define SSH2_WRONG_PASSPHRASE (&ssh2_wrong_passphrase) #define SSH2_WRONG_PASSPHRASE (&ssh2_wrong_passphrase)
bool ssh2_userkey_encrypted(const Filename *filename, char **comment); bool ppk_encrypted_f(const Filename *filename, char **comment);
ssh2_userkey *ssh2_load_userkey( bool rsa1_encrypted_f(const Filename *filename, char **comment);
const Filename *filename, const char *passphrase, const char **errorstr);
bool ssh2_userkey_loadpub( ssh2_userkey *ppk_load_f(const Filename *filename, const char *passphrase,
const Filename *filename, char **algorithm, BinarySink *bs, const char **errorstr);
int rsa1_load_f(const Filename *filename, RSAKey *key,
const char *passphrase, const char **errorstr);
bool ppk_save_f(const Filename *filename, ssh2_userkey *key, char *passphrase);
bool rsa1_save_f(const Filename *filename, RSAKey *key, char *passphrase);
bool ppk_loadpub_f(const Filename *filename, char **algorithm, BinarySink *bs,
char **commentptr, const char **errorstr); char **commentptr, const char **errorstr);
bool ssh2_save_userkey( int rsa1_loadpub_f(const Filename *filename, BinarySink *bs,
const Filename *filename, ssh2_userkey *key, char *passphrase); char **commentptr, const char **errorstr);
const ssh_keyalg *find_pubkey_alg(const char *name); const ssh_keyalg *find_pubkey_alg(const char *name);
const ssh_keyalg *find_pubkey_alg_len(ptrlen name); const ssh_keyalg *find_pubkey_alg_len(ptrlen name);

View File

@ -451,13 +451,13 @@ static void ssh1_login_process_queue(PacketProtocolLayer *ppl)
keytype == SSH_KEYTYPE_SSH1_PUBLIC) { keytype == SSH_KEYTYPE_SSH1_PUBLIC) {
const char *error; const char *error;
s->publickey_blob = strbuf_new(); s->publickey_blob = strbuf_new();
if (rsa_ssh1_loadpub(s->keyfile, if (rsa1_loadpub_f(s->keyfile,
BinarySink_UPCAST(s->publickey_blob), BinarySink_UPCAST(s->publickey_blob),
&s->publickey_comment, &error)) { &s->publickey_comment, &error)) {
s->privatekey_available = (keytype == SSH_KEYTYPE_SSH1); s->privatekey_available = (keytype == SSH_KEYTYPE_SSH1);
if (!s->privatekey_available) if (!s->privatekey_available)
ppl_logevent("Key file contains public key only"); ppl_logevent("Key file contains public key only");
s->privatekey_encrypted = rsa_ssh1_encrypted(s->keyfile, NULL); s->privatekey_encrypted = rsa1_encrypted_f(s->keyfile, NULL);
} else { } else {
ppl_logevent("Unable to load key (%s)", error); ppl_logevent("Unable to load key (%s)", error);
ppl_printf("Unable to load key file \"%s\" (%s)\r\n", ppl_printf("Unable to load key file \"%s\" (%s)\r\n",
@ -683,8 +683,7 @@ static void ssh1_login_process_queue(PacketProtocolLayer *ppl)
/* /*
* Try decrypting key with passphrase. * Try decrypting key with passphrase.
*/ */
retd = rsa_ssh1_loadkey( retd = rsa1_load_f(s->keyfile, &s->key, passphrase, &error);
s->keyfile, &s->key, passphrase, &error);
if (passphrase) { if (passphrase) {
smemclr(passphrase, strlen(passphrase)); smemclr(passphrase, strlen(passphrase));
sfree(passphrase); sfree(passphrase);
@ -702,7 +701,7 @@ static void ssh1_login_process_queue(PacketProtocolLayer *ppl)
got_passphrase = false; got_passphrase = false;
/* and try again */ /* and try again */
} else { } else {
unreachable("unexpected return from rsa_ssh1_loadkey()"); unreachable("unexpected return from rsa1_load_f()");
} }
} }

View File

@ -269,15 +269,13 @@ static void ssh2_userauth_process_queue(PacketProtocolLayer *ppl)
keytype == SSH_KEYTYPE_SSH2_PUBLIC_OPENSSH) { keytype == SSH_KEYTYPE_SSH2_PUBLIC_OPENSSH) {
const char *error; const char *error;
s->publickey_blob = strbuf_new(); s->publickey_blob = strbuf_new();
if (ssh2_userkey_loadpub(s->keyfile, if (ppk_loadpub_f(s->keyfile, &s->publickey_algorithm,
&s->publickey_algorithm,
BinarySink_UPCAST(s->publickey_blob), BinarySink_UPCAST(s->publickey_blob),
&s->publickey_comment, &error)) { &s->publickey_comment, &error)) {
s->privatekey_available = (keytype == SSH_KEYTYPE_SSH2); s->privatekey_available = (keytype == SSH_KEYTYPE_SSH2);
if (!s->privatekey_available) if (!s->privatekey_available)
ppl_logevent("Key file contains public key only"); ppl_logevent("Key file contains public key only");
s->privatekey_encrypted = s->privatekey_encrypted = ppk_encrypted_f(s->keyfile, NULL);
ssh2_userkey_encrypted(s->keyfile, NULL);
} else { } else {
ppl_logevent("Unable to load key (%s)", error); ppl_logevent("Unable to load key (%s)", error);
ppl_printf("Unable to load key file \"%s\" (%s)\r\n", ppl_printf("Unable to load key file \"%s\" (%s)\r\n",
@ -893,7 +891,7 @@ static void ssh2_userauth_process_queue(PacketProtocolLayer *ppl)
/* /*
* Try decrypting the key. * Try decrypting the key.
*/ */
key = ssh2_load_userkey(s->keyfile, passphrase, &error); key = ppk_load_f(s->keyfile, passphrase, &error);
if (passphrase) { if (passphrase) {
/* burn the evidence */ /* burn the evidence */
smemclr(passphrase, strlen(passphrase)); smemclr(passphrase, strlen(passphrase));

View File

@ -150,7 +150,7 @@ static int rsa_ssh1_load_main(FILE * fp, RSAKey *key, bool pub_only,
return ret; return ret;
} }
int rsa_ssh1_loadkey(const Filename *filename, RSAKey *key, int rsa1_load_f(const Filename *filename, RSAKey *key,
const char *passphrase, const char **errorstr) const char *passphrase, const char **errorstr)
{ {
FILE *fp; FILE *fp;
@ -194,7 +194,7 @@ int rsa_ssh1_loadkey(const Filename *filename, RSAKey *key,
* See whether an RSA key is encrypted. Return its comment field as * See whether an RSA key is encrypted. Return its comment field as
* well. * well.
*/ */
bool rsa_ssh1_encrypted(const Filename *filename, char **comment) bool rsa1_encrypted_f(const Filename *filename, char **comment)
{ {
FILE *fp; FILE *fp;
char buf[64]; char buf[64];
@ -222,7 +222,7 @@ bool rsa_ssh1_encrypted(const Filename *filename, char **comment)
* Read the public part of an SSH-1 RSA key from a file (public or * Read the public part of an SSH-1 RSA key from a file (public or
* private), and generate its public blob in exponent-first order. * private), and generate its public blob in exponent-first order.
*/ */
int rsa_ssh1_loadpub(const Filename *filename, BinarySink *bs, int rsa1_loadpub_f(const Filename *filename, BinarySink *bs,
char **commentptr, const char **errorstr) char **commentptr, const char **errorstr)
{ {
FILE *fp; FILE *fp;
@ -319,8 +319,7 @@ int rsa_ssh1_loadpub(const Filename *filename, BinarySink *bs,
/* /*
* Save an RSA key file. Return true on success. * Save an RSA key file. Return true on success.
*/ */
bool rsa_ssh1_savekey(const Filename *filename, RSAKey *key, bool rsa1_save_f(const Filename *filename, RSAKey *key, char *passphrase)
char *passphrase)
{ {
strbuf *buf = strbuf_new_nm(); strbuf *buf = strbuf_new_nm();
int estart; int estart;
@ -606,8 +605,8 @@ static int userkey_parse_line_counter(const char *text)
return -1; return -1;
} }
ssh2_userkey *ssh2_load_userkey( ssh2_userkey *ppk_load_f(const Filename *filename, const char *passphrase,
const Filename *filename, const char *passphrase, const char **errorstr) const char **errorstr)
{ {
FILE *fp; FILE *fp;
char header[40], *b, *encryption, *comment, *mac; char header[40], *b, *encryption, *comment, *mac;
@ -1056,8 +1055,7 @@ bool openssh_loadpub(FILE *fp, char **algorithm,
return false; return false;
} }
bool ssh2_userkey_loadpub(const Filename *filename, char **algorithm, bool ppk_loadpub_f(const Filename *filename, char **algorithm, BinarySink *bs,
BinarySink *bs,
char **commentptr, const char **errorstr) char **commentptr, const char **errorstr)
{ {
FILE *fp; FILE *fp;
@ -1159,7 +1157,7 @@ bool ssh2_userkey_loadpub(const Filename *filename, char **algorithm,
return false; return false;
} }
bool ssh2_userkey_encrypted(const Filename *filename, char **commentptr) bool ppk_encrypted_f(const Filename *filename, char **commentptr)
{ {
FILE *fp; FILE *fp;
char header[40], *b, *comment; char header[40], *b, *comment;
@ -1247,8 +1245,7 @@ void base64_encode(FILE *fp, const unsigned char *data, int datalen, int cpl)
fputc('\n', fp); fputc('\n', fp);
} }
bool ssh2_save_userkey( bool ppk_save_f(const Filename *filename, ssh2_userkey *key, char *passphrase)
const Filename *filename, ssh2_userkey *key, char *passphrase)
{ {
FILE *fp; FILE *fp;
strbuf *pub_blob, *priv_blob; strbuf *pub_blob, *priv_blob;

View File

@ -537,7 +537,7 @@ struct pageant_pubkey *find_key(const char *string, char **retstr)
const char *error; const char *error;
key_in.blob = strbuf_new(); key_in.blob = strbuf_new();
if (!rsa_ssh1_loadpub(fn, BinarySink_UPCAST(key_in.blob), if (!rsa1_loadpub_f(fn, BinarySink_UPCAST(key_in.blob),
NULL, &error)) { NULL, &error)) {
strbuf_free(key_in.blob); strbuf_free(key_in.blob);
key_in.blob = NULL; key_in.blob = NULL;
@ -567,7 +567,7 @@ struct pageant_pubkey *find_key(const char *string, char **retstr)
const char *error; const char *error;
key_in.blob = strbuf_new(); key_in.blob = strbuf_new();
if (!ssh2_userkey_loadpub(fn, NULL, BinarySink_UPCAST(key_in.blob), if (!ppk_loadpub_f(fn, NULL, BinarySink_UPCAST(key_in.blob),
NULL, &error)) { NULL, &error)) {
strbuf_free(key_in.blob); strbuf_free(key_in.blob);
key_in.blob = NULL; key_in.blob = NULL;

View File

@ -581,7 +581,7 @@ int main(int argc, char **argv)
if (keytype == SSH_KEYTYPE_SSH2) { if (keytype == SSH_KEYTYPE_SSH2) {
ssh2_userkey *uk; ssh2_userkey *uk;
ssh_key *key; ssh_key *key;
uk = ssh2_load_userkey(keyfile, NULL, &error); uk = ppk_load_f(keyfile, NULL, &error);
filename_free(keyfile); filename_free(keyfile);
if (!uk || !uk->key) { if (!uk || !uk->key) {
fprintf(stderr, "%s: unable to load host key '%s': " fprintf(stderr, "%s: unable to load host key '%s': "
@ -615,7 +615,7 @@ int main(int argc, char **argv)
exit(1); exit(1);
} }
hostkey1 = snew(RSAKey); hostkey1 = snew(RSAKey);
if (!rsa_ssh1_loadkey(keyfile, hostkey1, NULL, &error)) { if (!rsa1_load_f(keyfile, hostkey1, NULL, &error)) {
fprintf(stderr, "%s: unable to load host key '%s': " fprintf(stderr, "%s: unable to load host key '%s': "
"%s\n", appname, val, error); "%s\n", appname, val, error);
exit(1); exit(1);
@ -647,8 +647,7 @@ int main(int argc, char **argv)
ssc.rsa_kex_key = snew(RSAKey); ssc.rsa_kex_key = snew(RSAKey);
} }
if (!rsa_ssh1_loadkey(keyfile, ssc.rsa_kex_key, if (!rsa1_load_f(keyfile, ssc.rsa_kex_key, NULL, &error)) {
NULL, &error)) {
fprintf(stderr, "%s: unable to load RSA kex key '%s': " fprintf(stderr, "%s: unable to load RSA kex key '%s': "
"%s\n", appname, val, error); "%s\n", appname, val, error);
exit(1); exit(1);
@ -669,7 +668,7 @@ int main(int argc, char **argv)
struct AuthPolicy_ssh2_pubkey *node; struct AuthPolicy_ssh2_pubkey *node;
void *blob; void *blob;
if (!ssh2_userkey_loadpub(keyfile, NULL, BinarySink_UPCAST(sb), if (!ppk_loadpub_f(keyfile, NULL, BinarySink_UPCAST(sb),
NULL, &error)) { NULL, &error)) {
fprintf(stderr, "%s: unable to load user key '%s': " fprintf(stderr, "%s: unable to load user key '%s': "
"%s\n", appname, val, error); "%s\n", appname, val, error);
@ -690,7 +689,7 @@ int main(int argc, char **argv)
BinarySource src[1]; BinarySource src[1];
struct AuthPolicy_ssh1_pubkey *node; struct AuthPolicy_ssh1_pubkey *node;
if (!rsa_ssh1_loadpub(keyfile, BinarySink_UPCAST(sb), if (!rsa1_loadpub_f(keyfile, BinarySink_UPCAST(sb),
NULL, &error)) { NULL, &error)) {
fprintf(stderr, "%s: unable to load user key '%s': " fprintf(stderr, "%s: unable to load user key '%s': "
"%s\n", appname, val, error); "%s\n", appname, val, error);

View File

@ -672,9 +672,9 @@ void load_key_file(HWND hwnd, struct MainDlgState *state,
comment = NULL; comment = NULL;
passphrase = NULL; passphrase = NULL;
if (realtype == SSH_KEYTYPE_SSH1) if (realtype == SSH_KEYTYPE_SSH1)
needs_pass = rsa_ssh1_encrypted(filename, &comment); needs_pass = rsa1_encrypted_f(filename, &comment);
else if (realtype == SSH_KEYTYPE_SSH2) else if (realtype == SSH_KEYTYPE_SSH2)
needs_pass = ssh2_userkey_encrypted(filename, &comment); needs_pass = ppk_encrypted_f(filename, &comment);
else else
needs_pass = import_encrypted(filename, realtype, &comment); needs_pass = import_encrypted(filename, realtype, &comment);
do { do {
@ -699,14 +699,13 @@ void load_key_file(HWND hwnd, struct MainDlgState *state,
passphrase = dupstr(""); passphrase = dupstr("");
if (type == SSH_KEYTYPE_SSH1) { if (type == SSH_KEYTYPE_SSH1) {
if (realtype == type) if (realtype == type)
ret = rsa_ssh1_loadkey( ret = rsa1_load_f(filename, &newkey1, passphrase, &errmsg);
filename, &newkey1, passphrase, &errmsg);
else else
ret = import_ssh1(filename, realtype, &newkey1, ret = import_ssh1(filename, realtype, &newkey1,
passphrase, &errmsg); passphrase, &errmsg);
} else { } else {
if (realtype == type) if (realtype == type)
newkey2 = ssh2_load_userkey(filename, passphrase, &errmsg); newkey2 = ppk_load_f(filename, passphrase, &errmsg);
else else
newkey2 = import_ssh2(filename, realtype, passphrase, &errmsg); newkey2 = import_ssh2(filename, realtype, passphrase, &errmsg);
if (newkey2 == SSH2_WRONG_PASSPHRASE) if (newkey2 == SSH2_WRONG_PASSPHRASE)
@ -1309,9 +1308,8 @@ static INT_PTR CALLBACK MainDlgProc(HWND hwnd, UINT msg,
ret = export_ssh2(fn, type, &state->ssh2key, ret = export_ssh2(fn, type, &state->ssh2key,
*passphrase ? passphrase : NULL); *passphrase ? passphrase : NULL);
else else
ret = ssh2_save_userkey(fn, &state->ssh2key, ret = ppk_save_f(fn, &state->ssh2key,
*passphrase ? passphrase : *passphrase ? passphrase : NULL);
NULL);
filename_free(fn); filename_free(fn);
} else { } else {
Filename *fn = filename_from_str(filename); Filename *fn = filename_from_str(filename);
@ -1319,8 +1317,7 @@ static INT_PTR CALLBACK MainDlgProc(HWND hwnd, UINT msg,
ret = export_ssh1(fn, type, &state->key, ret = export_ssh1(fn, type, &state->key,
*passphrase ? passphrase : NULL); *passphrase ? passphrase : NULL);
else else
ret = rsa_ssh1_savekey( ret = rsa1_save_f(fn, &state->key,
fn, &state->key,
*passphrase ? passphrase : NULL); *passphrase ? passphrase : NULL);
filename_free(fn); filename_free(fn);
} }