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:
parent
8a87f4509c
commit
e5fbed7632
19
cmdgen.c
19
cmdgen.c
@ -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;
|
||||||
|
13
pageant.c
13
pageant.c
@ -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
31
ssh.h
@ -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);
|
||||||
|
|
||||||
|
@ -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()");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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));
|
||||||
|
21
sshpubk.c
21
sshpubk.c
@ -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;
|
||||||
|
@ -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;
|
||||||
|
@ -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);
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user