1
0
Fork 0
mirror of https://github.com/KingDuckZ/kamokan.git synced 2025-02-09 09:23:56 +00:00

Use REQUEST_URI instead of PATH_INFO.

This commit is contained in:
King_DuckZ 2017-06-04 22:14:05 +01:00
parent 2293604e11
commit 1a7ec9c2c4
4 changed files with 24 additions and 15 deletions

View file

@ -167,7 +167,7 @@ int main (int parArgc, char* parArgv[], char* parEnvp[]) {
resp_factory.register_jolly_maker(&make_response<PastieResponse>, RequestMethodType::GET);
std::unique_ptr<Response> response = resp_factory.make_response(
cgi_env->path_info(),
cgi_env->request_uri_relative(),
cgi_env->request_method()
);
if (response)

View file

@ -83,25 +83,25 @@ namespace cgi {
return optional<Env::VersionInfo>();
}
std::size_t calculate_skip_path_length (const boost::string_ref& parPathInfo, const boost::string_ref& parBasePath) {
std::size_t calculate_skip_path_length (const boost::string_ref& paPath, const boost::string_ref& parBasePath) {
const std::size_t base_path_tr_slash = (not parBasePath.empty() and parBasePath[parBasePath.size() - 1] == '/' ? 1 : 0);
boost::string_ref base_path = parBasePath.substr(0, parBasePath.size() - base_path_tr_slash);
SPDLOG_TRACE(spdlog::get("statuslog"), "calculating skip prefix for PATH_INFO=\"{}\", base path=\"{}\", parBasePath=\"{}\", base path trailing slash={}",
std::string(parPathInfo.begin(), parPathInfo.end()),
SPDLOG_TRACE(spdlog::get("statuslog"), "calculating skip prefix for REQUEST_URI=\"{}\", base path=\"{}\", parBasePath=\"{}\", base path trailing slash={}",
std::string(paPath.begin(), paPath.end()),
std::string(base_path.begin(), base_path.end()),
std::string(parBasePath.begin(), parBasePath.end()),
base_path_tr_slash
);
if (boost::starts_with(parPathInfo, base_path)) {
if (boost::starts_with(paPath, base_path)) {
//account for the trailing slash in either base path and path info
return std::min(parBasePath.size(), parPathInfo.size());
return std::min(parBasePath.size(), paPath.size());
}
else {
std::string str_base_path(parBasePath.begin(), parBasePath.end());
std::string str_path(parPathInfo.begin(), parPathInfo.end());
std::string str_path(paPath.begin(), paPath.end());
spdlog::get("statuslog")->error(
"base path is not a prefix of PATH_INFO: base path={}, PATH_INFO={}, tawashi will most likely malfunction",
"base path is not a prefix of REQUEST_URI: base path={}, REQUEST_URI={}, tawashi will most likely malfunction",
str_base_path,
str_path
);
@ -112,7 +112,7 @@ namespace cgi {
Env::Env(const char* const* parEnvList, const boost::string_ref& parBasePath) :
m_cgi_env(cgi_environment_vars(parEnvList)),
m_skip_path_info(calculate_skip_path_length(m_cgi_env[CGIVars::PATH_INFO], parBasePath)),
m_skip_path_info(calculate_skip_path_length(m_cgi_env[CGIVars::REQUEST_URI], parBasePath)),
m_request_method_type(RequestMethodType::_from_string(m_cgi_env[CGIVars::REQUEST_METHOD].data()))
{
{
@ -149,10 +149,8 @@ namespace cgi {
return split_version(m_cgi_env[CGIVars::GATEWAY_INTERFACE]);
}
boost::string_ref Env::path_info() const {
const std::string& path = m_cgi_env[CGIVars::PATH_INFO];
assert(m_skip_path_info <= path.size());
return boost::string_ref(path).substr(m_skip_path_info);
const std::string& Env::path_info() const {
return m_cgi_env[CGIVars::PATH_INFO];
}
const std::string& Env::path_translated() const {
@ -191,6 +189,10 @@ namespace cgi {
return m_request_method_type;
}
const std::string& Env::request_uri() const {
return m_cgi_env[CGIVars::REQUEST_URI];
}
const std::string& Env::script_name() const {
return m_cgi_env[CGIVars::SCRIPT_NAME];
}
@ -242,5 +244,10 @@ namespace cgi {
return parStream;
}
boost::string_ref Env::request_uri_relative() const {
const std::string& path = m_cgi_env[CGIVars::REQUEST_URI];
assert(m_skip_path_info <= path.size());
return boost::string_ref(path).substr(m_skip_path_info);
}
} //namespace cgi
} //namespace tawashi

View file

@ -50,7 +50,7 @@ namespace tawashi {
std::size_t content_length() const;
const std::string& content_type() const;
boost::optional<VersionInfo> gateway_interface() const a_pure;
boost::string_ref path_info() const;
const std::string& path_info() const;
const std::string& path_translated() const;
const std::string& query_string() const;
const std::string& http_client_ip() const;
@ -60,6 +60,7 @@ namespace tawashi {
const std::string& remote_ident() const;
const std::string& remote_user() const;
RequestMethodType request_method() const;
const std::string& request_uri() const;
const std::string& script_name() const;
const std::string& server_name() const;
bool https() const;
@ -69,6 +70,7 @@ namespace tawashi {
GetMapType query_string_split() const a_pure;
const SplitMime& content_type_split() const a_pure;
boost::string_ref request_uri_relative() const;
std::ostream& print_all (std::ostream& parStream, const char* parNewline) const;

View file

@ -78,7 +78,7 @@ namespace tawashi {
using opt_string = redis::IncRedis::opt_string;
using opt_string_list = redis::IncRedis::opt_string_list;
boost::string_ref token = cgi_env().path_info();
boost::string_ref token = cgi_env().request_uri_relative();
auto& redis = this->redis();
opt_string_list pastie_reply = redis.hmget(token, "pastie");
opt_string pastie = (pastie_reply and not pastie_reply->empty() ? (*pastie_reply)[0] : opt_string());