summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/libssh/libssh.h3
-rw-r--r--include/libssh/pki.h3
-rw-r--r--src/known_hosts.c6
-rw-r--r--src/pki.c30
4 files changed, 39 insertions, 3 deletions
diff --git a/include/libssh/libssh.h b/include/libssh/libssh.h
index 3453177..e6f0847 100644
--- a/include/libssh/libssh.h
+++ b/include/libssh/libssh.h
@@ -422,6 +422,9 @@ 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_key_is_private(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..8d3ef0c 100644
--- a/include/libssh/pki.h
+++ b/include/libssh/pki.h
@@ -39,9 +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);
int ssh_key_import_private(ssh_key key, ssh_session session,
const char *filename, const char *passphrase);
diff --git a/src/known_hosts.c b/src/known_hosts.c
index 7c935a8..7ec73de 100644
--- a/src/known_hosts.c
+++ b/src/known_hosts.c
@@ -474,6 +474,12 @@ int ssh_is_server_known(ssh_session session) {
if (match) {
/* We got a match. Now check the key type */
if (strcmp(session->current_crypto->server_pubkey_type, type) != 0) {
+ ssh_log(session,
+ SSH_LOG_PACKET,
+ "ssh_is_server_known: server type [%s] doesn't match the "
+ "type [%s] in known_hosts file",
+ session->current_crypto->server_pubkey_type,
+ type);
/* Different type. We don't override the known_changed error which is
* more important */
if (ret != SSH_SERVER_KNOWN_CHANGED)
diff --git a/src/pki.c b/src/pki.c
index fe3b13b..fd30ee4 100644
--- a/src/pki.c
+++ b/src/pki.c
@@ -151,6 +151,36 @@ 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 Check if the key is a private key.
+ *
+ * @param[in] k The key to check.
+ *
+ * @return 1 if it is a private key, 0 if not.
+ */
+int ssh_key_is_private(ssh_key k) {
+ if (k == NULL) {
+ return 0;
+ }
+
+ return (k->flags & SSH_KEY_FLAG_PRIVATE);
+}
+
+/**
* @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