Reverted new protocol

This commit is contained in:
Erik Ekman 2008-12-06 22:12:18 +00:00
parent 5450372a75
commit 33b5ef9bf9
2 changed files with 49 additions and 90 deletions

View file

@ -30,20 +30,7 @@
#define QUERY_NAME_SIZE 256 #define QUERY_NAME_SIZE 256
#define MAKE_HEADER(c,u) ((((c) & 0xf) << 4) | ((u) & 0xf)) #define DATAHEADER_TOTLEN 2
#define HEADER_GET_COMMAND(h) (((h) & 0xf0) >> 4)
#define HEADER_GET_USERID(h) ((h) & 0x0f)
enum header_command {
CMD_VERSION = 0,
CMD_LOGIN,
CMD_CASE_CHECK,
CMD_CODEC_SWITCH,
CMD_DATA,
CMD_PING
};
#define DATAHEADER_TOTLEN 3
#define MAKE_DATAHEADER(last,compressed,fragno) \ #define MAKE_DATAHEADER(last,compressed,fragno) \
((((last) & 0x1) << 7) | (((compressed) & 0x1) << 6) | ((fragno) & 0x3f)) ((((last) & 0x1) << 7) | (((compressed) & 0x1) << 6) | ((fragno) & 0x3f))

View file

@ -69,7 +69,10 @@ static char userid;
/* DNS id for next packet */ /* DNS id for next packet */
static uint16_t chunkid; static uint16_t chunkid;
/* The encoder used for packets /* Base32 encoder used for non-data packets */
static struct encoder *b32;
/* The encoder used for data packets
* Defaults to Base32, can be changed after handshake */ * Defaults to Base32, can be changed after handshake */
static struct encoder *dataenc; static struct encoder *dataenc;
@ -102,11 +105,13 @@ send_query(int fd, char *hostname)
} }
static void static void
send_packet(int fd, const char *data, const size_t datalen) send_packet(int fd, char cmd, const char *data, const size_t datalen)
{ {
char buf[4096]; char buf[4096];
/* Encode the data and add the topdomain */
build_hostname(buf, sizeof(buf), data, datalen, topdomain, dataenc); buf[0] = cmd;
build_hostname(buf + 1, sizeof(buf) - 1, data, datalen, topdomain, b32);
send_query(fd, buf); send_query(fd, buf);
} }
@ -115,6 +120,7 @@ build_hostname(char *buf, size_t buflen,
const char *data, const size_t datalen, const char *data, const size_t datalen,
const char *topdomain, struct encoder *encoder) const char *topdomain, struct encoder *encoder)
{ {
int encsize;
size_t space; size_t space;
char *b; char *b;
@ -125,7 +131,7 @@ build_hostname(char *buf, size_t buflen,
memset(buf, 0, buflen); memset(buf, 0, buflen);
encoder->encode(buf, &space, data, datalen); encsize = encoder->encode(buf, &space, data, datalen);
if (!encoder->places_dots()) if (!encoder->places_dots())
inline_dotify(buf, buflen); inline_dotify(buf, buflen);
@ -203,8 +209,6 @@ tunnel_tun(int tun_fd, int dns_fd)
packet.sentlen = 0; packet.sentlen = 0;
packet.offset = 0; packet.offset = 0;
packet.len = outlen; packet.len = outlen;
packet.seqno++;
packet.fragment = 0;
send_chunk(dns_fd); send_chunk(dns_fd);
@ -283,51 +287,26 @@ tunnel(int tun_fd, int dns_fd)
static void static void
send_chunk(int fd) send_chunk(int fd)
{ {
char buf[2048]; char hex[] = "0123456789ABCDEF";
char header[64]; char buf[4096];
char headerenc[64];
int avail; int avail;
int code;
char *p; char *p;
int rawblock;
int headerblocks;
int pkt_encoffset;
int buf_encoffset;
int sentlen;
int i;
size_t enclen;
rawblock = dataenc->blocksize_raw();
headerblocks = 1;
while (headerblocks * rawblock < DATAHEADER_TOTLEN) {
headerblocks++;
}
rawblock *= headerblocks;
pkt_encoffset = rawblock - DATAHEADER_TOTLEN;
buf_encoffset = dataenc->blocksize_encoded() * headerblocks;
/* Encode all of the message except the first headerblocks block */
p = packet.data; p = packet.data;
p += packet.offset; p += packet.offset;
avail = packet.len - packet.offset + pkt_encoffset; avail = packet.len - packet.offset;
sentlen = build_hostname(buf + buf_encoffset, sizeof(buf) - buf_encoffset,
&p[pkt_encoffset], avail, topdomain, dataenc);
packet.sentlen = sentlen + pkt_encoffset; packet.sentlen = build_hostname(buf + 1, sizeof(buf) - 1, p, avail, topdomain, dataenc);
if (packet.sentlen == avail)
code = 1;
else
code = 0;
code |= (userid << 1);
buf[0] = hex[code];
/* Then encode the header and maybe some pkt data */
header[0] = MAKE_HEADER(CMD_DATA, userid);
header[1] = packet.seqno;
header[2] = MAKE_DATAHEADER(avail == sentlen, 1, packet.fragment++);
for (i = 0; i < pkt_encoffset; i++) {
header[i + DATAHEADER_TOTLEN] = p[i];
}
/* Encode the first part, copy it into the buffer */
dataenc->encode(headerenc, &enclen, header, DATAHEADER_TOTLEN + pkt_encoffset);
for (i = 0; i < enclen; i++) {
buf[i] = headerenc[i];
}
send_query(fd, buf); send_query(fd, buf);
} }
@ -337,7 +316,7 @@ send_login(int fd, char *login, int len)
char data[19]; char data[19];
memset(data, 0, sizeof(data)); memset(data, 0, sizeof(data));
data[0] = MAKE_HEADER(CMD_LOGIN, userid); data[0] = userid;
memcpy(&data[1], login, MIN(len, 16)); memcpy(&data[1], login, MIN(len, 16));
data[17] = (rand_seed >> 8) & 0xff; data[17] = (rand_seed >> 8) & 0xff;
@ -345,7 +324,7 @@ send_login(int fd, char *login, int len)
rand_seed++; rand_seed++;
send_packet(fd, data, sizeof(data)); send_packet(fd, 'L', data, sizeof(data));
} }
static void static void
@ -359,32 +338,31 @@ send_ping(int fd)
packet.len = 0; packet.len = 0;
} }
data[0] = MAKE_HEADER(CMD_PING, userid); data[0] = userid;
data[1] = (rand_seed >> 8) & 0xff; data[1] = (rand_seed >> 8) & 0xff;
data[2] = (rand_seed >> 0) & 0xff; data[2] = (rand_seed >> 0) & 0xff;
rand_seed++; rand_seed++;
send_packet(fd, data, sizeof(data)); send_packet(fd, 'P', data, sizeof(data));
} }
static void static void
send_version(int fd, uint32_t version) send_version(int fd, uint32_t version)
{ {
char data[7]; char data[6];
data[0] = MAKE_HEADER(CMD_VERSION, 0xf); data[0] = (version >> 24) & 0xff;
data[1] = (version >> 24) & 0xff; data[1] = (version >> 16) & 0xff;
data[2] = (version >> 16) & 0xff; data[2] = (version >> 8) & 0xff;
data[3] = (version >> 8) & 0xff; data[3] = (version >> 0) & 0xff;
data[4] = (version >> 0) & 0xff;
data[5] = (rand_seed >> 8) & 0xff; data[4] = (rand_seed >> 8) & 0xff;
data[6] = (rand_seed >> 0) & 0xff; data[5] = (rand_seed >> 0) & 0xff;
rand_seed++; rand_seed++;
send_packet(fd, data, sizeof(data)); send_packet(fd, 'V', data, sizeof(data));
} }
static void static void
@ -393,15 +371,7 @@ send_case_check(int fd)
/* The '+' plus character is not allowed according to RFC. /* The '+' plus character is not allowed according to RFC.
* Expect to get SERVFAIL or similar if it is rejected. * Expect to get SERVFAIL or similar if it is rejected.
*/ */
char buf[512] = "__zZ+-aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyY1234."; char buf[512] = "zZ+-aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyY1234.";
char header = MAKE_HEADER(CMD_CASE_CHECK, userid);
char enc[5];
unsigned enclen;
dataenc->encode(enc, &enclen, &header, 1);
/* Encode header into start of message */
buf[0] = enc[0];
buf[1] = enc[1];
strncat(buf, topdomain, 512 - strlen(buf)); strncat(buf, topdomain, 512 - strlen(buf));
send_query(fd, buf); send_query(fd, buf);
@ -410,12 +380,16 @@ send_case_check(int fd)
static void static void
send_codec_switch(int fd, int userid, int bits) send_codec_switch(int fd, int userid, int bits)
{ {
char data[2]; char buf[512] = "S00.";
if (userid >= 0 && userid < 9) {
data[0] = MAKE_HEADER(CMD_VERSION, 0xf); buf[1] += userid;
data[1] = bits & 0xff; }
if (bits >= 0 && bits < 9) {
send_packet(fd, data, sizeof(data)); buf[2] += bits;
}
strncat(buf, topdomain, 512 - strlen(buf));
send_query(fd, buf);
} }
static int static int
@ -731,10 +705,8 @@ main(int argc, char **argv)
device = NULL; device = NULL;
chunkid = 0; chunkid = 0;
b32 = get_base32_encoder();
dataenc = get_base32_encoder(); dataenc = get_base32_encoder();
packet.seqno = 0;
packet.fragment = 0;
#if !defined(BSD) && !defined(__GLIBC__) #if !defined(BSD) && !defined(__GLIBC__)
__progname = strrchr(argv[0], '/'); __progname = strrchr(argv[0], '/');