Changes in / [9df916f:c2295f7]
- Files:
-
- 3 deleted
- 12 edited
Legend:
- Unmodified
- Added
- Removed
-
.bzrignore
r9df916f rc2295f7 8 8 build-arch-stamp 9 9 tags 10 decode11 encode -
Makefile
r9df916f rc2295f7 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 storage_text.o storage.o12 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 13 13 subdirs = protocols 14 14 -
bitlbee.c
r9df916f rc2295f7 27 27 #include "bitlbee.h" 28 28 #include "commands.h" 29 #include "crypting.h" 29 30 #include "protocols/nogaim.h" 30 31 #include "help.h" … … 243 244 } 244 245 246 int bitlbee_load( irc_t *irc, const 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, the 270 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 the 315 * password is not set if it was wrong, or if one is not identified 316 * yet. This means that a malicious user could easily overwrite 317 * files owned by someone else: 318 * a Bad Thing, methinks 319 \*/ 320 321 /* [WVG] No? Really? */ 322 323 /*\ 324 * [SH] Okay, okay, it wasn't really Wilmer who said that, it was 325 * 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 else 388 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 245 464 void bitlbee_shutdown( gpointer data ) 246 465 { -
bitlbee.h
r9df916f rc2295f7 100 100 101 101 #include "irc.h" 102 #include "storage.h"103 102 #include "set.h" 104 103 #include "protocols/nogaim.h" … … 116 115 help_t *help; 117 116 conf_t *conf; 118 storage_t *storage;119 117 char *helpfile; 120 118 GMainLoop *loop; … … 129 127 int root_command_string( irc_t *irc, user_t *u, char *command, int flags ); 130 128 int root_command( irc_t *irc, char *command[] ); 129 int bitlbee_load( irc_t *irc, const char *password ); 130 int bitlbee_save( irc_t *irc ); 131 131 void bitlbee_shutdown( gpointer data ); 132 132 double gettime( void ); -
commands.c
r9df916f rc2295f7 86 86 int cmd_identify( irc_t *irc, char **cmd ) 87 87 { 88 storage_status_t status = global.storage->load( irc->nick, cmd[1], irc);89 90 switch (status) {91 case STORAGE_INVALID_PASSWORD:88 int checkie = bitlbee_load( irc, cmd[1] ); 89 90 if( checkie == -1 ) 91 { 92 92 irc_usermsg( irc, "Incorrect password" ); 93 break; 94 case STORAGE_NO_SUCH_USER: 93 } 94 else if( checkie == 0 ) 95 { 95 96 irc_usermsg( irc, "The nick is (probably) not registered" ); 96 break; 97 case STORAGE_OK: 97 } 98 else if( checkie == 1 ) 99 { 98 100 irc_usermsg( irc, "Password accepted" ); 99 break; 100 default: 101 } 102 else 103 { 101 104 irc_usermsg( irc, "Something very weird happened" ); 102 break;103 105 } 104 106 … … 108 110 int cmd_register( irc_t *irc, char **cmd ) 109 111 { 112 int checkie; 113 char path[512]; 114 110 115 if( global.conf->authmode == AUTHMODE_REGISTERED ) 111 116 { … … 113 118 return( 0 ); 114 119 } 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; 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" ); 129 136 } 130 137 … … 134 141 int cmd_drop( irc_t *irc, char **cmd ) 135 142 { 136 storage_status_t status; 137 138 status = global.storage->remove (irc->nick, cmd[1]); 139 switch (status) { 140 case STORAGE_NO_SUCH_USER: 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 { 141 150 irc_usermsg( irc, "That account does not exist" ); 142 151 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 } 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 ); 154 172 } 155 173 … … 616 634 int cmd_save( irc_t *irc, char **cmd ) 617 635 { 618 if( global.storage->save( irc, TRUE ) == STORAGE_OK)636 if( bitlbee_save( irc ) ) 619 637 irc_usermsg( irc, "Configuration saved" ); 620 638 else -
conf.c
r9df916f rc2295f7 50 50 conf->nofork = 0; 51 51 conf->verbose = 0; 52 conf->storage = "text";53 52 conf->runmode = RUNMODE_INETD; 54 53 conf->authmode = AUTHMODE_OPEN; … … 199 198 conf->motdfile = g_strdup( ini->value ); 200 199 } 201 else if( g_strcasecmp( ini->key, "storage" ) == 0 )202 {203 g_free( conf->storage );204 conf->storage = g_strdup( ini->value );205 }206 200 else if( g_strcasecmp( ini->key, "pinginterval" ) == 0 ) 207 201 { -
conf.h
r9df916f rc2295f7 42 42 char *configdir; 43 43 char *motdfile; 44 char *storage;45 44 int ping_interval; 46 45 int ping_timeout; -
crypting.c
r9df916f rc2295f7 52 52 #include <stdlib.h> 53 53 54 #define irc_usermsg 55 54 56 #endif 55 57 … … 60 62 \*/ 61 63 62 int checkpass (const char *pass, const char *md5sum) 64 /* USE WITH CAUTION! 65 Sets pass without checking */ 66 void setpassnc (irc_t *irc, const char *pass) 67 { 68 if (irc->password) g_free (irc->password); 69 70 if (pass) { 71 irc->password = g_strdup (pass); 72 irc_usermsg (irc, "Password successfully changed"); 73 } else { 74 irc->password = NULL; 75 } 76 } 77 78 int setpass (irc_t *irc, const char *pass, const char* md5sum) 63 79 { 64 80 md5_state_t md5state; … … 78 94 if (digits[1] != md5sum[j + 1]) return (-1); 79 95 } 80 81 return( 0 ); 82 } 83 96 97 /* If pass is correct, we end up here and we set the pass */ 98 setpassnc (irc, pass); 99 100 return (0); 101 } 84 102 85 103 char *hashpass (irc_t *irc) { -
crypting.h
r9df916f rc2295f7 24 24 */ 25 25 26 int checkpass (const char *password, const char *md5sum); 26 void setpassnc (irc_t *irc, const char *pass); /* USE WITH CAUTION! */ 27 int setpass (irc_t *irc, const char *pass, const char* md5sum); 27 28 char *hashpass (irc_t *irc); 28 29 char *obfucrypt (irc_t *irc, char *line); -
irc.c
r9df916f rc2295f7 32 32 GSList *irc_connection_list = NULL; 33 33 34 staticchar *passchange (irc_t *irc, void *set, char *value)35 { 36 irc_setpass(irc, value);34 char *passchange (irc_t *irc, void *set, char *value) 35 { 36 setpassnc (irc, value); 37 37 return (NULL); 38 38 } … … 161 161 162 162 if( irc->status >= USTATUS_IDENTIFIED && set_getint( irc, "save_on_quit" ) ) 163 if( ! global.storage->save( irc, TRUE) )163 if( !bitlbee_save( irc ) ) 164 164 irc_usermsg( irc, "Error while saving settings!" ); 165 165 … … 266 266 if( global.conf->runmode == RUNMODE_INETD ) 267 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 }282 268 } 283 269 -
irc.h
r9df916f rc2295f7 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! */140 139 141 140 int irc_send( irc_t *irc, char *nick, char *s, int flags ); -
unix.c
r9df916f rc2295f7 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 59 58 60 59 if( global.conf->runmode == RUNMODE_INETD ) 61 60 { … … 71 70 if( i != 0 ) 72 71 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 80 72 81 73 /* Catch some signals to tell the user what's happening before quitting */ … … 95 87 if( !getuid() || !geteuid() ) 96 88 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 ); 97 93 if( help_init( &(global.help) ) == NULL ) 98 94 log_message( LOGLVL_WARNING, "Error opening helpfile %s.", HELP_FILE );
Note: See TracChangeset
for help on using the changeset viewer.