Skip to content
forked from YD-S/Webserv

A Webserver in C++98 with CGI execution

Notifications You must be signed in to change notification settings

Panesico/Webserv

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

42 (oscuro)

Webserv

A simple web server written in C++.

Features

  • Support for HTTP/1.1 protocol
  • Handling of GET, POST and DELETE requests
  • Static file serving
  • Dynamic content generation
  • Configuration via .conf files
  • Support for CGI scripts
  • Support for file uploads
  • Support for directory listing

Development

Diagrams

Sequence diagram

Sequence diagram

Macros

  • DEBUG: Set the minimum debug level. The higher the level, the higher the severity of the log messages. The default level is 3, for only error messages. Minimum level is 0, for all debug messages.

    • 0: Debug messages
    • 1: Info messages
    • 2: Warning messages
    • 3: Error messages
  • LOG_SYS_ERROR: Log error messages.

  • LOG_WARNING: Log warning messages.

  • LOG_INFO: Log info messages.

  • LOG_DEBUG: Log debug messages.

LocationConfig builder

The location config class can be built using a builder pattern. Here is an example:

LocationConfig()
        .addIndex("index.html")
        .addIndex("index.php")
        .setRoot("/var/www/html")
        .setPath("/")
        .addMethod("GET")
        .addMethod("POST")
        .setDirectoryListingEnabled(true)
        .setDirectoryResponseFile("/var/www/html/.directory")
        .setCgiEnabled(true)
        .setCgiPath("/var/www/html/cgi-bin")
        .setCgiExtension(".php")
        .setUploadEnabled(true)
        .setUploadPath("/var/www/html/uploads")

ServerConfig builder

The server config class can be built using a builder pattern. It has a default location config that can be set using the setDefaultLocation method. This default location config will be used for all requests that do not match any location config. Here is an example:

ServerConfig config = ServerConfig()
        .addListen(8080) // listen <_port>
        .addListen("localhost", 8081) // listen <host>:<_port>
        .setServerName("localhost") // server_name
        .setDefaultLocation(LocationConfig() // server level location config
                .addIndex("index.html") // index
                .addIndex("index.php") // index
                .setRoot("/var/www/html") // root
                .setPath("/") // location <path> { ... }
                .addMethod("GET") // methods
                .addMethod("POST") // methods
                .setDirectoryListingEnabled(true) // autoindex
                .setDirectoryResponseFile("/var/www/html/.directory") // autoindex_format
                .setCgiEnabled(true) // cgi_enabled
                .setCgiPath("/var/www/html/cgi-bin") // cgi_bin
                .setCgiExtension(".php") // cgi_ext
                .setUploadEnabled(true) // upload_enabled
                .setUploadPath("/var/www/html/uploads") // upload_path
                )
        .addLocation(LocationConfig() // for each location <path> { ... }
                .addIndex("index.html")
                .addIndex("index.php")
                .setRoot("/var/www/html")
                .setPath("/test")
                .addMethod("GET")
                .addMethod("POST")
                .setDirectoryListingEnabled(true)
                .setDirectoryResponseFile("/var/www/html/.directory")
                .setCgiEnabled(true)
                .setCgiPath("/var/www/html/cgi-bin")
                .setCgiExtension(".php")
                .setUploadEnabled(true)
                .setUploadPath("/var/www/html/uploads")
                );

Request builder

The _request class can be built using a builder pattern. Here is an example:

HttpRequest *req = new HttpRequest()
        ->setMethod("POST")
        ->setPath("/index.html")
        ->setVersion("HTTP/1.1")
        ->setHeader("Content-Type", MimeTypes::getType("html"))
        ->setHeader("Content-Length", "12")
        ->addParam("param1", "value")
        ->addParam("param2", "434")
        ->setBody("Hello World!");

Response builder

The response class can be built using a builder pattern. Here is an example:

HttpResponse *response = new HttpResponse()
        ->setVersion("HTTP/1.1")
        ->setStatus(HttpStatus::OK)
        ->setHeader("Content-Type", MimeTypes::getType("html"))
        ->setHeader("Content-Length", "12")
        ->setBody("Hello World!");

Build

make

Run

./webserv [config_file Optional - default: configs/default.conf]

About

A Webserver in C++98 with CGI execution

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 51.8%
  • SCSS 18.5%
  • CSS 12.6%
  • JavaScript 7.7%
  • HTML 6.7%
  • Shell 1.1%
  • Other 1.6%