feat(config): add config_get_vhost()

This commit is contained in:
2026-03-28 19:14:32 +01:00
parent d400722563
commit c183477686
4 changed files with 31 additions and 15 deletions
+2
View File
@@ -29,4 +29,6 @@ cws_config_s *cws_config_init(void);
void cws_config_free(cws_config_s *config); void cws_config_free(cws_config_s *config);
cws_vhost_s *config_get_vhost(cws_config_s *config, char *host);
#endif #endif
+12
View File
@@ -173,3 +173,15 @@ void cws_config_free(cws_config_s *config) {
free(config); free(config);
} }
} }
cws_vhost_s *config_get_vhost(cws_config_s *config, char *host) {
for (unsigned i = 0; i < config->virtual_hosts_count; ++i) {
cws_vhost_s *vh = config->virtual_hosts;
if (!strcmp(vh[i].domain, host)) {
return &vh[i];
}
}
/* Return default domain */
return config->default_vh;
}
+1 -13
View File
@@ -28,18 +28,6 @@ static void worker_close_client(int epfd, int client_fd) {
close(client_fd); close(client_fd);
} }
static cws_vhost_s *get_vhost(cws_config_s *config, char *host) {
for (unsigned i = 0; i < config->virtual_hosts_count; ++i) {
cws_vhost_s *vh = config->virtual_hosts;
if (!strcmp(vh[i].domain, host)) {
return &vh[i];
}
}
/* Return default domain */
return config->default_vh;
}
static cws_return worker_handle_client_data(int epfd, int client_fd, cws_config_s *config) { static cws_return worker_handle_client_data(int epfd, int client_fd, cws_config_s *config) {
string_s *data = string_new("", 4096); string_s *data = string_new("", 4096);
@@ -78,7 +66,7 @@ static cws_return worker_handle_client_data(int epfd, int client_fd, cws_config_
/* Configure handler */ /* Configure handler */
char *host = cws_request_get_header(request, "host"); char *host = cws_request_get_header(request, "host");
cws_vhost_s *vh = get_vhost(config, host); cws_vhost_s *vh = config_get_vhost(config, host);
cws_handler_config_s conf = { cws_handler_config_s conf = {
.domain = vh->domain, .domain = vh->domain,
.root = vh->root, .root = vh->root,
+16 -2
View File
@@ -1,21 +1,33 @@
#include "http/handler.h" #include "http/handler.h"
#include "config/config.h"
#include "utils/debug.h" #include "utils/debug.h"
#include <myclib/mystring.h> #include <myclib/mystring.h>
#include <string.h> #include <string.h>
#include <sys/stat.h> #include <sys/stat.h>
/* Sanitize and resolve file path */ /* Sanitize and resolve file path */
/* @TODO: fix path traversal */
static string_s *resolve_file_path(const char *url_path, cws_handler_config_s *config) { static string_s *resolve_file_path(const char *url_path, cws_handler_config_s *config) {
string_s *full_path = string_new(config->root, 256); string_s *full_path = string_new(config->root, 256);
if (!full_path) {
return NULL;
}
if (strcmp(url_path, "/") == 0) { if (strcmp(url_path, "/") == 0) {
string_append(full_path, "/"); string_append(full_path, "/");
/* Use vhost index file */ /* @TODO: Use vhost index file */
string_append(full_path, "index.html"); string_append(full_path, "index.html");
return full_path; return full_path;
} }
string_s *url_path_string = string_new(url_path, 0);
if (!url_path_string) {
return NULL;
}
if (string_find(url_path_string, "..")) {
return full_path;
}
string_append(full_path, url_path); string_append(full_path, url_path);
return full_path; return full_path;
@@ -43,6 +55,8 @@ cws_response_s *cws_handler_static_file(cws_request_s *request, cws_handler_conf
return cws_handler_not_implemented(); return cws_handler_not_implemented();
} }
/* @TODO: use config_get_vhost */
// cws_vhost_s *vhost = config_get_vhost(, request->host);
string_s *filepath = resolve_file_path(string_cstr(request->path), config); string_s *filepath = resolve_file_path(string_cstr(request->path), config);
const char *path = string_cstr(filepath); const char *path = string_cstr(filepath);