diff options
author | Andreas Schneider <asn@cryptomilk.org> | 2011-06-14 22:33:58 +0200 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2011-06-15 18:27:05 +0200 |
commit | 27cedaa0b6705d01a99dfe2b072f59b1fe1fb198 (patch) | |
tree | 6692e1cc38eab10e3e5d536043e7d03806a6cfed | |
parent | 2be90be7409219efa3577ac97c56f47a4d664fd8 (diff) | |
download | libssh-27cedaa0b6705d01a99dfe2b072f59b1fe1fb198.tar.gz libssh-27cedaa0b6705d01a99dfe2b072f59b1fe1fb198.tar.xz libssh-27cedaa0b6705d01a99dfe2b072f59b1fe1fb198.zip |
pki: Make ssh_key_is_public() a public function.
-rw-r--r-- | include/libssh/libssh.h | 2 | ||||
-rw-r--r-- | include/libssh/pki.h | 1 | ||||
-rw-r--r-- | src/pki.c | 15 |
3 files changed, 17 insertions, 1 deletions
diff --git a/include/libssh/libssh.h b/include/libssh/libssh.h index 3453177..45e1112 100644 --- a/include/libssh/libssh.h +++ b/include/libssh/libssh.h @@ -422,6 +422,8 @@ LIBSSH_API void ssh_key_free (ssh_key key); LIBSSH_API enum ssh_keytypes_e ssh_key_type(ssh_key key); LIBSSH_API const char *ssh_key_type_to_char(enum ssh_keytypes_e type); LIBSSH_API enum ssh_keytypes_e ssh_key_type_from_name(const char *name); +LIBSSH_API int ssh_key_is_public(ssh_key k); + LIBSSH_API int ssh_pki_import_privkey_base64(ssh_key key, ssh_session session, const char *b64_key, const char *passphrase); LIBSSH_API int ssh_userauth_pki_pubkey(ssh_session session, const char *username, diff --git a/include/libssh/pki.h b/include/libssh/pki.h index 06c933c..d51a358 100644 --- a/include/libssh/pki.h +++ b/include/libssh/pki.h @@ -39,7 +39,6 @@ struct ssh_key_struct { #endif }; -#define ssh_key_is_public(k) (k && k->flags & SSH_KEY_FLAG_PUBLIC) #define ssh_key_is_private(k) (k && k->flags & SSH_KEY_FLAG_PRIVATE) void ssh_key_clean (ssh_key key); @@ -151,6 +151,21 @@ enum ssh_keytypes_e ssh_key_type_from_name(const char *name) { } /** + * @brief Check if the key has/is a public key. + * + * @param[in] k The key to check. + * + * @return 1 if it is a public key, 0 if not. + */ +int ssh_key_is_public(ssh_key k) { + if (k == NULL) { + return 0; + } + + return (k->flags & SSH_KEY_FLAG_PUBLIC); +} + +/** * @brief import a key from a file * @param[out] key the ssh_key to update * @param[in] session The SSH Session to use. If a key decryption callback is set, it will |