version 1.23, 2022/10/28 00:43:08 |
version 1.24, 2022/10/28 00:44:17 |
|
|
} |
} |
|
|
static int |
static int |
|
ssh_ecdsa_serialize_private(const struct sshkey *key, struct sshbuf *b, |
|
enum sshkey_serialize_rep opts) |
|
{ |
|
int r; |
|
|
|
if (!sshkey_is_cert(key)) { |
|
if ((r = ssh_ecdsa_serialize_public(key, b, opts)) != 0) |
|
return r; |
|
} |
|
if ((r = sshbuf_put_bignum2(b, |
|
EC_KEY_get0_private_key(key->ecdsa))) != 0) |
|
return r; |
|
return 0; |
|
} |
|
|
|
static int |
ssh_ecdsa_generate(struct sshkey *k, int bits) |
ssh_ecdsa_generate(struct sshkey *k, int bits) |
{ |
{ |
EC_KEY *private; |
EC_KEY *private; |
|
|
/* .equal = */ ssh_ecdsa_equal, |
/* .equal = */ ssh_ecdsa_equal, |
/* .ssh_serialize_public = */ ssh_ecdsa_serialize_public, |
/* .ssh_serialize_public = */ ssh_ecdsa_serialize_public, |
/* .ssh_deserialize_public = */ ssh_ecdsa_deserialize_public, |
/* .ssh_deserialize_public = */ ssh_ecdsa_deserialize_public, |
|
/* .ssh_serialize_private = */ ssh_ecdsa_serialize_private, |
/* .generate = */ ssh_ecdsa_generate, |
/* .generate = */ ssh_ecdsa_generate, |
/* .copy_public = */ ssh_ecdsa_copy_public, |
/* .copy_public = */ ssh_ecdsa_copy_public, |
/* .sign = */ ssh_ecdsa_sign, |
/* .sign = */ ssh_ecdsa_sign, |