aboutsummaryrefslogtreecommitdiff
path: root/src/core/crypto/onion_tap.h
blob: 78174b1fabfa2776119ebe2992fdac2fd2141fc3 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/* Copyright (c) 2001 Matej Pfajfar.
 * Copyright (c) 2001-2004, Roger Dingledine.
 * Copyright (c) 2004-2006, Roger Dingledine, Nick Mathewson.
 * Copyright (c) 2007-2020, The Tor Project, Inc. */
/* See LICENSE for licensing information */

/**
 * \file onion_tap.h
 * \brief Header file for onion_tap.c.
 **/

#ifndef TOR_ONION_TAP_H
#define TOR_ONION_TAP_H

#define TAP_ONIONSKIN_CHALLENGE_LEN (PKCS1_OAEP_PADDING_OVERHEAD+\
                                 CIPHER_KEY_LEN+\
                                 DH1024_KEY_LEN)
#define TAP_ONIONSKIN_REPLY_LEN (DH1024_KEY_LEN+DIGEST_LEN)

struct crypto_dh_t;
struct crypto_pk_t;

int onion_skin_TAP_create(struct crypto_pk_t *router_key,
                      struct crypto_dh_t **handshake_state_out,
                      char *onion_skin_out);

int onion_skin_TAP_server_handshake(const char *onion_skin,
                                struct crypto_pk_t *private_key,
                                struct crypto_pk_t *prev_private_key,
                                char *handshake_reply_out,
                                char *key_out,
                                size_t key_out_len);

int onion_skin_TAP_client_handshake(struct crypto_dh_t *handshake_state,
                                const char *handshake_reply,
                                char *key_out,
                                size_t key_out_len,
                                const char **msg_out);

#endif /* !defined(TOR_ONION_TAP_H) */