we really should use this way to comment.
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@4423 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
9b43057b29
commit
49e689b3b5
107
src/switch.c
107
src/switch.c
|
@ -35,18 +35,18 @@
|
||||||
|
|
||||||
#include <switch.h>
|
#include <switch.h>
|
||||||
|
|
||||||
//pid filename: Stores the process id of the freeswitch process
|
/* pid filename: Stores the process id of the freeswitch process */
|
||||||
#define PIDFILE "freeswitch.pid"
|
#define PIDFILE "freeswitch.pid"
|
||||||
static char *pfile = PIDFILE;
|
static char *pfile = PIDFILE;
|
||||||
|
|
||||||
//log filename: Filename of the freeswitch log file to be used if we are in background mode
|
/* log filename: Filename of the freeswitch log file to be used if we are in background mode */
|
||||||
#define LOGFILE "freeswitch.log"
|
#define LOGFILE "freeswitch.log"
|
||||||
static char *lfile = LOGFILE;
|
static char *lfile = LOGFILE;
|
||||||
|
|
||||||
//If we are a windows service, what should we be called
|
/* If we are a windows service, what should we be called */
|
||||||
#define SERVICENAME "Freeswitch"
|
#define SERVICENAME "Freeswitch"
|
||||||
|
|
||||||
//Picky compiler
|
/* Picky compiler */
|
||||||
#ifdef __ICC
|
#ifdef __ICC
|
||||||
#pragma warning (disable:167)
|
#pragma warning (disable:167)
|
||||||
#endif
|
#endif
|
||||||
|
@ -55,73 +55,74 @@ static char *lfile = LOGFILE;
|
||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
|
||||||
//event to signal shutdown (for you unix people, this is like a pthread_cond)
|
/* event to signal shutdown (for you unix people, this is like a pthread_cond) */
|
||||||
static HANDLE shutdown_event;
|
static HANDLE shutdown_event;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//signal handler for when freeswitch is running in background mode.
|
/* signal handler for when freeswitch is running in background mode.
|
||||||
//signal triggers the shutdown of freeswitch
|
* signal triggers the shutdown of freeswitch
|
||||||
|
*/
|
||||||
static void handle_SIGHUP(int sig)
|
static void handle_SIGHUP(int sig)
|
||||||
{
|
{
|
||||||
uint32_t arg = 0;
|
uint32_t arg = 0;
|
||||||
if(sig);
|
if(sig);
|
||||||
//send shutdown signal to the freeswitch core
|
/* send shutdown signal to the freeswitch core */
|
||||||
switch_core_session_ctl(SCSC_SHUTDOWN, &arg);
|
switch_core_session_ctl(SCSC_SHUTDOWN, &arg);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
//kill a freeswitch process running in background mode
|
/* kill a freeswitch process running in background mode */
|
||||||
static int freeswitch_kill_background()
|
static int freeswitch_kill_background()
|
||||||
{
|
{
|
||||||
FILE *f; //FILE handle to open the pid file
|
FILE *f; /* FILE handle to open the pid file */
|
||||||
char path[256] = ""; //full path of the PID file
|
char path[256] = ""; /* full path of the PID file */
|
||||||
pid_t pid = 0; //pid from the pid file
|
pid_t pid = 0; /* pid from the pid file */
|
||||||
|
|
||||||
//set the globals so we can use the global paths.
|
/* set the globals so we can use the global paths. */
|
||||||
switch_core_set_globals();
|
switch_core_set_globals();
|
||||||
|
|
||||||
//get the full path of the pid file.
|
/* get the full path of the pid file. */
|
||||||
snprintf(path, sizeof(path), "%s%s%s", SWITCH_GLOBAL_dirs.log_dir, SWITCH_PATH_SEPARATOR, pfile);
|
snprintf(path, sizeof(path), "%s%s%s", SWITCH_GLOBAL_dirs.log_dir, SWITCH_PATH_SEPARATOR, pfile);
|
||||||
|
|
||||||
//open the pid file
|
/* open the pid file */
|
||||||
if ((f = fopen(path, "r")) == 0) {
|
if ((f = fopen(path, "r")) == 0) {
|
||||||
//pid file does not exist
|
/* pid file does not exist */
|
||||||
fprintf(stderr, "Cannot open pid file %s.\n", path);
|
fprintf(stderr, "Cannot open pid file %s.\n", path);
|
||||||
return 255;
|
return 255;
|
||||||
}
|
}
|
||||||
|
|
||||||
//pull the pid from the file
|
/* pull the pid from the file */
|
||||||
fscanf(f, "%d", &pid);
|
fscanf(f, "%d", &pid);
|
||||||
|
|
||||||
//if we have a valid pid
|
/* if we have a valid pid */
|
||||||
if (pid > 0) {
|
if (pid > 0) {
|
||||||
|
|
||||||
//kill the freeswitch running at the pid we found
|
/* kill the freeswitch running at the pid we found */
|
||||||
fprintf(stderr, "Killing: %d\n", (int) pid);
|
fprintf(stderr, "Killing: %d\n", (int) pid);
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
//for windows we need the event to signal for shutting down a background freewitc
|
/* for windows we need the event to signal for shutting down a background freewitch */
|
||||||
snprintf(path, sizeof(path), "Global\\Freeswitch.%d", pid);
|
snprintf(path, sizeof(path), "Global\\Freeswitch.%d", pid);
|
||||||
|
|
||||||
//open the event so we can signal it
|
/* open the event so we can signal it */
|
||||||
shutdown_event = OpenEvent(EVENT_MODIFY_STATE, FALSE, path);
|
shutdown_event = OpenEvent(EVENT_MODIFY_STATE, FALSE, path);
|
||||||
|
|
||||||
//did we sucessfully open the event
|
/* did we sucessfully open the event */
|
||||||
if (!shutdown_event) {
|
if (!shutdown_event) {
|
||||||
/* we can't get the event, so we can't signal the process to shutdown */
|
/* we can't get the event, so we can't signal the process to shutdown */
|
||||||
fprintf(stderr, "ERROR: Can't Shutdown: %d\n", (int) pid);
|
fprintf(stderr, "ERROR: Can't Shutdown: %d\n", (int) pid);
|
||||||
} else {
|
} else {
|
||||||
//signal the event to shutdown
|
/* signal the event to shutdown */
|
||||||
SetEvent(shutdown_event);
|
SetEvent(shutdown_event);
|
||||||
}
|
}
|
||||||
//cleanup
|
/* cleanup */
|
||||||
CloseHandle(shutdown_event);
|
CloseHandle(shutdown_event);
|
||||||
#else
|
#else
|
||||||
//for unix, send the signal to kill.
|
/* for unix, send the signal to kill. */
|
||||||
kill(pid, SIGTERM);
|
kill(pid, SIGTERM);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//be nice and close the file handle to the pid file
|
/* be nice and close the file handle to the pid file */
|
||||||
fclose(f);
|
fclose(f);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -129,81 +130,81 @@ static int freeswitch_kill_background()
|
||||||
|
|
||||||
#ifdef WIN32
|
#ifdef WIN32
|
||||||
|
|
||||||
//we need these vars to handle the service
|
/* we need these vars to handle the service */
|
||||||
SERVICE_STATUS_HANDLE hStatus;
|
SERVICE_STATUS_HANDLE hStatus;
|
||||||
SERVICE_STATUS status;
|
SERVICE_STATUS status;
|
||||||
|
|
||||||
//Handler function for service start/stop from the service
|
/* Handler function for service start/stop from the service */
|
||||||
void WINAPI ServiceCtrlHandler( DWORD control )
|
void WINAPI ServiceCtrlHandler( DWORD control )
|
||||||
{
|
{
|
||||||
switch( control )
|
switch( control )
|
||||||
{
|
{
|
||||||
case SERVICE_CONTROL_SHUTDOWN:
|
case SERVICE_CONTROL_SHUTDOWN:
|
||||||
case SERVICE_CONTROL_STOP:
|
case SERVICE_CONTROL_STOP:
|
||||||
//Shutdown freeswitch
|
/* Shutdown freeswitch */
|
||||||
switch_core_destroy(0);
|
switch_core_destroy(0);
|
||||||
//set service status valuse
|
/* set service status valuse */
|
||||||
status.dwCurrentState = SERVICE_STOPPED;
|
status.dwCurrentState = SERVICE_STOPPED;
|
||||||
status.dwWin32ExitCode = 0;
|
status.dwWin32ExitCode = 0;
|
||||||
status.dwCheckPoint = 0;
|
status.dwCheckPoint = 0;
|
||||||
status.dwWaitHint = 0;
|
status.dwWaitHint = 0;
|
||||||
break;
|
break;
|
||||||
case SERVICE_CONTROL_INTERROGATE:
|
case SERVICE_CONTROL_INTERROGATE:
|
||||||
// we already set the service status every time it changes.
|
/* we already set the service status every time it changes. */
|
||||||
// if there are other times we change it and don't update, we should do so here
|
/* if there are other times we change it and don't update, we should do so here */
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
SetServiceStatus( hStatus, &status );
|
SetServiceStatus( hStatus, &status );
|
||||||
}
|
}
|
||||||
|
|
||||||
//the main service entry point
|
/* the main service entry point */
|
||||||
void WINAPI service_main( DWORD numArgs, char **args )
|
void WINAPI service_main( DWORD numArgs, char **args )
|
||||||
{
|
{
|
||||||
const char *err = NULL; //error value for return from freeswitch initialization
|
const char *err = NULL; /* error value for return from freeswitch initialization */
|
||||||
// we have to initialize the service-specific stuff
|
/* we have to initialize the service-specific stuff */
|
||||||
memset( &status, 0, sizeof(SERVICE_STATUS) );
|
memset( &status, 0, sizeof(SERVICE_STATUS) );
|
||||||
status.dwServiceType = SERVICE_WIN32;
|
status.dwServiceType = SERVICE_WIN32;
|
||||||
status.dwCurrentState = SERVICE_START_PENDING;
|
status.dwCurrentState = SERVICE_START_PENDING;
|
||||||
status.dwControlsAccepted = SERVICE_ACCEPT_STOP;
|
status.dwControlsAccepted = SERVICE_ACCEPT_STOP;
|
||||||
|
|
||||||
//register our handler for service control messages
|
/* register our handler for service control messages */
|
||||||
hStatus = RegisterServiceCtrlHandler( SERVICENAME, &ServiceCtrlHandler );
|
hStatus = RegisterServiceCtrlHandler( SERVICENAME, &ServiceCtrlHandler );
|
||||||
|
|
||||||
//update the service status
|
/* update the service status */
|
||||||
SetServiceStatus( hStatus, &status );
|
SetServiceStatus( hStatus, &status );
|
||||||
|
|
||||||
//run freeswitch with elevated priority
|
/* run freeswitch with elevated priority */
|
||||||
set_high_priority();
|
set_high_priority();
|
||||||
|
|
||||||
//attempt to initialize freeswitch and load modules
|
/* attempt to initialize freeswitch and load modules */
|
||||||
if (switch_core_init_and_modload(lfile, &err) != SWITCH_STATUS_SUCCESS) {
|
if (switch_core_init_and_modload(lfile, &err) != SWITCH_STATUS_SUCCESS) {
|
||||||
//freeswitch did not start sucessfully
|
/* freeswitch did not start sucessfully */
|
||||||
status.dwCurrentState = SERVICE_STOPPED;
|
status.dwCurrentState = SERVICE_STOPPED;
|
||||||
} else {
|
} else {
|
||||||
//freeswitch started
|
/* freeswitch started */
|
||||||
status.dwCurrentState = SERVICE_RUNNING;
|
status.dwCurrentState = SERVICE_RUNNING;
|
||||||
}
|
}
|
||||||
|
|
||||||
//update the service status
|
/* update the service status */
|
||||||
SetServiceStatus( hStatus, &status );
|
SetServiceStatus( hStatus, &status );
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
//the main application entry point
|
/* the main application entry point */
|
||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
char pid_path[256] = ""; // full path to the pid file
|
char pid_path[256] = ""; /* full path to the pid file */
|
||||||
const char *err = NULL; // error value for return from freeswitch initialization
|
const char *err = NULL; /* error value for return from freeswitch initialization */
|
||||||
#ifndef WIN32
|
#ifndef WIN32
|
||||||
int nf = 0; // TRUE if we are running in nofork mode
|
int nf = 0; /* TRUE if we are running in nofork mode */
|
||||||
#endif
|
#endif
|
||||||
int nc = 0; // TRUE if we are running in noconsole mode
|
int nc = 0; /* TRUE if we are running in noconsole mode */
|
||||||
FILE *f; // file handle to the pid file
|
FILE *f; /* file handle to the pid file */
|
||||||
pid_t pid = 0; //
|
pid_t pid = 0;
|
||||||
int x; //
|
int x;
|
||||||
int die = 0; //
|
int die = 0;
|
||||||
char *usageDesc;
|
char *usageDesc;
|
||||||
int alt_dirs = 0;
|
int alt_dirs = 0;
|
||||||
|
|
||||||
|
@ -245,7 +246,7 @@ int main(int argc, char *argv[])
|
||||||
if (x == 1) {
|
if (x == 1) {
|
||||||
if (argv[x] && !strcmp(argv[x], "-service")) {
|
if (argv[x] && !strcmp(argv[x], "-service")) {
|
||||||
if(StartServiceCtrlDispatcher( dispatchTable ) == 0 ) {
|
if(StartServiceCtrlDispatcher( dispatchTable ) == 0 ) {
|
||||||
//Not loaded as a service
|
/* Not loaded as a service */
|
||||||
fprintf(stderr, "Error Freeswitch loaded as a console app with -service option\n");
|
fprintf(stderr, "Error Freeswitch loaded as a console app with -service option\n");
|
||||||
fprintf(stderr, "To install the service load freeswitch with -install\n");
|
fprintf(stderr, "To install the service load freeswitch with -install\n");
|
||||||
}
|
}
|
||||||
|
@ -279,7 +280,7 @@ int main(int argc, char *argv[])
|
||||||
SC_HANDLE handle = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS );
|
SC_HANDLE handle = OpenSCManager( NULL, NULL, SC_MANAGER_ALL_ACCESS );
|
||||||
SC_HANDLE service = OpenService( handle, SERVICENAME, DELETE );
|
SC_HANDLE service = OpenService( handle, SERVICENAME, DELETE );
|
||||||
if( service != NULL ) {
|
if( service != NULL ) {
|
||||||
// remove the service!
|
/* remove the service! */
|
||||||
DeleteService( service );
|
DeleteService( service );
|
||||||
}
|
}
|
||||||
exit(0);
|
exit(0);
|
||||||
|
|
Loading…
Reference in New Issue