tor_multipath_voip/src/algo_dup2.c

80 lines
2.4 KiB
C
Raw Normal View History

2019-05-06 10:02:25 +00:00
#include "proxy.h"
#include "algo_utils.h"
struct dup2_ctx {
uint16_t recv_id;
uint16_t emit_id;
};
void algo_dup2_init(struct evt_core_ctx* ctx, struct algo_ctx* app_ctx, struct algo_params* ap) {
app_ctx->misc = malloc(sizeof(struct dup2_ctx));
if (app_ctx->misc == NULL) {
perror("malloc failed in algo dup2 init");
exit(EXIT_FAILURE);
}
memset(app_ctx->misc, 0, sizeof(struct dup2_ctx));
}
int algo_dup2_on_stream(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) {
char url[256];
struct evt_core_fdinfo *to_fdinfo = NULL;
struct algo_ctx* app_ctx = fdinfo->cat->app_ctx;
// Check that we didn't already received the packet
struct dup2_ctx* dup2c = app_ctx->misc;
2019-05-14 09:23:23 +00:00
if (ring_ge(dup2c->recv_id, bp->ip.ap.fmt.content.clear.id)) {
2019-05-06 12:52:57 +00:00
mv_buffer_rtof(app_ctx, fdinfo);
2019-05-06 10:02:25 +00:00
return 0;
2019-05-06 12:52:57 +00:00
}
2019-05-14 09:23:23 +00:00
dup2c->recv_id = bp->ip.ap.fmt.content.clear.id;
2019-05-06 10:02:25 +00:00
// 1. Find destination
2019-05-14 09:23:23 +00:00
sprintf(url, "udp:write:127.0.0.1:%d", bp->ip.ap.fmt.content.clear.port);
2019-05-06 10:02:25 +00:00
to_fdinfo = evt_core_get_from_url (ctx, url);
if (to_fdinfo == NULL) {
fprintf(stderr, "No fd for URL %s in tcp-read. Dropping packet :( \n", url);
mv_buffer_wtof (app_ctx, fdinfo);
return 1;
}
// 2. Move buffer
mv_buffer_rtow (app_ctx, fdinfo, to_fdinfo);
main_on_udp_write(ctx, to_fdinfo);
return 0;
}
int algo_dup2_on_datagram(struct evt_core_ctx* ctx, struct evt_core_fdinfo* fdinfo, struct buffer_packet* bp) {
struct evt_core_fdinfo *to_fdinfo = NULL;
struct algo_ctx* app_ctx = fdinfo->cat->app_ctx;
struct dup2_ctx* dup2c = app_ctx->misc;
2019-05-14 09:23:23 +00:00
bp->ip.ap.fmt.content.clear.id = dup2c->emit_id;
2019-05-06 10:02:25 +00:00
dup2c->emit_id = dup2c->emit_id + 1;
2019-05-06 13:01:42 +00:00
struct evt_core_cat* cat = evt_core_get_from_cat (ctx, "tcp-write");
2019-05-09 13:33:27 +00:00
for (int i = 0; i < app_ctx->ap.links; i++) {
2019-05-06 10:02:25 +00:00
// 1. A whole packet has been read, we will find someone to write it
to_fdinfo = cat->socklist->len > i ? g_array_index(cat->socklist, struct evt_core_fdinfo*, i) : NULL;
2019-05-06 10:02:25 +00:00
if (to_fdinfo == NULL) {
2019-05-06 13:03:53 +00:00
fprintf(stderr, "No fd for cat %s in udp-read.\n", cat->name);
2019-05-06 12:52:57 +00:00
continue;
2019-05-06 10:02:25 +00:00
}
// 2. We move the buffer and notify the target
2019-05-06 12:52:57 +00:00
dup_buffer_tow (app_ctx, bp, to_fdinfo);
2019-05-06 10:02:25 +00:00
main_on_tcp_write(ctx, to_fdinfo);
}
2019-05-06 12:52:57 +00:00
// 3. Release the buffer
mv_buffer_rtof (app_ctx, fdinfo);
2019-05-06 10:02:25 +00:00
return 0;
}
int algo_dup2_on_err(struct evt_core_ctx *ctx, struct evt_core_fdinfo *fdinfo) {
// We do nothing
return 1;
}