some experiments
This commit is contained in:
parent
ceae213b03
commit
6367dbffe8
@ -1,4 +1,5 @@
|
|||||||
cmake_minimum_required(VERSION 3.0)
|
cmake_minimum_required(VERSION 3.0)
|
||||||
|
cmake_policy(SET CMP0076 NEW)
|
||||||
|
|
||||||
project(birdbadge
|
project(birdbadge
|
||||||
VERSION 0.0.1
|
VERSION 0.0.1
|
||||||
@ -12,7 +13,9 @@ set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|||||||
find_package(PkgConfig REQUIRED)
|
find_package(PkgConfig REQUIRED)
|
||||||
pkg_check_modules(FCGI fcgi)
|
pkg_check_modules(FCGI fcgi)
|
||||||
|
|
||||||
add_executable(birdbadge main.cpp)
|
add_executable(birdbadge )
|
||||||
|
|
||||||
|
add_subdirectory(src)
|
||||||
|
|
||||||
target_link_libraries(birdbadge
|
target_link_libraries(birdbadge
|
||||||
fcgi
|
fcgi
|
||||||
|
10
src/CMakeLists.txt
Normal file
10
src/CMakeLists.txt
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
set(SOURCE_FILES
|
||||||
|
main.cpp
|
||||||
|
server.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
set(HEADER_FILES
|
||||||
|
server.h
|
||||||
|
)
|
||||||
|
|
||||||
|
target_sources(birdbadge PRIVATE ${SOURCE_FILES})
|
32
src/main.cpp
Normal file
32
src/main.cpp
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
#include <fcgiapp.h>
|
||||||
|
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include "server.h"
|
||||||
|
|
||||||
|
int main() {
|
||||||
|
const char* socketPath = "/run/birdbadge/birdbadge.sock";
|
||||||
|
int sockfd = FCGX_OpenSocket(socketPath, 1024);
|
||||||
|
if (sockfd < 0) {
|
||||||
|
std::cerr << "Error opening socket" << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (chmod(socketPath, 0770) != 0) {
|
||||||
|
std::cerr << "Couldn't set socket permissions" << std::endl;
|
||||||
|
return 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
Server server;
|
||||||
|
FCGX_Request request;
|
||||||
|
|
||||||
|
FCGX_Init();
|
||||||
|
FCGX_InitRequest(&request, sockfd, 0);
|
||||||
|
|
||||||
|
while (FCGX_Accept_r(&request) == 0) {
|
||||||
|
server.handleRequest(request);
|
||||||
|
|
||||||
|
FCGX_Finish_r(&request);
|
||||||
|
}
|
||||||
|
}
|
@ -1,21 +1,31 @@
|
|||||||
#include <iostream>
|
#include "server.h"
|
||||||
#include <string>
|
|
||||||
#include <fcgio.h>
|
|
||||||
#include <fcgiapp.h>
|
|
||||||
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
constexpr static const char* GET("GET");
|
constexpr static const char* GET("GET");
|
||||||
|
|
||||||
constexpr static const char* REQUEST_METHOD("REQUEST_METHOD");
|
constexpr static const char* REQUEST_METHOD("REQUEST_METHOD");
|
||||||
|
constexpr static const char* REQUEST_URI("REQUEST_URI");
|
||||||
|
|
||||||
|
constexpr static const char* DOCUMENT_URI("DOCUMENT_URI");
|
||||||
|
constexpr static const char* DOCUMENT_ROOT("DOCUMENT_ROOT");
|
||||||
|
|
||||||
constexpr static const char* SCRIPT_NAME("SCRIPT_NAME");
|
constexpr static const char* SCRIPT_NAME("SCRIPT_NAME");
|
||||||
|
constexpr static const char* SCRIPT_FILENAME("SCRIPT_FILENAME");
|
||||||
|
|
||||||
constexpr static const char* status405("Status: 405 Method Not Allowed");
|
constexpr static const char* status405("Status: 405 Method Not Allowed");
|
||||||
constexpr static const char* contentTypeHtml("Content-type: text/html");
|
constexpr static const char* contentTypeHtml("Content-type: text/html");
|
||||||
|
|
||||||
constexpr static const char* headerEnd("\n\n");
|
constexpr static const char* headerEnd("\n\n");
|
||||||
|
|
||||||
void handleRequest(FCGX_Request& request) {
|
Server::Server():
|
||||||
|
requestCount(0)
|
||||||
|
{}
|
||||||
|
|
||||||
|
Server::~Server() {
|
||||||
|
}
|
||||||
|
|
||||||
|
void Server::handleRequest(FCGX_Request& request) {
|
||||||
|
++requestCount;
|
||||||
|
|
||||||
fcgi_streambuf cin_fcgi_streambuf(request.in);
|
fcgi_streambuf cin_fcgi_streambuf(request.in);
|
||||||
fcgi_streambuf cout_fcgi_streambuf(request.out);
|
fcgi_streambuf cout_fcgi_streambuf(request.out);
|
||||||
fcgi_streambuf cerr_fcgi_streambuf(request.err);
|
fcgi_streambuf cerr_fcgi_streambuf(request.err);
|
||||||
@ -29,19 +39,21 @@ void handleRequest(FCGX_Request& request) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string scriptName{FCGX_GetParam(SCRIPT_NAME, request.envp)};
|
try {
|
||||||
|
printEnv(os, request);
|
||||||
|
|
||||||
|
os << requestCount;
|
||||||
|
} catch (const std::exception e) {
|
||||||
os << contentTypeHtml;
|
os << contentTypeHtml;
|
||||||
os << headerEnd;
|
os << headerEnd;
|
||||||
os << scriptName << "\n";
|
os << e.what();
|
||||||
}
|
|
||||||
|
|
||||||
int main() {
|
|
||||||
FCGX_Request request;
|
|
||||||
|
|
||||||
FCGX_Init();
|
|
||||||
FCGX_InitRequest(&request, 0, 0);
|
|
||||||
|
|
||||||
while (FCGX_Accept_r(&request) == 0) {
|
|
||||||
handleRequest(request);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Server::printEnv(std::ostream& out, FCGX_Request& request) {
|
||||||
|
char **envp = request.envp;
|
||||||
|
for (int i = 0; envp[i] != nullptr; ++i) {
|
||||||
|
out << envp[i] << "</br>";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
21
src/server.h
Normal file
21
src/server.h
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <iostream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include <fcgiapp.h>
|
||||||
|
#include <fcgio.h>
|
||||||
|
|
||||||
|
class Server {
|
||||||
|
public:
|
||||||
|
Server();
|
||||||
|
~Server();
|
||||||
|
|
||||||
|
void handleRequest(FCGX_Request& request);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void printEnv(std::ostream& out, FCGX_Request& request);
|
||||||
|
|
||||||
|
private:
|
||||||
|
uint64_t requestCount;
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user