X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?a=blobdiff_plain;f=secnet.h;h=cdeadad1d2cc8e171f3168d9baf53dc84da36696;hb=13b8fbf4548f3457b02afd36e9284d39839d6f85;hp=818e94653ba2b7e52c322cfb4fecba4f4750aa84;hpb=e3f1375768e53a28a4b5e7b965f2f9f3472aab42;p=secnet.git diff --git a/secnet.h b/secnet.h index 818e946..cdeadad 100644 --- a/secnet.h +++ b/secnet.h @@ -46,6 +46,7 @@ #define MAX_PEER_ADDRS 5 /* send at most this many copies; honour at most that many addresses */ +struct hash_if; struct comm_if; struct comm_addr; @@ -363,8 +364,8 @@ extern init_module log_module; #define CL_PURE 0 #define CL_RESOLVER 1 #define CL_RANDOMSRC 2 -#define CL_RSAPUBKEY 3 -#define CL_RSAPRIVKEY 4 +#define CL_SIGPUBKEY 3 +#define CL_SIGPRIVKEY 4 #define CL_COMM 5 #define CL_IPIF 6 #define CL_LOG 7 @@ -377,6 +378,11 @@ extern init_module log_module; struct buffer_if; +struct alg_msg_data { + uint8_t *sigstart; + int32_t siglen; +}; + /* PURE closure requires no interface */ /* RESOLVER interface */ @@ -411,21 +417,30 @@ struct random_if { random_fn *generate; }; -/* RSAPUBKEY interface */ +/* SIGPUBKEY interface */ -typedef bool_t rsa_checksig_fn(void *st, uint8_t *data, int32_t datalen, - cstring_t signature); -struct rsapubkey_if { +typedef void sig_sethash_fn(void *st, struct hash_if *hash); +typedef bool_t sig_unpick_fn(void *sst, struct buffer_if *msg, + struct alg_msg_data *sig); +typedef bool_t sig_checksig_fn(void *st, uint8_t *data, int32_t datalen, + const struct alg_msg_data *sig); +struct sigpubkey_if { void *st; - rsa_checksig_fn *check; + sig_sethash_fn *sethash; /* must be called before check, if non-0 */ + sig_unpick_fn *unpick; + sig_checksig_fn *check; }; -/* RSAPRIVKEY interface */ +/* SIGPRIVKEY interface */ -typedef string_t rsa_makesig_fn(void *st, uint8_t *data, int32_t datalen); -struct rsaprivkey_if { +/* Appends the signature to msg. + * Can fail and returnn False, eg if the buffer is too small. */ +typedef bool_t sig_makesig_fn(void *st, uint8_t *data, int32_t datalen, + struct buffer_if *msg); +struct sigprivkey_if { void *st; - rsa_makesig_fn *sign; + sig_sethash_fn *sethash; /* must be called before sign, if non-0 */ + sig_makesig_fn *sign; }; /* COMM interface */ @@ -574,7 +589,7 @@ struct transform_inst_if { struct transform_if { void *st; - int capab_transformnum; + int capab_bit; int32_t keylen; /* <<< INT_MAX */ transform_createinstance_fn *create; };