/* Copyright 2017, Michele Santullo * This file is part of "tawashi". * * "tawashi" is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * "tawashi" is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with "tawashi". If not, see . */ #include "pastie_response.hpp" #include "incredis/incredis.hpp" #include "settings_bag.hpp" #include "escapist.hpp" #include "cgi_env.hpp" #include #include #include #include namespace tawashi { namespace { const char g_nolang_token[] = "colourless"; } //unnamed namespace PastieResponse::PastieResponse ( const Kakoune::SafePtr& parSettings, std::ostream* parStreamOut, const Kakoune::SafePtr& parCgiEnv ) : Response(parSettings, parStreamOut, parCgiEnv, true), m_langmap_dir(parSettings->as("langmap_dir")), m_plain_text(false), m_syntax_highlight(true) { } void PastieResponse::on_process() { auto get = cgi_env().query_string_split(); const std::string& query_str(cgi_env().query_string()); if (get["m"] == "plain" or query_str.empty()) { this->change_type(Response::ContentType, "text/plain; charset=utf-8"); m_plain_text = true; } else if (query_str == g_nolang_token) { m_syntax_highlight = false; } else { srchilite::LangMap lang_map(m_langmap_dir, "lang.map"); lang_map.open(); m_lang_file.clear(); if (not query_str.empty()) m_lang_file = lang_map.getFileName(query_str); if (m_lang_file.empty()) m_lang_file = "default.lang"; } } void PastieResponse::on_mustache_prepare (mstch::map& parContext) { using opt_string = redis::IncRedis::opt_string; using opt_string_list = redis::IncRedis::opt_string_list; auto token = boost::string_ref(cgi_env().path_info()).substr(1); 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()); srchilite::SourceHighlight highlighter; highlighter.setDataDir(settings().as("langmap_dir")); highlighter.setGenerateEntireDoc(false); highlighter.setGenerateLineNumbers(true); std::string processed_pastie; if (m_syntax_highlight) { processed_pastie = std::move(*pastie); } else { Escapist houdini; processed_pastie = houdini.escape_html(*pastie); } if (not m_plain_text and m_syntax_highlight) { std::istringstream iss(std::move(processed_pastie)); std::ostringstream oss; highlighter.highlight(iss, oss, m_lang_file); processed_pastie = oss.str(); } parContext["pastie"] = std::move(processed_pastie); } std::string PastieResponse::on_mustache_retrieve() { if (m_plain_text) return "{{pastie}}"; else return load_mustache(); } } //namespace tawashi