2015-02-24 12:43:01 +00:00
|
|
|
#ifndef DROPBEAR_ECDSA_H_
|
|
|
|
#define DROPBEAR_ECDSA_H_
|
2013-04-13 16:50:03 +00:00
|
|
|
|
|
|
|
#include "includes.h"
|
|
|
|
#include "buffer.h"
|
2013-05-03 15:07:48 +00:00
|
|
|
#include "signkey.h"
|
2013-04-13 16:50:03 +00:00
|
|
|
|
2013-05-09 15:24:58 +00:00
|
|
|
#ifdef DROPBEAR_ECDSA
|
|
|
|
|
2013-11-12 15:02:32 +00:00
|
|
|
/* Prefer the larger size - it's fast anyway */
|
2013-10-31 14:49:15 +00:00
|
|
|
#if defined(DROPBEAR_ECC_521)
|
2013-04-28 15:17:43 +00:00
|
|
|
#define ECDSA_DEFAULT_SIZE 521
|
2013-10-31 14:49:15 +00:00
|
|
|
#elif defined(DROPBEAR_ECC_384)
|
|
|
|
#define ECDSA_DEFAULT_SIZE 384
|
|
|
|
#elif defined(DROPBEAR_ECC_256)
|
|
|
|
#define ECDSA_DEFAULT_SIZE 256
|
2013-04-28 15:17:43 +00:00
|
|
|
#else
|
|
|
|
#define ECDSA_DEFAULT_SIZE 0
|
|
|
|
#endif
|
|
|
|
|
2013-04-13 16:50:03 +00:00
|
|
|
ecc_key *gen_ecdsa_priv_key(unsigned int bit_size);
|
|
|
|
ecc_key *buf_get_ecdsa_pub_key(buffer* buf);
|
|
|
|
ecc_key *buf_get_ecdsa_priv_key(buffer *buf);
|
|
|
|
void buf_put_ecdsa_pub_key(buffer *buf, ecc_key *key);
|
|
|
|
void buf_put_ecdsa_priv_key(buffer *buf, ecc_key *key);
|
2013-05-03 15:07:48 +00:00
|
|
|
enum signkey_type ecdsa_signkey_type(ecc_key * key);
|
2013-04-13 16:50:03 +00:00
|
|
|
|
|
|
|
void buf_put_ecdsa_sign(buffer *buf, ecc_key *key, buffer *data_buf);
|
|
|
|
int buf_ecdsa_verify(buffer *buf, ecc_key *key, buffer *data_buf);
|
2013-11-06 16:18:52 +00:00
|
|
|
/* Returns 1 on success */
|
|
|
|
int signkey_is_ecdsa(enum signkey_type type);
|
2013-04-13 16:50:03 +00:00
|
|
|
|
2013-05-09 15:24:58 +00:00
|
|
|
#endif
|
|
|
|
|
2015-02-24 12:43:01 +00:00
|
|
|
#endif /* DROPBEAR_ECDSA_H_ */
|