blob: d203077e101f065fedaa60259c96ab8bacb6384f [file] [log] [blame]
#pragma once
#include "common.hpp"
#include "sessions.hpp"
#include <boost/asio/io_context.hpp>
#include <boost/asio/ip/address.hpp>
#include <boost/beast/http/message.hpp>
#include <boost/beast/http/string_body.hpp>
#include <boost/beast/websocket.hpp>
#include <boost/url/url_view.hpp>
#include <string>
#include <string_view>
#include <system_error>
namespace crow
{
struct Request
{
boost::beast::http::request<boost::beast::http::string_body> req;
boost::beast::http::fields& fields;
std::string_view url{};
boost::urls::url_view urlView{};
bool isSecure{false};
std::string& body;
boost::asio::io_context* ioService{};
boost::asio::ip::address ipAddress{};
std::shared_ptr<persistent_data::UserSession> session;
std::string userRole{};
Request(boost::beast::http::request<boost::beast::http::string_body> reqIn,
std::error_code& ec) :
req(std::move(reqIn)),
fields(req.base()), body(req.body())
{
if (!setUrlInfo())
{
ec = std::make_error_code(std::errc::invalid_argument);
}
}
Request(const Request& other) :
req(other.req), fields(req.base()), isSecure(other.isSecure),
body(req.body()), ioService(other.ioService),
ipAddress(other.ipAddress), session(other.session),
userRole(other.userRole)
{
setUrlInfo();
}
Request(Request&& other) noexcept :
req(std::move(other.req)), fields(req.base()), isSecure(other.isSecure),
body(req.body()), ioService(other.ioService),
ipAddress(std::move(other.ipAddress)),
session(std::move(other.session)), userRole(std::move(other.userRole))
{
setUrlInfo();
}
Request& operator=(const Request&) = delete;
Request& operator=(const Request&&) = delete;
~Request() = default;
boost::beast::http::verb method() const
{
return req.method();
}
std::string_view getHeaderValue(std::string_view key) const
{
return req[key];
}
std::string_view getHeaderValue(boost::beast::http::field key) const
{
return req[key];
}
std::string_view methodString() const
{
return req.method_string();
}
std::string_view target() const
{
return req.target();
}
bool target(const std::string_view target)
{
req.target(target);
return setUrlInfo();
}
unsigned version() const
{
return req.version();
}
bool isUpgrade() const
{
return boost::beast::websocket::is_upgrade(req);
}
bool keepAlive() const
{
return req.keep_alive();
}
private:
bool setUrlInfo()
{
auto result = boost::urls::parse_relative_ref(target());
if (!result)
{
return false;
}
urlView = *result;
url = urlView.encoded_path();
return true;
}
};
} // namespace crow