2005-07-20 10:55:40 -05:00
|
|
|
#include <windows.h>
|
2005-09-13 14:53:19 -05:00
|
|
|
#include <signal.h>
|
2005-07-20 10:55:40 -05:00
|
|
|
#include "log.h"
|
|
|
|
#include "options.h"
|
|
|
|
#include "IMService.h"
|
2005-09-13 14:53:19 -05:00
|
|
|
#include "manager.h"
|
2005-07-20 10:55:40 -05:00
|
|
|
|
|
|
|
IMService::IMService(void)
|
|
|
|
{
|
2005-08-05 17:02:06 +04:00
|
|
|
serviceName= "MySqlManager";
|
|
|
|
displayName= "MySQL Manager";
|
2005-09-13 14:53:19 -05:00
|
|
|
username= NULL;
|
|
|
|
password= NULL;
|
2005-07-20 10:55:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
IMService::~IMService(void)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void IMService::Stop()
|
|
|
|
{
|
|
|
|
ReportStatus(SERVICE_STOP_PENDING);
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2005-07-20 10:55:40 -05:00
|
|
|
// stop the IM work
|
2005-09-13 14:53:19 -05:00
|
|
|
raise(SIGTERM);
|
2005-07-20 10:55:40 -05:00
|
|
|
}
|
|
|
|
|
2005-09-13 14:53:19 -05:00
|
|
|
void IMService::Run(DWORD argc, LPTSTR *argv)
|
2005-07-20 10:55:40 -05:00
|
|
|
{
|
|
|
|
// report to the SCM that we're about to start
|
|
|
|
ReportStatus((DWORD)SERVICE_START_PENDING);
|
|
|
|
|
2006-05-19 04:51:23 +04:00
|
|
|
Options::load(argc, argv);
|
2006-05-18 18:57:50 +04:00
|
|
|
|
2005-07-20 10:55:40 -05:00
|
|
|
// init goes here
|
2005-08-03 16:20:27 -05:00
|
|
|
ReportStatus((DWORD)SERVICE_RUNNING);
|
2005-07-20 10:55:40 -05:00
|
|
|
|
|
|
|
// wait for main loop to terminate
|
2006-05-19 04:51:23 +04:00
|
|
|
manager();
|
|
|
|
Options::cleanup();
|
2005-07-20 10:55:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void IMService::Log(const char *msg)
|
|
|
|
{
|
|
|
|
log_info(msg);
|
|
|
|
}
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
int HandleServiceOptions()
|
2005-07-20 10:55:40 -05:00
|
|
|
{
|
2005-08-03 16:20:27 -05:00
|
|
|
int ret_val= 0;
|
2005-07-20 10:55:40 -05:00
|
|
|
|
|
|
|
IMService winService;
|
|
|
|
|
2006-05-18 18:57:50 +04:00
|
|
|
if (Options::Service::install_as_service)
|
2005-07-20 10:55:40 -05:00
|
|
|
{
|
|
|
|
if (winService.IsInstalled())
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service is already installed");
|
2005-07-20 10:55:40 -05:00
|
|
|
else if (winService.Install())
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service installed successfully");
|
2005-07-20 10:55:40 -05:00
|
|
|
else
|
|
|
|
{
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service failed to install");
|
2005-08-09 07:57:37 -06:00
|
|
|
ret_val= 1;
|
2005-07-20 10:55:40 -05:00
|
|
|
}
|
|
|
|
}
|
2006-05-18 18:57:50 +04:00
|
|
|
else if (Options::Service::remove_service)
|
2005-07-20 10:55:40 -05:00
|
|
|
{
|
|
|
|
if (! winService.IsInstalled())
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service is not installed");
|
2005-08-03 16:20:27 -05:00
|
|
|
else if (winService.Remove())
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service removed successfully");
|
2005-08-05 17:02:06 +04:00
|
|
|
else
|
2005-07-20 10:55:40 -05:00
|
|
|
{
|
2005-08-09 07:57:36 -06:00
|
|
|
log_info("Service failed to remove");
|
2005-08-09 07:57:37 -06:00
|
|
|
ret_val= 1;
|
2005-07-20 10:55:40 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
2006-05-18 18:57:50 +04:00
|
|
|
{
|
|
|
|
log_info("Initializing Instance Manager service...");
|
|
|
|
|
|
|
|
if (!winService.Init())
|
|
|
|
{
|
|
|
|
log_info("Service failed to initialize.");
|
|
|
|
fprintf(stderr,
|
|
|
|
"The service should be started by Windows Service Manager.\n"
|
|
|
|
"The MySQL Manager should be started with '--standalone'\n"
|
|
|
|
"to run from command line.");
|
|
|
|
ret_val= 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-07-20 10:55:40 -05:00
|
|
|
return ret_val;
|
|
|
|
}
|