X-Git-Url: https://www.tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fsptps.h;h=0616ac7ae4a771e538ec2dd59547a4530da7f8af;hb=5ede437307cc3bbb20431f4b82f4a2ef79c9b746;hp=065c6a099d24d146a2120e4cf489b4d2005e88d0;hpb=483c5dcfb43719e5fd50902641252e28a04fd74e;p=tinc diff --git a/src/sptps.h b/src/sptps.h index 065c6a09..0616ac7a 100644 --- a/src/sptps.h +++ b/src/sptps.h @@ -40,11 +40,12 @@ #define SPTPS_SIG 2 // Waiting for a SIGnature record #define SPTPS_ACK 3 // Waiting for an ACKnowledgement record -typedef bool (*send_data_t)(void *handle, const char *data, size_t len); +typedef bool (*send_data_t)(void *handle, uint8_t type, const char *data, size_t len); typedef bool (*receive_record_t)(void *handle, uint8_t type, const char *data, uint16_t len); typedef struct sptps { bool initiator; + bool datagram; int state; char *inbuf; @@ -76,10 +77,11 @@ typedef struct sptps { receive_record_t receive_record; } sptps_t; -extern bool sptps_start(sptps_t *s, void *handle, bool initiator, ecdsa_t mykey, ecdsa_t hiskey, const char *label, size_t labellen, send_data_t send_data, receive_record_t receive_record); +extern bool sptps_start(sptps_t *s, void *handle, bool initiator, bool datagram, ecdsa_t mykey, ecdsa_t hiskey, const char *label, size_t labellen, send_data_t send_data, receive_record_t receive_record); extern bool sptps_stop(sptps_t *s); extern bool sptps_send_record(sptps_t *s, uint8_t type, const char *data, uint16_t len); extern bool sptps_receive_data(sptps_t *s, const char *data, size_t len); extern bool sptps_force_kex(sptps_t *s); +extern bool sptps_verify_datagram(sptps_t *s, const char *data, size_t len); #endif