server04 passed
This commit is contained in:
36
server04.c
36
server04.c
@@ -20,28 +20,41 @@ int main() {
|
|||||||
int connection_number = 1;
|
int connection_number = 1;
|
||||||
char *request = malloc(BUF_SIZE);
|
char *request = malloc(BUF_SIZE);
|
||||||
char buffer[BUF_SIZE] = {0};
|
char buffer[BUF_SIZE] = {0};
|
||||||
int bytesReceived;
|
|
||||||
data_map_t *data = data_map_create(1024);
|
data_map_t *data = data_map_create(1024);
|
||||||
printf("Listening for incoming connections...\n");
|
printf("Listening for incoming connections...\n");
|
||||||
while ((bytesReceived = recvfrom(server, buffer, sizeof(buffer), 0, (SOCKADDR *) &clientAddr, &clientAddrSize)) > 0) {
|
while (true) {
|
||||||
|
int bytesReceived = recvfrom(server, buffer, sizeof(buffer), 0, (SOCKADDR *) &clientAddr, &clientAddrSize);
|
||||||
const char *equals = "=";
|
const char *equals = "=";
|
||||||
size_t pos;
|
size_t pos;
|
||||||
// IN_ADDR addr = clientAddr.sin_addr;
|
// IN_ADDR addr = clientAddr.sin_addr;
|
||||||
// printf("{%d} Client ip: |%d.%d.%d.%d| \n", connection_number, addr.S_un.S_un_b.s_b1, addr.S_un.S_un_b.s_b2, addr.S_un.S_un_b.s_b3, addr.S_un.S_un_b.s_b4);
|
// printf("{%d} Client ip: |%d.%d.%d.%d| \n", connection_number, addr.S_un.S_un_b.s_b1, addr.S_un.S_un_b.s_b2, addr.S_un.S_un_b.s_b3, addr.S_un.S_un_b.s_b4);
|
||||||
// printf("{%d} Client port: |%d| \n", connection_number, clientAddr.sin_port);
|
// printf("{%d} Client port: |%d| \n", connection_number, clientAddr.sin_port);
|
||||||
if ((pos = strcspn(buffer, equals)) >= 0) {
|
printf("{%d} Client sent: |%s| \n", connection_number, buffer);
|
||||||
|
if ((pos = strcspn(buffer, equals)) != strlen(buffer)) {
|
||||||
key_value_t *kv = malloc(sizeof(key_value_t));
|
key_value_t *kv = malloc(sizeof(key_value_t));
|
||||||
|
kv->key = malloc(sizeof(char)*1024);
|
||||||
|
kv->value = malloc(sizeof(char)*1024);
|
||||||
strncpy_s(kv->key, BUF_SIZE, buffer, pos);
|
strncpy_s(kv->key, BUF_SIZE, buffer, pos);
|
||||||
strncpy_s(kv->value, BUF_SIZE, buffer + sizeof(char)*(pos+1), sizeof(buffer) - pos - 1);
|
strncpy_s(kv->value, BUF_SIZE, buffer + sizeof(char)*(pos+1), sizeof(buffer) - pos - 1);
|
||||||
data_map_insert_kv(data, kv);
|
data_map_insert_kv(data, kv);
|
||||||
printf("{%d} Key: |%s| Value: |%s| \n", connection_number, kv->key, kv->value);
|
printf("{%d} Key: |%s| Value: |%s| \n", connection_number, kv->key, kv->value);
|
||||||
} else {
|
} else {
|
||||||
printf("{%d} Client sent: |%s| \n", connection_number, buffer);
|
printf("{%d} Client query: |%s| \n", connection_number, buffer);
|
||||||
|
char *value = data_map_get(data, buffer);
|
||||||
|
if (strcmp(buffer, "version") == 0) {
|
||||||
|
const char *version = "version=Ken's Key-Value Store 1.0";
|
||||||
|
sendto(server, version, strlen(version), 0, (SOCKADDR *) &clientAddr, clientAddrSize);
|
||||||
|
} else {
|
||||||
|
sprintf(buffer, "%s=%s", buffer, value);
|
||||||
|
sendto(server, buffer, strlen(buffer), 0, (SOCKADDR *) &clientAddr, clientAddrSize);
|
||||||
}
|
}
|
||||||
sendto(server, buffer, bytesReceived, 0, (SOCKADDR *) &clientAddr, clientAddrSize);
|
|
||||||
strncpy_s(request, BUF_SIZE, buffer, bytesReceived);
|
}
|
||||||
printf("{%d} Client sent: |%s| \n", connection_number, request);
|
// sendto(server, buffer, bytesReceived, 0, (SOCKADDR *) &clientAddr, clientAddrSize);
|
||||||
|
// strncpy_s(request, BUF_SIZE, buffer, bytesReceived);
|
||||||
|
// printf("{%d} Client sent: |%s| \n", connection_number, request);
|
||||||
connection_number++;
|
connection_number++;
|
||||||
|
memset(buffer, 0, sizeof(buffer));
|
||||||
}
|
}
|
||||||
data_map_free(data);
|
data_map_free(data);
|
||||||
free(request);
|
free(request);
|
||||||
@@ -64,7 +77,7 @@ void data_map_free(data_map_t *map) {
|
|||||||
free(map);
|
free(map);
|
||||||
}
|
}
|
||||||
void data_map_insert_kv(data_map_t *map, key_value_t *kv) {
|
void data_map_insert_kv(data_map_t *map, key_value_t *kv) {
|
||||||
if (map->data == NULL) {
|
if (map==NULL || map->data == NULL) {
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
for (int i = 0; i < map->count; i++) {
|
for (int i = 0; i < map->count; i++) {
|
||||||
@@ -79,8 +92,7 @@ void data_map_insert_kv(data_map_t *map, key_value_t *kv) {
|
|||||||
key_value_t *new_array = realloc(map->data, map->capacity * sizeof(key_value_t));
|
key_value_t *new_array = realloc(map->data, map->capacity * sizeof(key_value_t));
|
||||||
map->data = new_array;
|
map->data = new_array;
|
||||||
}
|
}
|
||||||
map->data[map->count].key = kv->key;
|
map->data[map->count] = *kv;
|
||||||
map->data[map->count].value = kv->value;
|
|
||||||
map->count = new_size;
|
map->count = new_size;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -115,11 +127,11 @@ void data_map_insert(data_map_t *map, char *key, char *value) {
|
|||||||
data_map_append(map, key, value);
|
data_map_append(map, key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *data_map_get(data_map_t *map, const char *key) {
|
char *data_map_get(const data_map_t *map, const char *key) {
|
||||||
for (int i = 0; i < map->count; i++) {
|
for (int i = 0; i < map->count; i++) {
|
||||||
if (strcmp(map->data[i].key, key) == 0) {
|
if (strcmp(map->data[i].key, key) == 0) {
|
||||||
return map->data[i].value;
|
return map->data[i].value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return "";
|
||||||
}
|
}
|
||||||
@@ -25,4 +25,4 @@ void data_map_free(data_map_t *map);
|
|||||||
void data_map_append(data_map_t *map, char *key, char *value);
|
void data_map_append(data_map_t *map, char *key, char *value);
|
||||||
void data_map_insert(data_map_t *map, char *key, char *value);
|
void data_map_insert(data_map_t *map, char *key, char *value);
|
||||||
void data_map_insert_kv(data_map_t *map, key_value_t *kv);
|
void data_map_insert_kv(data_map_t *map, key_value_t *kv);
|
||||||
char *data_map_get(data_map_t *map, const char *key);
|
char *data_map_get(const data_map_t *map, const char *key);
|
||||||
|
|||||||
@@ -4,16 +4,18 @@ import time
|
|||||||
import random
|
import random
|
||||||
from typing import Optional, Dict, List, Tuple
|
from typing import Optional, Dict, List, Tuple
|
||||||
|
|
||||||
|
|
||||||
class DatabaseTestClient:
|
class DatabaseTestClient:
|
||||||
def __init__(self, host: str = 'localhost', server_port: int = 40000):
|
def __init__(self, host: str = 'localhost', server_port: int = 40000):
|
||||||
self.host = host
|
self.host = host
|
||||||
self.server_port = server_port
|
self.server_port = server_port
|
||||||
self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM )
|
self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM )
|
||||||
|
self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
|
||||||
# Bind to any available interface (empty string) on an ephemeral port (0)
|
# Bind to any available interface (empty string) on an ephemeral port (0)
|
||||||
self.sock.bind(('', 0))
|
self.sock.bind(('0.0.0.0', 50000))
|
||||||
# Get the actual port assigned
|
# Get the actual port assigned
|
||||||
self.client_port = self.sock.getsockname()[1]
|
self.client_port = self.sock.getsockname()[1]
|
||||||
self.sock.settimeout(1.0) # 1 second timeout for receives
|
self.sock.settimeout(5.0) # 1 second timeout for receives
|
||||||
print(f"Client bound to port {self.client_port}")
|
print(f"Client bound to port {self.client_port}")
|
||||||
|
|
||||||
def send_insert(self, key: str, value: str) -> None:
|
def send_insert(self, key: str, value: str) -> None:
|
||||||
@@ -30,7 +32,7 @@ class DatabaseTestClient:
|
|||||||
self.sock.sendto(key.encode(), (self.host, self.server_port))
|
self.sock.sendto(key.encode(), (self.host, self.server_port))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
data, addr = self.sock.recvfrom(1000) # Changed from recvmsg to recvfrom
|
data, addr = self.sock.recvfrom(1024) # Changed from recvmsg to recvfrom
|
||||||
return data.decode()
|
return data.decode()
|
||||||
except socket.timeout:
|
except socket.timeout:
|
||||||
return None
|
return None
|
||||||
|
|||||||
Reference in New Issue
Block a user