diff options
author | Andreas Schneider <asn@cryptomilk.org> | 2011-08-20 18:08:37 +0200 |
---|---|---|
committer | Andreas Schneider <asn@cryptomilk.org> | 2011-08-20 18:37:43 +0200 |
commit | ce41747faef799e8723840c0cd640ba44bbcc834 (patch) | |
tree | 8e2b95b3b5ac231480bf458990a48c6f75b35dc3 /src | |
parent | 8acc3dd3afeff6b9f4c2327c9b2d0bc0f0eafb18 (diff) | |
download | libssh-ce41747faef799e8723840c0cd640ba44bbcc834.tar.gz libssh-ce41747faef799e8723840c0cd640ba44bbcc834.tar.xz libssh-ce41747faef799e8723840c0cd640ba44bbcc834.zip |
pki: Introduce ssh_signature.
Diffstat (limited to 'src')
-rw-r--r-- | src/pki.c | 43 |
1 files changed, 43 insertions, 0 deletions
@@ -229,6 +229,49 @@ int ssh_key_is_private(const ssh_key k) { return (k->flags & SSH_KEY_FLAG_PRIVATE); } +ssh_signature ssh_signature_new(void) +{ + struct ssh_signature_struct *sig; + + sig = malloc(sizeof(struct ssh_signature_struct)); + if (sig == NULL) { + return NULL; + } + ZERO_STRUCTP(sig); + + return sig; +} + +void ssh_signature_free(ssh_signature sig) +{ + if (sig == NULL) { + return; + } + + switch(sig->type) { + case SSH_KEYTYPE_DSS: +#ifdef HAVE_LIBGCRYPT + gcry_sexp_release(sig->dsa_sig); +#elif defined HAVE_LIBCRYPTO + DSA_SIG_free(sig->dsa_sig); +#endif + break; + case SSH_KEYTYPE_RSA: + case SSH_KEYTYPE_RSA1: +#ifdef HAVE_LIBGCRYPT + gcry_sexp_release(sig->rsa_sig); +#elif defined HAVE_LIBCRYPTO + SAFE_FREE(sig->rsa_sig); +#endif + break; + case SSH_KEYTYPE_ECDSA: + case SSH_KEYTYPE_UNKNOWN: + break; + } + + SAFE_FREE(sig); +} + /** * @brief import a base64 formated key from a memory c-string * |