diff options
| author | Jelmer Vernooij <jelmer@samba.org> | 2005-11-07 17:42:49 +0100 | 
|---|---|---|
| committer | Jelmer Vernooij <jelmer@samba.org> | 2005-11-07 17:42:49 +0100 | 
| commit | abe53d3c48a6552e136ddc8bc554764daf255a05 (patch) | |
| tree | 946f5254a5a3931e2d48eefc4d697fae59500260 /win32.c | |
| parent | 99318adcb88fa3f1dd21882ec364e682fec96c5e (diff) | |
More work on config manager
Diffstat (limited to 'win32.c')
| -rw-r--r-- | win32.c | 136 | 
1 files changed, 87 insertions, 49 deletions
| @@ -50,10 +50,47 @@ static void WINAPI service_ctrl (DWORD dwControl)      }  } +
 +static void bitlbee_init(int argc, char **argv)
 +{
 +	int i = -1;
 +	memset( &global, 0, sizeof( global_t ) );
 +	
 +	global.loop = g_main_new( FALSE );
 +	
 +	global.conf = conf_load( argc, argv );
 +	if( global.conf == NULL )
 +		return;
 +	
 +	if( global.conf->runmode == RUNMODE_INETD )
 +	{
 +		i = bitlbee_inetd_init();
 +		log_message( LOGLVL_INFO, "Bitlbee %s starting in inetd mode.", BITLBEE_VERSION );
 +
 +	}
 +	else if( global.conf->runmode == RUNMODE_DAEMON )
 +	{
 +		i = bitlbee_daemon_init();
 +		log_message( LOGLVL_INFO, "Bitlbee %s starting in daemon mode.", BITLBEE_VERSION );
 +	} 
 +	else 
 +	{
 +		log_message( LOGLVL_INFO, "No bitlbee mode specified...");
 +	}
 +	
 +	if( i != 0 )
 +		return;
 + 	
 +	if( access( global.conf->configdir, F_OK ) != 0 )
 +		log_message( LOGLVL_WARNING, "The configuration directory %s does not exist. Configuration won't be saved.", global.conf->configdir );
 +	else if( access( global.conf->configdir, 06 ) != 0 )
 +		log_message( LOGLVL_WARNING, "Permission problem: Can't read/write from/to %s.", global.conf->configdir );
 +	if( help_init( &(global.help) ) == NULL )
 +		log_message( LOGLVL_WARNING, "Error opening helpfile %s.", global.helpfile );
 +}
  void service_main (DWORD argc, LPTSTR *argv)  { -	int i = -1;  	SERVICE_STATUS_HANDLE handle;
  	SERVICE_STATUS status; @@ -64,58 +101,53 @@ void service_main (DWORD argc, LPTSTR *argv)      status.dwServiceType = SERVICE_WIN32_OWN_PROCESS;      status.dwServiceSpecificExitCode = 0; - -	memset( &global, 0, sizeof( global_t ) ); -	 -	global.loop = g_main_new( FALSE ); -	 -	global.conf = conf_load( argc, argv ); -	if( global.conf == NULL ) -		return; -	 -	if( global.conf->runmode == RUNMODE_INETD ) -	{ -		i = bitlbee_inetd_init(); -		log_message( LOGLVL_INFO, "Bitlbee %s starting in inetd mode.", BITLBEE_VERSION ); - -	} -	else if( global.conf->runmode == RUNMODE_DAEMON ) -	{ -		i = bitlbee_daemon_init(); -		log_message( LOGLVL_INFO, "Bitlbee %s starting in daemon mode.", BITLBEE_VERSION ); -	}  -	else  -	{ -		log_message( LOGLVL_INFO, "No bitlbee mode specified..."); -	} -	 -	if( i != 0 ) -		return; - 	 -	if( access( global.conf->configdir, F_OK ) != 0 ) -		log_message( LOGLVL_WARNING, "The configuration directory %s does not exist. Configuration won't be saved.", global.conf->configdir ); -	else if( access( global.conf->configdir, 06 ) != 0 ) -		log_message( LOGLVL_WARNING, "Permission problem: Can't read/write from/to %s.", global.conf->configdir ); -	if( help_init( &(global.help) ) == NULL ) -		log_message( LOGLVL_WARNING, "Error opening helpfile %s.", global.helpfile ); +
 +	bitlbee_init(argc, argv);  	SetServiceStatus(handle, &status);  	g_main_run( global.loop );  } -int WINAPI WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow) -{ -    SERVICE_TABLE_ENTRY dispatch_table[] = -    { -        { TEXT("bitlbee"), (LPSERVICE_MAIN_FUNCTION)service_main }, -        { NULL, NULL } -    };
 +SERVICE_TABLE_ENTRY dispatch_table[] =
 +{
 +   { TEXT("bitlbee"), (LPSERVICE_MAIN_FUNCTION)service_main },
 +   { NULL, NULL }
 +};
 +
 +static int debug = 0;
 +
 +static void usage()
 +{
 +	printf("Options:\n");
 +	printf("-h   Show this help message\n");
 +	printf("-d   Debug mode (simple console program)\n");
 +}
 +
 +int main( int argc, char **argv) +{    
 +	int i;
 +	WSADATA WSAData;
  	nogaim_init( );
 - -    if (!StartServiceCtrlDispatcher(dispatch_table)) -		log_message( LOGLVL_ERROR, "StartServiceCtrlDispatcher failed."); +
 +	for (i = 1; i < argc; i++) {
 +		if (!strcmp(argv[i], "-d")) debug = 1;
 +		if (!strcmp(argv[i], "-h")) {
 +			usage();
 +			return 0;
 +		}
 +	}
 +
 +    WSAStartup(MAKEWORD(1,1), &WSAData);
 +
 +	if (!debug) { +		if (!StartServiceCtrlDispatcher(dispatch_table)) +			log_message( LOGLVL_ERROR, "StartServiceCtrlDispatcher failed.");
 +	} else {
 +			bitlbee_init(argc, argv);
 + 			g_main_run( global.loop );
 +	}  	return 0;
  } @@ -164,7 +196,6 @@ conf_t *conf_load( int argc, char *argv[] )  	memset( &global, 0, sizeof( global_t ) );  	global.loop = g_main_new(FALSE); -	nogaim_init();  	conf = g_new0( conf_t,1 );  	global.conf = conf; @@ -177,8 +208,8 @@ conf_t *conf_load( int argc, char *argv[] )  	conf_get_string(key_main, "configdir", NULL, &global.conf->configdir);  	conf_get_string(key_main, "motdfile", NULL, &global.conf->motdfile);  	conf_get_string(key_main, "helpfile", NULL, &global.helpfile); -	global.conf->runmode = RUNMODE_INETD; -	conf_get_int(key_main, "AuthMode", AUTHMODE_CLOSED, &global.conf->authmode); +	global.conf->runmode = RUNMODE_DAEMON; +	conf_get_int(key_main, "AuthMode", AUTHMODE_OPEN, &global.conf->authmode);  	conf_get_string(key_proxy, "host", "", &tmp); strcpy(proxyhost, tmp);  	conf_get_string(key_proxy, "user", "", &tmp); strcpy(proxyuser, tmp);  	conf_get_string(key_proxy, "password", "", &tmp); strcpy(proxypass, tmp); @@ -242,7 +273,14 @@ void log_message(int level, char *message, ...)  	WORD elevel;      va_list ap; -    va_start(ap, message); +    va_start(ap, message);
 +
 +	if (debug) {
 +		vprintf(message, ap);
 +		putchar('\n');
 +		va_end(ap);
 +		return;
 +	}      hEventSource = RegisterEventSource(NULL, TEXT("bitlbee")); | 
