diff options
| author | Dimitri Staessens <dimitri@ouroboros.rocks> | 2020-02-24 22:30:22 +0100 | 
|---|---|---|
| committer | Sander Vrijders <sander@ouroboros.rocks> | 2020-02-25 08:21:09 +0100 | 
| commit | fe6b60909d455abdac7885ceaba1097749e7aeb1 (patch) | |
| tree | ffd3f3c6a2f15a1af5b393d8a5c068304b29a636 /include | |
| parent | 11fbe2f998a39ca156e2c806fd78f2af781836a4 (diff) | |
| download | ouroboros-fe6b60909d455abdac7885ceaba1097749e7aeb1.tar.gz ouroboros-fe6b60909d455abdac7885ceaba1097749e7aeb1.zip | |
lib, ipcpd: piggyback ECDHE on flow allocation
The initial implementation for the ECDHE key exchange was doing the
key exchange after a flow was established. The public keys are now
sent allowg on the flow allocation messages, so that an encrypted
tunnel can be created within 1 RTT. The flow allocation steps had to
be extended to pass the opaque data ('piggybacking').
Signed-off-by: Dimitri Staessens <dimitri@ouroboros.rocks>
Signed-off-by: Sander Vrijders <sander@ouroboros.rocks>
Diffstat (limited to 'include')
| -rw-r--r-- | include/ouroboros/ipcp-dev.h | 12 | 
1 files changed, 8 insertions, 4 deletions
| diff --git a/include/ouroboros/ipcp-dev.h b/include/ouroboros/ipcp-dev.h index 59e594fe..d60e0b45 100644 --- a/include/ouroboros/ipcp-dev.h +++ b/include/ouroboros/ipcp-dev.h @@ -30,10 +30,14 @@ int  ipcp_create_r(int result);  int  ipcp_flow_req_arr(const uint8_t * dst,                         size_t          len, -                       qosspec_t       qs); - -int  ipcp_flow_alloc_reply(int fd, -                           int response); +                       qosspec_t       qs, +                       const void *    data, +                       size_t          dlen); + +int  ipcp_flow_alloc_reply(int          fd, +                           int          response, +                           const void * data, +                           size_t       len);  int  ipcp_flow_read(int                   fd,                      struct shm_du_buff ** sdb); | 
