」 feat: added getserver in config to get a server from a server_name

This commit is contained in:
2025-04-22 11:17:05 +02:00
parent 773a54d7cd
commit 8ff043802c
3 changed files with 31 additions and 11 deletions

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/04/14 12:20:06 by adjoly #+# #+# */
/* Updated: 2025/04/18 10:03:09 by adjoly ### ########.fr */
/* Updated: 2025/04/22 10:57:26 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -24,10 +24,11 @@ class Config {
Logger *getLogger(void) { return _log; }
std::vector<Server *> *getServers(void) { return _servers; }
std::vector<Server *> getServers(void) { return _servers; }
Server *getServer(const std::string &);
private:
std::vector<Server *> *_servers;
std::vector<Server *> _servers;
};
}; // namespace config

View File

@ -6,7 +6,7 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/03/19 14:11:28 by adjoly #+# #+# */
/* Updated: 2025/04/18 10:08:33 by adjoly ### ########.fr */
/* Updated: 2025/04/22 10:59:27 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
@ -15,6 +15,7 @@
#include "config/default.hpp"
#include "cppeleven.hpp"
#include "node/ANode.hpp"
#include "webserv.hpp"
namespace webserv {
namespace config {
@ -55,6 +56,16 @@ class Server {
// @brief Can be used to get the port specified in the config file
int getPort(void) { return _port; }
// @brief Can be used to check if a servername is present in this config
bool isServerName(const std::string &server_name) {
for (auto it = prange(_server_names)) {
if (*it == server_name) {
return true;
}
}
return false;
}
protected:
private:
std::map<std::string, Route *>

View File

@ -6,12 +6,14 @@
/* By: adjoly <adjoly@student.42angouleme.fr> +#+ +:+ +#+ */
/* +#+#+#+#+#+ +#+ */
/* Created: 2025/04/14 12:53:54 by adjoly #+# #+# */
/* Updated: 2025/04/18 10:21:36 by adjoly ### ########.fr */
/* Updated: 2025/04/22 11:11:26 by adjoly ### ########.fr */
/* */
/* ************************************************************************** */
#include "cppeleven.hpp"
#include "node/ANode.hpp"
#include <config/default.hpp>
#include <webserv.hpp>
using namespace webserv::config;
@ -30,19 +32,25 @@ Config::Config(std::string &filename) {
}
std::map<std::string, toml::ANode *> *node = table->getTable();
for (std::map<std::string, toml::ANode *>::iterator it = node->begin();
it != node->end(); it++) {
for (auto it = prange(node)) {
Server *srv = new Server(it->second);
_servers->push_back(srv);
_servers.push_back(srv);
}
delete table;
delete file;
}
Config::~Config(void) {
std::vector<Server *>::iterator it = _servers->begin();
for (; it != _servers->end() ; it++) {
for (auto it = range(_servers)) {
delete *it;
}
delete _servers;
}
Server *Config::getServer(const std::string &server_name) {
for (auto it = range(_servers)) {
if ((*it)->isServerName(server_name)) {
return (*it);
}
}
return (not_nullptr);
}