2012-07-13 21:07:39 +02:00
|
|
|
/******************************************************************************
|
|
|
|
* Icinga 2 *
|
|
|
|
* Copyright (C) 2012 Icinga Development Team (http://www.icinga.org/) *
|
|
|
|
* *
|
|
|
|
* This program 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 2 *
|
|
|
|
* of the License, or (at your option) any later version. *
|
|
|
|
* *
|
|
|
|
* This program 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 this program; if not, write to the Free Software Foundation *
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA. *
|
|
|
|
******************************************************************************/
|
|
|
|
|
2012-07-13 21:00:54 +02:00
|
|
|
#include "i2-base.h"
|
2013-02-10 18:57:23 +01:00
|
|
|
|
2012-07-13 21:00:54 +02:00
|
|
|
using namespace icinga;
|
|
|
|
|
2013-02-17 19:14:34 +01:00
|
|
|
boost::once_flag Process::m_ThreadOnce;
|
2012-07-13 21:00:54 +02:00
|
|
|
boost::mutex Process::m_Mutex;
|
|
|
|
deque<Process::Ptr> Process::m_Tasks;
|
2013-02-20 19:52:25 +01:00
|
|
|
double Process::m_LastReport = 0;
|
2013-02-10 12:45:39 +01:00
|
|
|
|
|
|
|
Process::Process(const vector<String>& arguments, const Dictionary::Ptr& extraEnvironment)
|
2013-02-13 11:39:24 +01:00
|
|
|
: AsyncTask<Process, ProcessResult>(), m_Arguments(arguments), m_ExtraEnvironment(extraEnvironment)
|
2012-07-13 21:00:54 +02:00
|
|
|
{
|
2013-02-19 23:02:08 +01:00
|
|
|
{
|
|
|
|
boost::mutex::scoped_lock lock(m_Mutex);
|
|
|
|
boost::call_once(&Process::Initialize, m_ThreadOnce);
|
|
|
|
}
|
2013-02-10 12:45:39 +01:00
|
|
|
|
2013-02-13 11:39:24 +01:00
|
|
|
#ifndef _WIN32
|
|
|
|
m_FD = -1;
|
2013-02-13 11:48:19 +01:00
|
|
|
#endif /* _WIN32 */
|
2013-02-10 12:45:39 +01:00
|
|
|
}
|
|
|
|
|
2013-02-13 20:08:09 +01:00
|
|
|
vector<String> Process::SplitCommand(const Value& command)
|
2013-02-10 12:45:39 +01:00
|
|
|
{
|
|
|
|
vector<String> args;
|
2013-02-13 20:08:09 +01:00
|
|
|
|
|
|
|
if (command.IsObjectType<Dictionary>()) {
|
|
|
|
Dictionary::Ptr dict = command;
|
|
|
|
Value arg;
|
|
|
|
BOOST_FOREACH(tie(tuples::ignore, arg), dict) {
|
|
|
|
args.push_back(arg);
|
|
|
|
}
|
|
|
|
|
|
|
|
return args;
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: implement
|
2013-02-13 11:39:24 +01:00
|
|
|
#ifdef _WIN32
|
2013-02-10 14:07:17 +01:00
|
|
|
args.push_back(command);
|
2013-02-13 11:39:24 +01:00
|
|
|
#else /* _WIN32 */
|
2013-02-10 12:45:39 +01:00
|
|
|
args.push_back("sh");
|
|
|
|
args.push_back("-c");
|
|
|
|
args.push_back(command);
|
2013-02-10 14:07:17 +01:00
|
|
|
#endif
|
2013-02-10 12:45:39 +01:00
|
|
|
return args;
|
2012-07-13 21:00:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void Process::Run(void)
|
|
|
|
{
|
2013-02-20 19:52:25 +01:00
|
|
|
int count;
|
|
|
|
|
2013-02-10 01:35:40 +01:00
|
|
|
{
|
|
|
|
boost::mutex::scoped_lock lock(m_Mutex);
|
|
|
|
m_Tasks.push_back(GetSelf());
|
2013-02-20 19:52:25 +01:00
|
|
|
count = m_Tasks.size();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (count > 50 && Utility::GetTime() - m_LastReport > 5) {
|
|
|
|
Logger::Write(LogInformation, "base", "More than 50 pending Process tasks: " +
|
|
|
|
Convert::ToString(count));
|
|
|
|
m_LastReport = Utility::GetTime();
|
2013-02-10 01:35:40 +01:00
|
|
|
}
|
|
|
|
|
2013-02-13 11:39:24 +01:00
|
|
|
NotifyWorker();
|
2012-07-13 21:00:54 +02:00
|
|
|
}
|