Changes in / [b8ef1b1:1aa0bb5]
- Files:
-
- 3 added
- 16 edited
Legend:
- Unmodified
- Added
- Removed
-
.bzrignore
rb8ef1b1 r1aa0bb5 8 8 build-arch-stamp 9 9 tags 10 decode 11 encode -
Makefile
rb8ef1b1 r1aa0bb5 10 10 11 11 # Program variables 12 objects = account.o bitlbee.o commands.o conf.o crypting.o help.o ini.o irc.o log.o nick.o query.o set.o unix.o url.o user.o 12 objects = account.o bitlbee.o commands.o conf.o crypting.o help.o ini.o irc.o log.o nick.o query.o set.o unix.o url.o user.o storage_text.o storage.o 13 13 subdirs = protocols 14 14 -
bitlbee.c
rb8ef1b1 r1aa0bb5 27 27 #include "bitlbee.h" 28 28 #include "commands.h" 29 #include "crypting.h"30 29 #include "protocols/nogaim.h" 31 30 #include "help.h" … … 244 243 } 245 244 246 int bitlbee_load( irc_t *irc, char* password )247 {248 char s[512];249 char *line;250 int proto;251 char nick[MAX_NICK_LENGTH+1];252 FILE *fp;253 user_t *ru = user_find( irc, ROOT_NICK );254 255 if( irc->status == USTATUS_IDENTIFIED )256 return( 1 );257 258 g_snprintf( s, 511, "%s%s%s", global.conf->configdir, irc->nick, ".accounts" );259 fp = fopen( s, "r" );260 if( !fp ) return( 0 );261 262 fscanf( fp, "%32[^\n]s", s );263 if( setpass( irc, password, s ) < 0 )264 {265 fclose( fp );266 return( -1 );267 }268 269 /* Do this now. If the user runs with AuthMode = Registered, the270 account command will not work otherwise. */271 irc->status = USTATUS_IDENTIFIED;272 273 while( fscanf( fp, "%511[^\n]s", s ) > 0 )274 {275 fgetc( fp );276 line = deobfucrypt( irc, s );277 root_command_string( irc, ru, line, 0 );278 g_free( line );279 }280 fclose( fp );281 282 g_snprintf( s, 511, "%s%s%s", global.conf->configdir, irc->nick, ".nicks" );283 fp = fopen( s, "r" );284 if( !fp ) return( 0 );285 while( fscanf( fp, "%s %d %s", s, &proto, nick ) > 0 )286 {287 http_decode( s );288 nick_set( irc, s, proto, nick );289 }290 fclose( fp );291 292 if( set_getint( irc, "auto_connect" ) )293 {294 strcpy( s, "account on" ); /* Can't do this directly because r_c_s alters the string */295 root_command_string( irc, ru, s, 0 );296 }297 298 return( 1 );299 }300 301 int bitlbee_save( irc_t *irc )302 {303 char s[512];304 char path[512], new_path[512];305 char *line;306 nick_t *n;307 set_t *set;308 mode_t ou = umask( 0077 );309 account_t *a;310 FILE *fp;311 char *hash;312 313 /*\314 * [SH] Nothing should be saved if no password is set, because the315 * password is not set if it was wrong, or if one is not identified316 * yet. This means that a malicious user could easily overwrite317 * files owned by someone else:318 * a Bad Thing, methinks319 \*/320 321 /* [WVG] No? Really? */322 323 /*\324 * [SH] Okay, okay, it wasn't really Wilmer who said that, it was325 * me. I just thought it was funny.326 \*/327 328 hash = hashpass( irc );329 if( hash == NULL )330 {331 irc_usermsg( irc, "Please register yourself if you want to save your settings." );332 return( 0 );333 }334 335 g_snprintf( path, 511, "%s%s%s", global.conf->configdir, irc->nick, ".nicks~" );336 fp = fopen( path, "w" );337 if( !fp ) return( 0 );338 for( n = irc->nicks; n; n = n->next )339 {340 strcpy( s, n->handle );341 s[169] = 0; /* Prevent any overflow (169 ~ 512 / 3) */342 http_encode( s );343 g_snprintf( s + strlen( s ), 510 - strlen( s ), " %d %s", n->proto, n->nick );344 if( fprintf( fp, "%s\n", s ) != strlen( s ) + 1 )345 {346 irc_usermsg( irc, "fprintf() wrote too little. Disk full?" );347 fclose( fp );348 return( 0 );349 }350 }351 if( fclose( fp ) != 0 )352 {353 irc_usermsg( irc, "fclose() reported an error. Disk full?" );354 return( 0 );355 }356 357 g_snprintf( new_path, 512, "%s%s%s", global.conf->configdir, irc->nick, ".nicks" );358 if( unlink( new_path ) != 0 )359 {360 if( errno != ENOENT )361 {362 irc_usermsg( irc, "Error while removing old .nicks file" );363 return( 0 );364 }365 }366 if( rename( path, new_path ) != 0 )367 {368 irc_usermsg( irc, "Error while renaming new .nicks file" );369 return( 0 );370 }371 372 g_snprintf( path, 511, "%s%s%s", global.conf->configdir, irc->nick, ".accounts~" );373 fp = fopen( path, "w" );374 if( !fp ) return( 0 );375 if( fprintf( fp, "%s", hash ) != strlen( hash ) )376 {377 irc_usermsg( irc, "fprintf() wrote too little. Disk full?" );378 fclose( fp );379 return( 0 );380 }381 g_free( hash );382 383 for( a = irc->accounts; a; a = a->next )384 {385 if( a->protocol == PROTO_OSCAR || a->protocol == PROTO_ICQ || a->protocol == PROTO_TOC )386 g_snprintf( s, sizeof( s ), "account add oscar \"%s\" \"%s\" %s", a->user, a->pass, a->server );387 else388 g_snprintf( s, sizeof( s ), "account add %s \"%s\" \"%s\" \"%s\"",389 proto_name[a->protocol], a->user, a->pass, a->server ? a->server : "" );390 391 line = obfucrypt( irc, s );392 if( *line )393 {394 if( fprintf( fp, "%s\n", line ) != strlen( line ) + 1 )395 {396 irc_usermsg( irc, "fprintf() wrote too little. Disk full?" );397 fclose( fp );398 return( 0 );399 }400 }401 g_free( line );402 }403 404 for( set = irc->set; set; set = set->next )405 {406 if( set->value && set->def )407 {408 g_snprintf( s, sizeof( s ), "set %s \"%s\"", set->key, set->value );409 line = obfucrypt( irc, s );410 if( *line )411 {412 if( fprintf( fp, "%s\n", line ) != strlen( line ) + 1 )413 {414 irc_usermsg( irc, "fprintf() wrote too little. Disk full?" );415 fclose( fp );416 return( 0 );417 }418 }419 g_free( line );420 }421 }422 423 if( strcmp( irc->mynick, ROOT_NICK ) != 0 )424 {425 g_snprintf( s, sizeof( s ), "rename %s %s", ROOT_NICK, irc->mynick );426 line = obfucrypt( irc, s );427 if( *line )428 {429 if( fprintf( fp, "%s\n", line ) != strlen( line ) + 1 )430 {431 irc_usermsg( irc, "fprintf() wrote too little. Disk full?" );432 fclose( fp );433 return( 0 );434 }435 }436 g_free( line );437 }438 if( fclose( fp ) != 0 )439 {440 irc_usermsg( irc, "fclose() reported an error. Disk full?" );441 return( 0 );442 }443 444 g_snprintf( new_path, 512, "%s%s%s", global.conf->configdir, irc->nick, ".accounts" );445 if( unlink( new_path ) != 0 )446 {447 if( errno != ENOENT )448 {449 irc_usermsg( irc, "Error while removing old .accounts file" );450 return( 0 );451 }452 }453 if( rename( path, new_path ) != 0 )454 {455 irc_usermsg( irc, "Error while renaming new .accounts file" );456 return( 0 );457 }458 459 umask( ou );460 461 return( 1 );462 }463 464 245 void bitlbee_shutdown( gpointer data ) 465 246 { -
bitlbee.h
rb8ef1b1 r1aa0bb5 100 100 101 101 #include "irc.h" 102 #include "storage.h" 102 103 #include "set.h" 103 104 #include "protocols/nogaim.h" … … 115 116 help_t *help; 116 117 conf_t *conf; 118 storage_t *storage; 117 119 char *helpfile; 118 120 GMainLoop *loop; … … 127 129 int root_command_string( irc_t *irc, user_t *u, char *command, int flags ); 128 130 int root_command( irc_t *irc, char *command[] ); 129 int bitlbee_load( irc_t *irc, char *password );130 int bitlbee_save( irc_t *irc );131 131 void bitlbee_shutdown( gpointer data ); 132 132 double gettime( void ); -
commands.c
rb8ef1b1 r1aa0bb5 86 86 int cmd_identify( irc_t *irc, char **cmd ) 87 87 { 88 int checkie = bitlbee_load( irc, cmd[1]);89 90 if( checkie == -1 )91 {88 storage_status_t status = global.storage->load( irc->nick, cmd[1], irc ); 89 90 switch (status) { 91 case STORAGE_INVALID_PASSWORD: 92 92 irc_usermsg( irc, "Incorrect password" ); 93 } 94 else if( checkie == 0 ) 95 { 93 break; 94 case STORAGE_NO_SUCH_USER: 96 95 irc_usermsg( irc, "The nick is (probably) not registered" ); 97 } 98 else if( checkie == 1 ) 99 { 96 break; 97 case STORAGE_OK: 100 98 irc_usermsg( irc, "Password accepted" ); 101 } 102 else 103 { 99 break; 100 default: 104 101 irc_usermsg( irc, "Something very weird happened" ); 102 break; 105 103 } 106 104 … … 110 108 int cmd_register( irc_t *irc, char **cmd ) 111 109 { 112 int checkie;113 char path[512];114 115 110 if( global.conf->authmode == AUTHMODE_REGISTERED ) 116 111 { … … 118 113 return( 0 ); 119 114 } 120 121 g_snprintf( path, 511, "%s%s%s", global.conf->configdir, irc->nick, ".accounts" ); 122 checkie = access( path, F_OK ); 123 124 g_snprintf( path, 511, "%s%s%s", global.conf->configdir, irc->nick, ".nicks" ); 125 checkie += access( path, F_OK ); 126 127 if( checkie == -2 ) 128 { 129 setpassnc( irc, cmd[1] ); 130 root_command_string( irc, user_find( irc, irc->mynick ), "save", 0 ); 131 irc->status = USTATUS_IDENTIFIED; 132 } 133 else 134 { 135 irc_usermsg( irc, "Nick is already registered" ); 115 116 irc_setpass( irc, cmd[1] ); 117 switch( global.storage->save( irc, FALSE )) { 118 case STORAGE_ALREADY_EXISTS: 119 irc_usermsg( irc, "Nick is already registered" ); 120 break; 121 122 case STORAGE_OK: 123 irc->status = USTATUS_IDENTIFIED; 124 break; 125 126 default: 127 irc_usermsg( irc, "Error registering" ); 128 break; 136 129 } 137 130 … … 141 134 int cmd_drop( irc_t *irc, char **cmd ) 142 135 { 143 char s[512]; 144 FILE *fp; 145 146 g_snprintf( s, 511, "%s%s%s", global.conf->configdir, irc->nick, ".accounts" ); 147 fp = fopen( s, "r" ); 148 if( !fp ) 149 { 136 storage_status_t status; 137 138 status = global.storage->remove (irc->nick, cmd[1]); 139 switch (status) { 140 case STORAGE_NO_SUCH_USER: 150 141 irc_usermsg( irc, "That account does not exist" ); 151 142 return( 0 ); 152 } 153 154 fscanf( fp, "%32[^\n]s", s ); 155 fclose( fp ); 156 if( setpass( irc, cmd[1], s ) < 0 ) 157 { 158 irc_usermsg( irc, "Incorrect password" ); 159 return( 0 ); 160 } 161 162 g_snprintf( s, 511, "%s%s%s", global.conf->configdir, irc->nick, ".accounts" ); 163 unlink( s ); 164 165 g_snprintf( s, 511, "%s%s%s", global.conf->configdir, irc->nick, ".nicks" ); 166 unlink( s ); 167 168 setpassnc( irc, NULL ); 169 irc_usermsg( irc, "Files belonging to account `%s' removed", irc->nick ); 170 171 return( 0 ); 143 case STORAGE_INVALID_PASSWORD: 144 irc_usermsg( irc, "Password invalid" ); 145 return( 0 ); 146 case STORAGE_OK: 147 irc_setpass( irc, NULL ); 148 irc_usermsg( irc, "Account `%s' removed", irc->nick ); 149 return( 0 ); 150 default: 151 irc_usermsg( irc, "Error: '%d'", status ); 152 return( 0 ); 153 } 172 154 } 173 155 … … 634 616 int cmd_save( irc_t *irc, char **cmd ) 635 617 { 636 if( bitlbee_save( irc ))618 if( global.storage->save( irc, TRUE ) == STORAGE_OK ) 637 619 irc_usermsg( irc, "Configuration saved" ); 638 620 else -
conf.c
rb8ef1b1 r1aa0bb5 50 50 conf->nofork = 0; 51 51 conf->verbose = 0; 52 conf->storage = "text"; 52 53 conf->runmode = RUNMODE_INETD; 53 54 conf->authmode = AUTHMODE_OPEN; … … 198 199 conf->motdfile = g_strdup( ini->value ); 199 200 } 201 else if( g_strcasecmp( ini->key, "storage" ) == 0 ) 202 { 203 g_free( conf->storage ); 204 conf->storage = g_strdup( ini->value ); 205 } 200 206 else if( g_strcasecmp( ini->key, "pinginterval" ) == 0 ) 201 207 { -
conf.h
rb8ef1b1 r1aa0bb5 42 42 char *configdir; 43 43 char *motdfile; 44 char *storage; 44 45 int ping_interval; 45 46 int ping_timeout; -
crypting.c
rb8ef1b1 r1aa0bb5 46 46 } irc_t; 47 47 48 #define set_add( a, b, c, d )49 #define set_find( a, b ) NULL50 51 48 #include "md5.h" 52 49 #include "crypting.h" … … 55 52 #include <stdlib.h> 56 53 57 #define irc_usermsg58 59 54 #endif 60 55 … … 65 60 \*/ 66 61 67 /* USE WITH CAUTION! 68 Sets pass without checking */ 69 void setpassnc (irc_t *irc, char *pass) { 70 if (!set_find (irc, "password")) 71 set_add (irc, "password", NULL, passchange); 72 73 if (irc->password) g_free (irc->password); 74 75 if (pass) { 76 irc->password = g_strdup (pass); 77 irc_usermsg (irc, "Password successfully changed"); 78 } else { 79 irc->password = NULL; 80 } 81 } 82 83 char *passchange (irc_t *irc, void *set, char *value) { 84 setpassnc (irc, value); 85 return (NULL); 86 } 87 88 int setpass (irc_t *irc, char *pass, char* md5sum) { 62 int checkpass (const char *pass, const char *md5sum) 63 { 89 64 md5_state_t md5state; 90 65 md5_byte_t digest[16]; … … 103 78 if (digits[1] != md5sum[j + 1]) return (-1); 104 79 } 105 106 /* If pass is correct, we end up here and we set the pass */ 107 setpassnc (irc, pass); 108 109 return (0); 110 } 80 81 return( 0 ); 82 } 83 111 84 112 85 char *hashpass (irc_t *irc) { … … 135 108 } 136 109 137 char *obfucrypt (irc_t *irc, char *line) { 110 char *obfucrypt (irc_t *irc, char *line) 111 { 138 112 int i, j; 139 113 char *rv; … … 141 115 if (irc->password == NULL) return (NULL); 142 116 143 rv = (char *)g_malloc (strlen (line) + 1); 144 memset (rv, '\0', strlen (line) + 1); 117 rv = g_new0(char, strlen (line) + 1); 145 118 146 119 i = j = 0; … … 160 133 } 161 134 162 char *deobfucrypt (irc_t *irc, char *line) { 135 char *deobfucrypt (irc_t *irc, char *line) 136 { 163 137 int i, j; 164 138 char *rv; … … 166 140 if (irc->password == NULL) return (NULL); 167 141 168 rv = (char *)g_malloc (strlen (line) + 1); 169 memset (rv, '\0', strlen (line) + 1); 142 rv = g_new0(char, strlen (line) + 1); 170 143 171 144 i = j = 0; … … 189 162 int main( int argc, char *argv[] ) 190 163 { 191 irc_t *irc = g_ malloc( sizeof( irc_t ));164 irc_t *irc = g_new0( irc_t, 1 ); 192 165 char *hash, *action, line[256]; 193 166 char* (*func)( irc_t *, char * ); … … 201 174 } 202 175 203 memset( irc, 0, sizeof( irc_t ) );204 176 irc->password = g_strdup( argv[1] ); 205 177 -
crypting.h
rb8ef1b1 r1aa0bb5 24 24 */ 25 25 26 void setpassnc (irc_t *irc, char *pass); /* USE WITH CAUTION! */ 27 char *passchange (irc_t *irc, void *set, char *value); 28 int setpass (irc_t *irc, char *pass, char* md5sum); 26 int checkpass (const char *password, const char *md5sum); 29 27 char *hashpass (irc_t *irc); 30 28 char *obfucrypt (irc_t *irc, char *line); -
irc.c
rb8ef1b1 r1aa0bb5 31 31 32 32 GSList *irc_connection_list = NULL; 33 34 static char *passchange (irc_t *irc, void *set, char *value) 35 { 36 irc_setpass (irc, value); 37 return (NULL); 38 } 33 39 34 40 irc_t *irc_new( int fd ) … … 129 135 set_add( irc, "to_char", ": ", set_eval_to_char ); 130 136 set_add( irc, "typing_notice", "false", set_eval_bool ); 137 set_add( irc, "password", NULL, passchange); 131 138 132 139 conf_loaddefaults( irc ); … … 154 161 155 162 if( irc->status >= USTATUS_IDENTIFIED && set_getint( irc, "save_on_quit" ) ) 156 if( ! bitlbee_save( irc) )163 if( !global.storage->save( irc, TRUE ) ) 157 164 irc_usermsg( irc, "Error while saving settings!" ); 158 165 … … 259 266 if( global.conf->runmode == RUNMODE_INETD ) 260 267 g_main_quit( global.loop ); 268 } 269 270 /* USE WITH CAUTION! 271 Sets pass without checking */ 272 void irc_setpass (irc_t *irc, const char *pass) 273 { 274 if (irc->password) g_free (irc->password); 275 276 if (pass) { 277 irc->password = g_strdup (pass); 278 irc_usermsg (irc, "Password successfully changed"); 279 } else { 280 irc->password = NULL; 281 } 261 282 } 262 283 -
irc.h
rb8ef1b1 r1aa0bb5 137 137 void irc_whois( irc_t *irc, char *nick ); 138 138 int irc_away( irc_t *irc, char *away ); 139 void irc_setpass( irc_t *irc, const char *pass ); /* USE WITH CAUTION! */ 139 140 140 141 int irc_send( irc_t *irc, char *nick, char *s, int flags ); -
nick.c
rb8ef1b1 r1aa0bb5 27 27 #include "bitlbee.h" 28 28 29 void nick_set( irc_t *irc, c har *handle, int proto,char *nick )29 void nick_set( irc_t *irc, const char *handle, int proto, const char *nick ) 30 30 { 31 31 nick_t *m = NULL, *n = irc->nicks; … … 56 56 } 57 57 58 char *nick_get( irc_t *irc, c har *handle, int proto, const char *realname )58 char *nick_get( irc_t *irc, const char *handle, int proto, const char *realname ) 59 59 { 60 60 static char nick[MAX_NICK_LENGTH+1]; … … 129 129 } 130 130 131 void nick_del( irc_t *irc, c har *nick )131 void nick_del( irc_t *irc, const char *nick ) 132 132 { 133 133 nick_t *l = NULL, *n = irc->nicks; … … 176 176 } 177 177 178 int nick_ok( c har *nick )179 { 180 c har *s;178 int nick_ok( const char *nick ) 179 { 180 const char *s; 181 181 182 182 /* Empty/long nicks are not allowed */ … … 237 237 } 238 238 239 int nick_cmp( c har *a,char *b )239 int nick_cmp( const char *a, const char *b ) 240 240 { 241 241 char aa[1024] = "", bb[1024] = ""; … … 253 253 } 254 254 255 char *nick_dup( char *nick ) 256 { 257 char *cp; 258 259 cp = g_new0 ( char, MAX_NICK_LENGTH + 1 ); 260 strncpy( cp, nick, MAX_NICK_LENGTH ); 261 262 return( cp ); 263 } 255 char *nick_dup( const char *nick ) 256 { 257 return g_strndup( nick, MAX_NICK_LENGTH ); 258 } -
nick.h
rb8ef1b1 r1aa0bb5 32 32 } nick_t; 33 33 34 void nick_set( irc_t *irc, c har *handle, int proto,char *nick );35 char *nick_get( irc_t *irc, c har *handle, int proto, const char *realname );36 void nick_del( irc_t *irc, c har *nick );34 void nick_set( irc_t *irc, const char *handle, int proto, const char *nick ); 35 char *nick_get( irc_t *irc, const char *handle, int proto, const char *realname ); 36 void nick_del( irc_t *irc, const char *nick ); 37 37 void nick_strip( char *nick ); 38 38 39 int nick_ok( c har *nick );39 int nick_ok( const char *nick ); 40 40 int nick_lc( char *nick ); 41 41 int nick_uc( char *nick ); 42 int nick_cmp( c har *a,char *b );43 char *nick_dup( c har *nick );42 int nick_cmp( const char *a, const char *b ); 43 char *nick_dup( const char *nick ); -
protocols/proxy.c
rb8ef1b1 r1aa0bb5 50 50 #define GAIM_ERR_COND (G_IO_HUP | G_IO_ERR | G_IO_NVAL) 51 51 52 /*FIXME*53 #ifndef _WIN3254 if (getsockopt(fd, SOL_SOCKET, SO_ERROR, &error, &len) < 0) {55 closesocket(fd);56 g_free(phb);57 return -1;58 }59 fcntl(fd, F_SETFL, 0);60 #endif*/61 62 52 char proxyhost[128] = ""; 63 53 int proxyport = 0; … … 83 73 84 74 85 static struct sockaddr_in *gaim_gethostbyname(c har *host, int port)75 static struct sockaddr_in *gaim_gethostbyname(const char *host, int port) 86 76 { 87 77 static struct sockaddr_in sin; … … 154 144 } 155 145 156 static int proxy_connect_none(c har *host, unsigned short port, struct PHB *phb)146 static int proxy_connect_none(const char *host, unsigned short port, struct PHB *phb) 157 147 { 158 148 struct sockaddr_in *sin; … … 281 271 } 282 272 283 static int proxy_connect_http(c har *host, unsigned short port, struct PHB *phb)273 static int proxy_connect_http(const char *host, unsigned short port, struct PHB *phb) 284 274 { 285 275 phb->host = g_strdup(host); … … 365 355 } 366 356 367 static int proxy_connect_socks4(c har *host, unsigned short port, struct PHB *phb)357 static int proxy_connect_socks4(const char *host, unsigned short port, struct PHB *phb) 368 358 { 369 359 phb->host = g_strdup(host); … … 547 537 } 548 538 549 static int proxy_connect_socks5(c har *host, unsigned short port, struct PHB *phb)539 static int proxy_connect_socks5(const char *host, unsigned short port, struct PHB *phb) 550 540 { 551 541 phb->host = g_strdup(host); … … 588 578 } 589 579 590 int proxy_connect(c har *host, int port, GaimInputFunction func, gpointer data)580 int proxy_connect(const char *host, int port, GaimInputFunction func, gpointer data) 591 581 { 592 582 struct PHB *phb; -
protocols/proxy.h
rb8ef1b1 r1aa0bb5 56 56 G_MODULE_EXPORT void gaim_input_remove(gint); 57 57 58 G_MODULE_EXPORT int proxy_connect(c har *host, int port, GaimInputFunction func, gpointer data);58 G_MODULE_EXPORT int proxy_connect(const char *host, int port, GaimInputFunction func, gpointer data); 59 59 60 60 #endif /* _PROXY_H_ */ -
unix.c
rb8ef1b1 r1aa0bb5 52 52 53 53 global.helpfile = g_strdup( HELP_FILE ); 54 54 55 55 global.conf = conf_load( argc, argv ); 56 56 if( global.conf == NULL ) 57 57 return( 1 ); 58 58 59 59 60 if( global.conf->runmode == RUNMODE_INETD ) 60 61 { … … 70 71 if( i != 0 ) 71 72 return( i ); 73 74 global.storage = storage_init( global.conf->storage ); 75 if ( global.storage == NULL) { 76 log_message( LOGLVL_ERROR, "No such storage backend '%s'", global.conf->storage ); 77 return( 1 ); 78 } 79 72 80 73 81 /* Catch some signals to tell the user what's happening before quitting */ … … 87 95 if( !getuid() || !geteuid() ) 88 96 log_message( LOGLVL_WARNING, "BitlBee is running with root privileges. Why?" ); 89 if( access( global.conf->configdir, F_OK ) != 0 )90 log_message( LOGLVL_WARNING, "The configuration directory %s does not exist. Configuration won't be saved.", CONFIG );91 else if( access( global.conf->configdir, R_OK ) != 0 || access( global.conf->configdir, W_OK ) != 0 )92 log_message( LOGLVL_WARNING, "Permission problem: Can't read/write from/to %s.", global.conf->configdir );93 97 if( help_init( &(global.help) ) == NULL ) 94 98 log_message( LOGLVL_WARNING, "Error opening helpfile %s.", HELP_FILE );
Note: See TracChangeset
for help on using the changeset viewer.