config
This commit is contained in:
parent
2a75d25632
commit
b22811eca2
10 changed files with 75 additions and 16 deletions
|
@ -349,6 +349,11 @@ static bool config_read_caa_record(char* data, CAARecord* record) {
|
|||
return true;
|
||||
}
|
||||
|
||||
static bool config_read_cmd_record(char* data, CMDRecord* record) {
|
||||
record->command = data;
|
||||
return true;
|
||||
}
|
||||
|
||||
static bool config_read_record_data(char* data, Record* record) {
|
||||
switch (record->type) {
|
||||
case UNKOWN:
|
||||
|
@ -374,6 +379,8 @@ static bool config_read_record_data(char* data, Record* record) {
|
|||
return config_read_srv_record(data, &record->data.srv);
|
||||
case CAA:
|
||||
return config_read_caa_record(data, &record->data.caa);
|
||||
case CMD:
|
||||
return config_read_cmd_record(data, &record->data.cmd);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
|
|
@ -43,6 +43,8 @@ ResultCode rescode_from_id(uint8_t id) {
|
|||
}
|
||||
}
|
||||
|
||||
#define MAX(var, max) var = var > max ? max : var;
|
||||
|
||||
void read_header(PacketBuffer* buffer, Header* header) {
|
||||
// memset(header, 0, sizeof(Header));
|
||||
header->id = buffer_read_short(buffer);
|
||||
|
|
|
@ -1,34 +1,49 @@
|
|||
#include <stdbool.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
#include "packet.h"
|
||||
#include "buffer.h"
|
||||
#include "header.h"
|
||||
#include "question.h"
|
||||
#include "record.h"
|
||||
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
void read_packet(PacketBuffer* buffer, Packet* packet) {
|
||||
read_header(buffer, &packet->header);
|
||||
|
||||
packet->questions = malloc(sizeof(Question) * packet->header.questions);
|
||||
for(uint16_t i = 0; i < packet->header.questions; i++) {
|
||||
read_question(buffer, &packet->questions[i]);
|
||||
if (!read_question(buffer, &packet->questions[i])) {
|
||||
i--;
|
||||
packet->header.questions--;
|
||||
}
|
||||
}
|
||||
|
||||
packet->answers = malloc(sizeof(Record) * packet->header.answers);
|
||||
for(uint16_t i = 0; i < packet->header.answers; i++) {
|
||||
read_record(buffer, &packet->answers[i]);
|
||||
if (!read_record(buffer, &packet->answers[i])) {
|
||||
i--;
|
||||
packet->header.answers--;
|
||||
}
|
||||
}
|
||||
|
||||
packet->authorities = malloc(sizeof(Record) * packet->header.authoritative_entries);
|
||||
for(uint16_t i = 0; i < packet->header.authoritative_entries; i++) {
|
||||
read_record(buffer, &packet->authorities[i]);
|
||||
if (!read_record(buffer, &packet->authorities[i])) {
|
||||
i--;
|
||||
packet->header.authoritative_entries--;
|
||||
}
|
||||
}
|
||||
|
||||
packet->resources = malloc(sizeof(Record) * packet->header.resource_entries);
|
||||
for(uint16_t i = 0; i < packet->header.resource_entries; i++) {
|
||||
read_record(buffer, &packet->resources[i]);
|
||||
if (!read_record(buffer, &packet->resources[i])) {
|
||||
i--;
|
||||
packet->header.resource_entries--;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -6,6 +6,8 @@
|
|||
#include "record.h"
|
||||
#include "../server/addr.h"
|
||||
|
||||
#include <stdbool.h>
|
||||
|
||||
typedef struct {
|
||||
Header header;
|
||||
Question* questions;
|
||||
|
|
|
@ -1,21 +1,28 @@
|
|||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
#include "question.h"
|
||||
#include "buffer.h"
|
||||
#include "record.h"
|
||||
#include "../io/log.h"
|
||||
|
||||
void read_question(PacketBuffer* buffer, Question* question) {
|
||||
bool read_question(PacketBuffer* buffer, Question* question) {
|
||||
buffer_read_qname(buffer, &question->domain);
|
||||
|
||||
uint16_t qtype_num = buffer_read_short(buffer);
|
||||
record_from_id(qtype_num, &question->qtype);
|
||||
question->cls = buffer_read_short(buffer);
|
||||
|
||||
if (question->qtype == UNKOWN) {
|
||||
free(question->domain);
|
||||
return false;
|
||||
}
|
||||
|
||||
INIT_LOG_BUFFER(log)
|
||||
LOGONLY(print_question(question, log);)
|
||||
TRACE("Reading question: %s", log);
|
||||
return true;
|
||||
}
|
||||
|
||||
void write_question(PacketBuffer* buffer, Question* question) {
|
||||
|
@ -85,6 +92,8 @@ void print_question(Question* question, char* buffer) {
|
|||
case CAA:
|
||||
APPEND(buffer, "CAA ");
|
||||
break;
|
||||
case CMD:
|
||||
APPEND(buffer, "CMD ");
|
||||
break;
|
||||
}
|
||||
APPEND(buffer, "%.*s",
|
||||
|
|
|
@ -9,7 +9,7 @@ typedef struct {
|
|||
uint16_t cls;
|
||||
} Question;
|
||||
|
||||
void read_question(PacketBuffer* buffer, Question* question);
|
||||
bool read_question(PacketBuffer* buffer, Question* question);
|
||||
void write_question(PacketBuffer* buffer, Question* question);
|
||||
void free_question(Question* question);
|
||||
void print_question(Question* question, char* buffer);
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
#include <stdbool.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
@ -28,6 +29,8 @@ uint16_t record_to_id(RecordType type) {
|
|||
return 33;
|
||||
case CAA:
|
||||
return 257;
|
||||
case CMD:
|
||||
return 1000;
|
||||
default:
|
||||
return 0;
|
||||
}
|
||||
|
@ -65,6 +68,9 @@ void record_from_id(uint16_t i, RecordType* type) {
|
|||
case 257:
|
||||
*type = CAA;
|
||||
break;
|
||||
case 1000:
|
||||
*type = CMD;
|
||||
break;
|
||||
default:
|
||||
*type = UNKOWN;
|
||||
}
|
||||
|
@ -172,7 +178,7 @@ static void read_caa_record(PacketBuffer* buffer, Record* record, int header_pos
|
|||
record->data.caa = data;
|
||||
}
|
||||
|
||||
void read_record(PacketBuffer* buffer, Record* record) {
|
||||
bool read_record(PacketBuffer* buffer, Record* record) {
|
||||
buffer_read_qname(buffer, &record->domain);
|
||||
|
||||
uint16_t qtype_num = buffer_read_short(buffer);
|
||||
|
@ -217,12 +223,14 @@ void read_record(PacketBuffer* buffer, Record* record) {
|
|||
break;
|
||||
default:
|
||||
buffer_step(buffer, record->len);
|
||||
return;
|
||||
free(record->domain);
|
||||
return false;
|
||||
}
|
||||
|
||||
INIT_LOG_BUFFER(log)
|
||||
LOGONLY(print_record(record, log);)
|
||||
TRACE("Reading record: %s", log);
|
||||
return true;
|
||||
}
|
||||
|
||||
static void write_a_record(PacketBuffer* buffer, Record* record) {
|
||||
|
@ -536,5 +544,10 @@ void print_record(Record* record, char* buffer) {
|
|||
record->data.caa.value + 1
|
||||
);
|
||||
break;
|
||||
case CMD:
|
||||
APPEND(buffer, "CMD (%s)",
|
||||
record->data.cmd.command
|
||||
);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -3,6 +3,7 @@
|
|||
#include "buffer.h"
|
||||
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
|
||||
typedef enum {
|
||||
UNKOWN,
|
||||
|
@ -15,7 +16,8 @@ typedef enum {
|
|||
TXT, // 16
|
||||
AAAA, // 28
|
||||
SRV, // 33
|
||||
CAA // 257
|
||||
CAA, // 257
|
||||
CMD // 1000
|
||||
} RecordType;
|
||||
|
||||
uint16_t record_to_id(RecordType type);
|
||||
|
@ -75,6 +77,10 @@ typedef struct {
|
|||
uint8_t* value;
|
||||
} CAARecord;
|
||||
|
||||
typedef struct {
|
||||
char* command;
|
||||
} CMDRecord;
|
||||
|
||||
typedef struct {
|
||||
uint32_t ttl;
|
||||
uint16_t cls;
|
||||
|
@ -92,10 +98,11 @@ typedef struct {
|
|||
AAAARecord aaaa;
|
||||
SRVRecord srv;
|
||||
CAARecord caa;
|
||||
CMDRecord cmd;
|
||||
} data;
|
||||
} Record;
|
||||
|
||||
void read_record(PacketBuffer* buffer, Record* record);
|
||||
bool read_record(PacketBuffer* buffer, Record* record);
|
||||
void write_record(PacketBuffer* buffer, Record* record);
|
||||
void free_record(Record* record);
|
||||
void print_record(Record* record, char* buffer);
|
||||
|
|
|
@ -117,16 +117,17 @@ static bool read_tcp(Connection* connection, Packet* packet) {
|
|||
&connection->sock.tcp,
|
||||
&len,
|
||||
sizeof(uint16_t)
|
||||
) < 0) {
|
||||
) < 2) {
|
||||
return false;
|
||||
}
|
||||
len = ntohs(len);
|
||||
|
||||
uint8_t buffer[len];
|
||||
if ( read_tcp_stream(
|
||||
if (read_tcp_stream(
|
||||
&connection->sock.tcp,
|
||||
buffer,
|
||||
len
|
||||
) < 0) {
|
||||
) < len) {
|
||||
return false;
|
||||
}
|
||||
|
||||
|
|
|
@ -91,6 +91,7 @@ static void* server_listen(void* arg) {
|
|||
free_connection(&connection);
|
||||
continue;
|
||||
}
|
||||
pthread_detach(thread);
|
||||
}
|
||||
|
||||
return NULL;
|
||||
|
@ -120,6 +121,8 @@ void server_run(Server* server) {
|
|||
|
||||
pthread_join(udp, NULL);
|
||||
pthread_join(tcp, NULL);
|
||||
|
||||
pthread_exit(0);
|
||||
}
|
||||
|
||||
void server_free(Server* server) {
|
||||
|
|
Loading…
Reference in a new issue