diff options
| -rw-r--r-- | project2/cgi/Jamfile.jam | 1 | ||||
| -rw-r--r-- | project2/cgi/cgiAppEngine.cpp | 21 | ||||
| -rw-r--r-- | project2/cgi/cgiAppEngine.h | 6 | ||||
| -rw-r--r-- | project2/cgi/p2webCgi.cpp | 6 | ||||
| -rw-r--r-- | project2/cgi/p2webFCgi.cpp | 6 | ||||
| -rw-r--r-- | project2/cgi/testCgi.cpp | 60 | ||||
| -rw-r--r-- | project2/cli/Jamfile.jam | 16 | ||||
| -rw-r--r-- | project2/cli/claOptions.cpp (renamed from project2/console/claOptions.cpp) | 31 | ||||
| -rw-r--r-- | project2/cli/claOptions.h (renamed from project2/console/claOptions.h) | 4 | ||||
| -rw-r--r-- | project2/console/Jamfile.jam | 1 | ||||
| -rw-r--r-- | project2/console/consoleAppEngine.cpp | 15 | ||||
| -rw-r--r-- | project2/console/consoleAppEngine.h | 3 | ||||
| -rw-r--r-- | project2/console/p2consoleMain.cpp | 2 | 
13 files changed, 102 insertions, 70 deletions
| diff --git a/project2/cgi/Jamfile.jam b/project2/cgi/Jamfile.jam index 8da2f11..5b8e5a5 100644 --- a/project2/cgi/Jamfile.jam +++ b/project2/cgi/Jamfile.jam @@ -55,5 +55,6 @@ exe testCgi :  	testCgi.cpp  	:  	<library>p2cgicommon +	<library>../cli//p2cli  	<include>../../libmisc  	; diff --git a/project2/cgi/cgiAppEngine.cpp b/project2/cgi/cgiAppEngine.cpp index 8adfb35..bd25172 100644 --- a/project2/cgi/cgiAppEngine.cpp +++ b/project2/cgi/cgiAppEngine.cpp @@ -1,4 +1,5 @@  #include <pch.hpp> +#include "optionsSource.h"  #include "cgiAppEngine.h"  #include "cgiResult.h"  #include <cgicc/Cgicc.h> @@ -122,7 +123,7 @@ finalTransformSource(TransformSourcePtr ts)  }  void -CgiApplicationEngine::processRun(std::ostream & IO, CgiRequestContext * crc) const +CgiApplicationEngine::process(std::ostream & IO, CgiRequestContext * crc) const  {  	bool sessionEmpty = crc->getSession()->Empty();  	crc->startTime = boost::date_time::microsec_clock<boost::posix_time::ptime>::universal_time(); @@ -308,11 +309,15 @@ doExceptionReporting(const E & e, std::ostream & IO)  }  void -CgiApplicationEngine::process(std::ostream & IO, CgiRequestContext * crc) const +CgiApplicationEngine::process(std::ostream & IO, cgicc::CgiInput * cgii, const CgiEnvInput & cgienv) const  {  	try { -		Logger()->messagef(LOG_DEBUG, "%s: Processing request", __FUNCTION__); -		processRun(IO, crc); +		boost::function<std::string()> sn = boost::bind(&CgiEnvInput::getenv, &cgienv, "SERVER_NAME"); +		OptionsSource::loadSources(boost::bind(&CgiApplicationEngine::derivedPlatform, sn)); +		CgiRequestContext crc(cgii, cgienv); +		Plugable::onAllComponents(boost::bind(&ComponentLoader::onBefore, _1)); +		Logger()->messagebf(LOG_DEBUG, "%s: Processing request (%s)", __FUNCTION__, crc.getRedirectURL()); +		process(IO, &crc);  		Logger()->messagef(LOG_DEBUG, "%s: Completed request", __FUNCTION__);  	}  	catch (const std::exception & e) { @@ -333,13 +338,13 @@ CgiApplicationEngine::process(std::ostream & IO, CgiRequestContext * crc) const  }  const Glib::ustring & -CgiApplicationEngine::derivedPlatform(CgiRequestContext * crc) +CgiApplicationEngine::derivedPlatform(const boost::function<std::string()> & vhostName)  { -	auto pi = std::find_if(platHosts.begin(), platHosts.end(), [crc](const PlatformHostname & r) -> bool { -			return r.second->match(crc->getServerName()); +	auto pi = std::find_if(platHosts.begin(), platHosts.end(), [vhostName](const PlatformHostname & r) -> bool { +			return r.second->match(vhostName());  		});  	if (pi == platHosts.end()) { -		throw NoSuchPlatform(crc->getServerName()); +		throw NoSuchPlatform(vhostName());  	}  	return pi->first;  } diff --git a/project2/cgi/cgiAppEngine.h b/project2/cgi/cgiAppEngine.h index 476378a..1bc282f 100644 --- a/project2/cgi/cgiAppEngine.h +++ b/project2/cgi/cgiAppEngine.h @@ -32,11 +32,11 @@ class CgiApplicationEngine {  		CgiApplicationEngine();  		virtual ~CgiApplicationEngine(); -		void process(std::ostream & IO, CgiRequestContext *) const; -		static const Glib::ustring & derivedPlatform(CgiRequestContext *); +		void process(std::ostream & IO, cgicc::CgiInput * cgii, const CgiEnvInput & cgienv) const; +		static const Glib::ustring & derivedPlatform(const boost::function<std::string()> & vhostName);  	private: -		void processRun(std::ostream & IO, CgiRequestContext *) const; +		void process(std::ostream & IO, CgiRequestContext *) const;  		void addAppData(const MultiRowSetPresenter * p, OutputOptionsPtr o, CgiRequestContext *, bool) const;  		void addEnvData(const MultiRowSetPresenter * p, OutputOptionsPtr o, CgiRequestContext *, bool) const; diff --git a/project2/cgi/p2webCgi.cpp b/project2/cgi/p2webCgi.cpp index a8b47e8..a4e2328 100644 --- a/project2/cgi/p2webCgi.cpp +++ b/project2/cgi/p2webCgi.cpp @@ -1,5 +1,4 @@  #include "cgiAppEngine.h" -#include "optionsSource.h"  #include <boost/bind.hpp>  class GetEnv : public CgiEnvInput { @@ -18,10 +17,7 @@ main(void)  	Plugable::onAllComponents(boost::bind(&ComponentLoader::onBegin, _1));  	CgiApplicationEngine app;  	GetEnv ge; -	CgiRequestContext crc(NULL, ge); -	OptionsSource::loadSources(boost::bind(&CgiApplicationEngine::derivedPlatform, &crc)); -	Plugable::onAllComponents(boost::bind(&ComponentLoader::onBefore, _1)); -	app.process(std::cout, &crc); +	app.process(std::cout, NULL, ge);  	Plugable::onAllComponents(boost::bind(&ComponentLoader::onIteration, _1));  	Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1));  	Plugable::onAllComponents(boost::bind(&ComponentLoader::onIdle, _1)); diff --git a/project2/cgi/p2webFCgi.cpp b/project2/cgi/p2webFCgi.cpp index 4bc9b2d..0551bf0 100644 --- a/project2/cgi/p2webFCgi.cpp +++ b/project2/cgi/p2webFCgi.cpp @@ -1,6 +1,5 @@  #include "FCgiIO.h"  #include "cgiAppEngine.h" -#include "optionsSource.h"  #include <boost/bind.hpp>  time_t lastPeriodic = 0; @@ -45,10 +44,7 @@ main(void)  		while (FCGX_Accept_r(&request) == 0) {  			alarm(0);  			cgicc::FCgiIO IO(request); -			CgiRequestContext crc(&IO, IO); -			OptionsSource::loadSources(boost::bind(&CgiApplicationEngine::derivedPlatform, &crc)); -			Plugable::onAllComponents(boost::bind(&ComponentLoader::onBefore, _1)); -			app.process(IO, &crc); +			app.process(IO, &IO, IO);  			FCGX_Finish_r(&request);  			Plugable::onAllComponents(boost::bind(&ComponentLoader::onIteration, _1));  			if (time(NULL) > lastPeriodic + periodicDelay) { diff --git a/project2/cgi/testCgi.cpp b/project2/cgi/testCgi.cpp index 6fa8d42..d923d3c 100644 --- a/project2/cgi/testCgi.cpp +++ b/project2/cgi/testCgi.cpp @@ -4,6 +4,7 @@  #include "options.h"  #include "safeMapFind.h"  #include "../files/optionsSource.h" +#include "../cli/claOptions.h"  #include "cgiRequestContext.h"  #include "cgiAppEngine.h" @@ -23,23 +24,11 @@ class TestInput : public cgicc::CgiInput, public CgiEnvInput {  		typedef boost::shared_ptr<std::string> StrPtr;  		typedef std::map<std::string, StrPtr> OptStore; -		TestInput(int argc, char ** argv) : -			crc(NULL, *this) +		TestInput(int argc, char ** argv)  		{ -			auto cp = boost::bind(&CgiApplicationEngine::derivedPlatform, &crc); -			OptionsSource::loadSources(cp); -			FileOptions fo(".testCgi.settings"); -			fo.loadInto(TestConfigConsumer(), cp); -			if (argc > 1) { -				const char * qm = strchr(argv[1], '?'); -				if (qm) { -					optStore()["REDIRECT_URL"] = StrPtr(new std::string(argv[1], qm - argv[1])); -					optStore()["QUERY_STRING"] = StrPtr(new std::string(qm + 1)); -				} -				else { -					optStore()["REDIRECT_URL"] = StrPtr(new std::string(argv[1])); -				} -			} +			Plugable::newLoader<OptionsSource, OptionsSource>("_1", new FileOptions(".testCgi.settings")); +			Plugable::newLoader<OptionsSource, OptionsSource>("_2", new CommandLineArguments(argc, argv, +						[](const char * url) { urls.push_back(url); }));  		}  		std::string getenv(const std::string & varName) const @@ -54,30 +43,44 @@ class TestInput : public cgicc::CgiInput, public CgiEnvInput {  		}  		void run()  		{ +			Plugable::onAllComponents(boost::bind(&ComponentLoader::onBegin, _1));  			CgiApplicationEngine app; -			if (urlListFile.empty()) { -				for (int run = 0; run < runCount; run += 1) { -					app.process(std::cout, &crc); +			boost::function<std::string()> sn = boost::bind(&CgiEnvInput::getenv, this, "SERVER_NAME"); +			OptionsSource::loadSources(boost::bind(&CgiApplicationEngine::derivedPlatform, sn)); + +			if (!urlListFile.empty()) { +				std::ifstream urlFile(urlListFile); +				while (!urlFile.eof()) { +					std::string url; +					urlFile >> url; +					urls.push_back(url);  				}  			} -			else { -				for (int run = 0; run < runCount; run += 1) { -					std::ifstream urls(urlListFile); -					while (!urls.eof()) { -						std::string url; -						urls >> url; + +			while (runCount-- > 0) { +				BOOST_FOREACH(const auto & url, urls) { +					int qm = url.find('?'); +					if (qm != -1) { +						optStore()["REDIRECT_URL"] = StrPtr(new std::string(url.substr(0, qm))); +						optStore()["QUERY_STRING"] = StrPtr(new std::string(url.substr(qm + 1))); +					} +					else {  						optStore()["REDIRECT_URL"] = StrPtr(new std::string(url)); -						app.process(std::cout, &crc); +						optStore()["QUERY_STRING"] = StrPtr(new std::string());  					} +					app.process(std::cout, this, *this); +					Plugable::onAllComponents(boost::bind(&ComponentLoader::onIteration, _1));  				} +				Plugable::onAllComponents(boost::bind(&ComponentLoader::onPeriodic, _1));  			} +			Plugable::onAllComponents(boost::bind(&ComponentLoader::onIdle, _1));  		}  		INITOPTIONS;  	private: -		CgiRequestContext crc;  		static int runCount;  		static std::string urlListFile; +		static std::vector<std::string> urls;  		static OptStore & optStore()  		{  			static OptStore _optStore; @@ -86,6 +89,7 @@ class TestInput : public cgicc::CgiInput, public CgiEnvInput {  };  int TestInput::runCount;  std::string TestInput::urlListFile; +std::vector<std::string> TestInput::urls;  DECLARE_OPTIONS(TestInput, "Project2 CGI test options")  TESTOPT("SERVER_NAME", "localhost", "FQDN of web service") @@ -97,7 +101,6 @@ TESTOPT("REQUEST_METHOD", "GET", "Request method")  TESTOPT("PATH_INFO", "", "Path info")  TESTOPT("PATH_TRANSLATED", "", "Path translated")  TESTOPT("SCRIPT_NAME", "p2fcgi", "Script name") -TESTOPT("QUERY_STRING", "", "Query string")  TESTOPT("REMOTE_HOST", "", "Remote host")  TESTOPT("REMOTE_ADDR", "", "Remote address")  TESTOPT("AUTH_TYPE", "", "Authentication type") @@ -108,7 +111,6 @@ TESTOPT("CONTENT_LENGTH", "", "Content length")  TESTOPT("HTTP_ACCEPT", "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8", "Accepted MIME types")  TESTOPT("HTTP_USER_AGENT", "Mozilla/5.0", "User agent")  TESTOPT("REDIRECT_REQUEST", "", "Redirect request") -TESTOPT("REDIRECT_URL", "", "Redirect URL")  TESTOPT("REDIRECT_STATUS", "", "Redirect status")  TESTOPT("HTTP_REFERER", "", "Referrer")  TESTOPT("HTTP_COOKIE", "", "Cookie") diff --git a/project2/cli/Jamfile.jam b/project2/cli/Jamfile.jam new file mode 100644 index 0000000..28487aa --- /dev/null +++ b/project2/cli/Jamfile.jam @@ -0,0 +1,16 @@ +alias glibmm : : : : +	<cflags>"`pkg-config --cflags glibmm-2.4`" +	<linkflags>"`pkg-config --libs glibmm-2.4`" +	; + +lib p2cli : +	[ glob *.cpp ] +	: +	<include>. +	<include>../../libmisc +	<library>glibmm +	<library>../common//p2common +	: : +	<include>. +	; + diff --git a/project2/console/claOptions.cpp b/project2/cli/claOptions.cpp index ee28bf6..b1e1250 100644 --- a/project2/console/claOptions.cpp +++ b/project2/cli/claOptions.cpp @@ -4,15 +4,14 @@  #include "../common/optionsSource.h"  #include "../common/exceptions.h"  #include "claOptions.h" -#include "consoleAppEngine.h" -StaticMessageException(InvalidScriptName, "Script name should be group/name");  SimpleMessageException(ArgumentRequired);  SimpleMessageException(UnknownOption); -CommandLineArguments::CommandLineArguments(int c, const char * const * v) : +CommandLineArguments::CommandLineArguments(int c, const char * const * v, const Others & o) :  	argc(c),  	argv(v), +	others(o),  	loadedAt(0)  {  } @@ -26,7 +25,12 @@ CommandLineArguments::loadInto(const ConfigConsumer & consume, const Options::Cu  			moreopts = false;  		}  		else if (moreopts && strncmp(argv[x], "--", 2) == 0) { -			Glib::ustring name(argv[x] + 2); +			Glib::ustring plat, name(argv[x] + 2); +			Glib::ustring::size_type sl = name.find('/'); +			if (sl != (Glib::ustring::size_type)-1) { +				plat = name.substr(sl + 1); +				name = name.substr(0, sl); +			}  			const Options::Option * o = consume.get(name);  			if (!o) {  				throw UnknownOption(name); @@ -36,10 +40,10 @@ CommandLineArguments::loadInto(const ConfigConsumer & consume, const Options::Cu  				if (x >= argc) {  					throw ArgumentRequired(name);  				} -				consume(name, platform(), argv[x], platform); +				consume(name, plat, argv[x], platform);  			}  			else { -				consume(name, platform(), name, platform); +				consume(name, plat, name, platform);  			}  		}  		else if (moreopts && *(argv[x]) == '-') { @@ -56,27 +60,20 @@ CommandLineArguments::loadInto(const ConfigConsumer & consume, const Options::Cu  						if (x >= argc) {  							throw ArgumentRequired(name);  						} -						consume(name, platform(), argv[x], platform); +						consume(name, Glib::ustring(), argv[x], platform);  					}  					else { -						consume(name, platform(), n, platform); +						consume(name, Glib::ustring(), n, platform);  						n += 1;  					}  				}  				else { -					consume(name, platform(), name, platform); +					consume(name, Glib::ustring(), name, platform);  				}  			}  		}  		else { -			const char * sl = strchr(argv[x], '/'); -			if (sl) { -				ConsoleApplicationEngine::todolist.push_back(ConsoleApplicationEngine::ToDo(std::string(argv[x], sl), sl + 1)); -				sl++; -			} -			else { -				throw InvalidScriptName(); -			} +			others(argv[x]);  		}  	}  	time(&loadedAt); diff --git a/project2/console/claOptions.h b/project2/cli/claOptions.h index ea3fb01..c669004 100644 --- a/project2/console/claOptions.h +++ b/project2/cli/claOptions.h @@ -5,13 +5,15 @@  class CommandLineArguments : public OptionsSource {  	public: -		CommandLineArguments(int c, const char * const * v); +		typedef boost::function<void(const char * const)> Others; +		CommandLineArguments(int c, const char * const * v, const Others &);  		void loadInto(const ConfigConsumer & consume, const Options::CurrentPlatform & platform) const;  		bool needReload() const;  	private:  		const int argc;  		const char * const * argv; +		const Others others;  		mutable time_t loadedAt;  }; diff --git a/project2/console/Jamfile.jam b/project2/console/Jamfile.jam index fc5d50b..260de3e 100644 --- a/project2/console/Jamfile.jam +++ b/project2/console/Jamfile.jam @@ -14,6 +14,7 @@ exe p2console :  	<include>.  	<library>..//p2parts  	<library>../common//p2common +	<library>../cli//p2cli  	<include>../../libmisc  	; diff --git a/project2/console/consoleAppEngine.cpp b/project2/console/consoleAppEngine.cpp index 332d7b8..592b006 100644 --- a/project2/console/consoleAppEngine.cpp +++ b/project2/console/consoleAppEngine.cpp @@ -13,6 +13,7 @@  #include <boost/uuid/uuid_generators.hpp>  #include <iostream> +StaticMessageException(InvalidScriptName, "Script name should be group/name");  SimpleMessageException(UnknownPlatformAlias);  class ShowHelpTrigger : public Options::Target { @@ -135,3 +136,17 @@ ConsoleApplicationEngine::process()  		Plugable::onAllComponents(boost::bind(&ComponentLoader::onIteration, _1));  	}  } + +void +ConsoleApplicationEngine::appendScript(const char * arg) +{ +	const char * sl = strchr(arg, '/'); +	if (sl) { +		todolist.push_back(ConsoleApplicationEngine::ToDo(std::string(arg, sl), sl + 1)); +		sl++; +	} +	else { +		throw InvalidScriptName(); +	} +} + diff --git a/project2/console/consoleAppEngine.h b/project2/console/consoleAppEngine.h index b75d9b1..f4017e4 100644 --- a/project2/console/consoleAppEngine.h +++ b/project2/console/consoleAppEngine.h @@ -18,6 +18,8 @@ class ConsoleApplicationEngine : public ExecContext {  		VariableType getParameter(const VariableType&) const;  		SessionPtr getSession() const; +		static void appendScript(const char * arg); +  		INITOPTIONS;  	private: @@ -28,7 +30,6 @@ class ConsoleApplicationEngine : public ExecContext {  		typedef std::map<Glib::ustring, const Glib::ustring> ConsolePlatforms;  		typedef std::map<std::string, std::string> Parameters; -		friend class CommandLineArguments;  		mutable ConsolePlatforms conplat;  		SessionPtr runtime;  		MultiRowSetPresenterPtr presenter; diff --git a/project2/console/p2consoleMain.cpp b/project2/console/p2consoleMain.cpp index 3c0f473..6b9a2ea 100644 --- a/project2/console/p2consoleMain.cpp +++ b/project2/console/p2consoleMain.cpp @@ -6,7 +6,7 @@  int  main(int argc, char ** argv)  { -	Plugable::newLoader<OptionsSource, OptionsSource>("", new CommandLineArguments(argc, argv)); +	Plugable::newLoader<OptionsSource, OptionsSource>("", new CommandLineArguments(argc, argv, &ConsoleApplicationEngine::appendScript));  	Plugable::onAllComponents(boost::bind(&ComponentLoader::onBegin, _1));  	OptionsSource::loadSources([] { return ConsoleApplicationEngine::reqPlatform;} ); | 
