Changeset 5100caa


Ignore:
Timestamp:
2006-07-01T15:52:05Z (18 years ago)
Author:
Wilmer van der Gaast <wilmer@…>
Branches:
master
Children:
fef6116
Parents:
0a3c243
Message:

Added "account set" command.

Files:
9 edited

Legend:

Unmodified
Added
Removed
  • account.c

    r0a3c243 r5100caa  
    2828#include "account.h"
    2929
     30char *set_eval_account( set_t *set, char *value );
     31
    3032account_t *account_add( irc_t *irc, struct prpl *prpl, char *user, char *pass )
    3133{
    3234        account_t *a;
     35        set_t *s;
    3336       
    3437        if( irc->accounts )
     
    4851        a->irc = irc;
    4952       
     53        s = set_add( &a->set, "auto_connect", NULL, set_eval_account, a );
     54        s->flags |= ACC_SET_NOSAVE;
     55       
     56        s = set_add( &a->set, "password", NULL, set_eval_account, a );
     57        s->flags |= ACC_SET_NOSAVE;
     58       
     59        s = set_add( &a->set, "server", NULL, set_eval_account, a );
     60        s->flags |= ACC_SET_NOSAVE | ACC_SET_OFFLINE_ONLY;
     61       
     62        s = set_add( &a->set, "username", NULL, set_eval_account, a );
     63        s->flags |= ACC_SET_NOSAVE | ACC_SET_OFFLINE_ONLY;
     64        set_setstr( &a->set, "username", user );
     65       
    5066        return( a );
     67}
     68
     69char *set_eval_account( set_t *set, char *value )
     70{
     71        account_t *acc = set->data;
     72       
     73        /* Double-check: We refuse to edit on-line accounts. */
     74        if( acc->gc )
     75                return NULL;
     76       
     77        if( strcmp( set->key, "username" ) == 0 )
     78        {
     79                g_free( acc->user );
     80                acc->user = g_strdup( value );
     81                return value;
     82        }
     83        else if( strcmp( set->key, "password" ) == 0 )
     84        {
     85                g_free( acc->pass );
     86                acc->pass = g_strdup( value );
     87                return NULL;    /* password shouldn't be visible in plaintext! */
     88        }
     89        else if( strcmp( set->key, "server" ) == 0 )
     90        {
     91                g_free( acc->server );
     92                if( *value )
     93                        acc->server = g_strdup( value );
     94                else
     95                        acc->server = NULL;
     96                return value;
     97        }
     98        else if( strcmp( set->key, "auto_connect" ) == 0 )
     99        {
     100                if( !is_bool( value ) )
     101                        return NULL;
     102               
     103                acc->auto_connect = bool2int( value );
     104                return value;
     105        }
     106       
     107        return NULL;
    51108}
    52109
     
    130187                        }
    131188                       
     189                        while( a->set )
     190                                set_del( &a->set, a->set->key );
     191                       
    132192                        g_free( a->user );
    133193                        g_free( a->pass );
  • account.h

    r0a3c243 r5100caa  
    3737        int reconnect;
    3838       
     39        set_t *set;
     40       
    3941        struct irc *irc;
    4042        struct gaim_connection *gc;
     
    4850void account_off( irc_t *irc, account_t *a );
    4951
     52#define ACC_SET_NOSAVE          1
     53#define ACC_SET_OFFLINE_ONLY    2
     54
    5055#endif
  • lib/misc.c

    r0a3c243 r5100caa  
    486486        }
    487487}
     488
     489int is_bool( char *value )
     490{
     491        if( *value == 0 )
     492                return 0;
     493       
     494        if( ( g_strcasecmp( value, "true" ) == 0 ) || ( g_strcasecmp( value, "yes" ) == 0 ) || ( g_strcasecmp( value, "on" ) == 0 ) )
     495                return 1;
     496        if( ( g_strcasecmp( value, "false" ) == 0 ) || ( g_strcasecmp( value, "no" ) == 0 ) || ( g_strcasecmp( value, "off" ) == 0 ) )
     497                return 1;
     498       
     499        while( *value )
     500                if( !isdigit( *value ) )
     501                        return 0;
     502                else
     503                        value ++;
     504       
     505        return 1;
     506}
     507
     508int bool2int( char *value )
     509{
     510        int i;
     511       
     512        if( ( g_strcasecmp( value, "true" ) == 0 ) || ( g_strcasecmp( value, "yes" ) == 0 ) || ( g_strcasecmp( value, "on" ) == 0 ) )
     513                return 1;
     514        if( ( g_strcasecmp( value, "false" ) == 0 ) || ( g_strcasecmp( value, "no" ) == 0 ) || ( g_strcasecmp( value, "off" ) == 0 ) )
     515                return 0;
     516       
     517        if( sscanf( value, "%d", &i ) == 1 )
     518                return i;
     519       
     520        return 0;
     521}
  • lib/misc.h

    r0a3c243 r5100caa  
    5151G_MODULE_EXPORT void random_bytes( unsigned char *buf, int count );
    5252
     53G_MODULE_EXPORT int is_bool( char *value );
     54G_MODULE_EXPORT int bool2int( char *value );
     55
    5356#endif
  • lib/rc4.c

    r0a3c243 r5100caa  
    165165        if( clear_len < 0 )
    166166        {
    167                 *clear = g_strdup( "" );
     167                *clear = (unsigned char*) g_strdup( "" );
    168168                return 0;
    169169        }
  • root_commands.c

    r0a3c243 r5100caa  
    232232
    233233                a = account_add( irc, prpl, cmd[3], cmd[4] );
    234                
    235234                if( cmd[5] )
    236                         a->server = g_strdup( cmd[5] );
     235                        set_setstr( &a->set, "server", cmd[5] );
    237236               
    238237                irc_usermsg( irc, "Account successfully added" );
     
    358357                }
    359358        }
     359        else if( g_strcasecmp( cmd[1], "set" ) == 0 )
     360        {
     361                char *acc_handle, *set_name = NULL, *tmp;
     362               
     363                if( !cmd[2] )
     364                {
     365                        irc_usermsg( irc, "Not enough parameters given (need %d)", 2 );
     366                        return;
     367                }
     368               
     369                acc_handle = g_strdup( cmd[2] );
     370                if( ( tmp = strchr( acc_handle, '/' ) ) )
     371                {
     372                        *tmp = 0;
     373                        set_name = tmp + 1;
     374                }
     375                a = account_get( irc, acc_handle );
     376               
     377                if( a == NULL )
     378                {
     379                        irc_usermsg( irc, "Invalid account" );
     380                        return;
     381                }
     382               
     383                if( cmd[3] )
     384                {
     385                        set_t *s = set_find( &a->set, set_name );
     386                       
     387                        if( a->gc && s && s->flags & ACC_SET_OFFLINE_ONLY )
     388                        {
     389                                irc_usermsg( irc, "This setting can only be changed when the account is off-line" );
     390                                return;
     391                        }
     392                       
     393                        set_setstr( &a->set, set_name, cmd[3] );
     394                       
     395                        if( ( strcmp( cmd[3], "=" ) ) == 0 && cmd[4] )
     396                                irc_usermsg( irc, "Warning: Correct syntax: \002account set <variable> <value>\002 (without =)" );
     397                }
     398                if( set_name ) /* else 'forgotten' on purpose.. Must show new value after changing */
     399                {
     400                        char *s = set_getstr( &a->set, set_name );
     401                        if( s )
     402                                irc_usermsg( irc, "%s = `%s'", set_name, s );
     403                        else
     404                                irc_usermsg( irc, "%s is empty", set_name );
     405                }
     406                else
     407                {
     408                        set_t *s = a->set;
     409                        while( s )
     410                        {
     411                                if( s->value || s->def )
     412                                        irc_usermsg( irc, "%s = `%s'", s->key, s->value?s->value:s->def );
     413                                else
     414                                        irc_usermsg( irc, "%s is empty", s->key );
     415                                s = s->next;
     416                        }
     417                }
     418               
     419                g_free( acc_handle );
     420        }
    360421        else
    361422        {
     
    682743                if( s )
    683744                        irc_usermsg( irc, "%s = `%s'", cmd[1], s );
     745                else
     746                        irc_usermsg( irc, "%s is empty", cmd[1] );
    684747        }
    685748        else
     
    690753                        if( s->value || s->def )
    691754                                irc_usermsg( irc, "%s = `%s'", s->key, s->value?s->value:s->def );
     755                        else
     756                                irc_usermsg( irc, "%s is empty", s->key );
    692757                        s = s->next;
    693758                }
  • set.c

    r0a3c243 r5100caa  
    101101}
    102102
     103int set_getbool( set_t **head, char *key )
     104{
     105        char *s = set_getstr( head, key );
     106       
     107        if( !s )
     108                return 0;
     109       
     110        return bool2int( s );
     111}
     112
    103113int set_setstr( set_t **head, char *key, char *value )
    104114{
     
    166176       
    167177        for( s = value; *s; s ++ )
    168                 if( *s < '0' || *s > '9' )
     178                if( !isdigit( *s ) )
    169179                        return NULL;
    170180       
     
    174184char *set_eval_bool( set_t *set, char *value )
    175185{
    176         if( ( g_strcasecmp( value, "true" ) == 0 ) || ( g_strcasecmp( value, "yes" ) == 0 ) || ( g_strcasecmp( value, "on" ) == 0 ) )
    177                 return( value );
    178         if( ( g_strcasecmp( value, "false" ) == 0 ) || ( g_strcasecmp( value, "no" ) == 0 ) || ( g_strcasecmp( value, "off" ) == 0 ) )
    179                 return( value );
    180         return( set_eval_int( set, value ) );
     186        return is_bool( value ) ? value : NULL;
    181187}
    182188
  • set.h

    r0a3c243 r5100caa  
    3232        char *def;      /* Default */
    3333       
     34        int flags;
     35       
    3436        /* Eval: Returns NULL if the value is incorrect or exactly the
    3537           passed value variable. When returning a corrected value,
     
    4042
    4143set_t *set_add( set_t **head, char *key, char *def, void *eval, void *data );
    42 G_MODULE_EXPORT set_t *set_find( set_t **head, char *key );
     44set_t *set_find( set_t **head, char *key );
    4345G_MODULE_EXPORT char *set_getstr( set_t **head, char *key );
    4446G_MODULE_EXPORT int set_getint( set_t **head, char *key );
  • storage_xml.c

    r0a3c243 r5100caa  
    157157                        xd->current_account = account_add( irc, prpl, handle, password );
    158158                        if( server )
    159                                 xd->current_account->server = g_strdup( server );
     159                                set_setstr( &xd->current_account->set, "server", server );
    160160                        if( autoconnect )
    161                                 /* Return value doesn't matter, since account_add() already sets
    162                                    a default! */
    163                                 sscanf( autoconnect, "%d", &xd->current_account->auto_connect );
     161                                set_setstr( &xd->current_account->set, "auto_connect", autoconnect );
    164162                }
    165163                else
     
    176174        else if( g_strcasecmp( element_name, "setting" ) == 0 )
    177175        {
    178                 if( xd->current_account == NULL )
    179                 {
    180                         char *setting;
    181                        
    182                         if( xd->current_setting )
    183                         {
    184                                 g_free( xd->current_setting );
    185                                 xd->current_setting = NULL;
    186                         }
    187                        
    188                         if( ( setting = xml_attr( attr_names, attr_values, "name" ) ) )
    189                                 xd->current_setting = g_strdup( setting );
    190                         else
    191                                 g_set_error( error, G_MARKUP_ERROR, G_MARKUP_ERROR_INVALID_CONTENT,
    192                                              "Missing attributes for %s element", element_name );
    193                 }
     176                char *setting;
     177               
     178                if( xd->current_setting )
     179                {
     180                        g_free( xd->current_setting );
     181                        xd->current_setting = NULL;
     182                }
     183               
     184                if( ( setting = xml_attr( attr_names, attr_values, "name" ) ) )
     185                        xd->current_setting = g_strdup( setting );
     186                else
     187                        g_set_error( error, G_MARKUP_ERROR, G_MARKUP_ERROR_INVALID_CONTENT,
     188                                     "Missing attributes for %s element", element_name );
    194189        }
    195190        else if( g_strcasecmp( element_name, "buddy" ) == 0 )
     
    243238                   yet. */
    244239        }
    245         else if( g_strcasecmp( g_markup_parse_context_get_element( ctx ), "setting" ) == 0 &&
    246                  xd->current_setting && xd->current_account == NULL )
    247         {
    248                 set_setstr( &irc->set, xd->current_setting, (char*) text );
     240        else if( g_strcasecmp( g_markup_parse_context_get_element( ctx ), "setting" ) == 0 && xd->current_setting )
     241        {
     242                set_setstr( xd->current_account ? &xd->current_account->set : &irc->set,
     243                            xd->current_setting, (char*) text );
    249244                g_free( xd->current_setting );
    250245                xd->current_setting = NULL;
     
    348343}
    349344
    350 static int xml_printf( int fd, char *fmt, ... )
     345static int xml_printf( int fd, int indent, char *fmt, ... )
    351346{
    352347        va_list params;
    353348        char *out;
     349        char tabs[9] = "\t\t\t\t\t\t\t\t";
    354350        int len;
     351       
     352        /* Maybe not very clean, but who needs more than 8 levels of indentation anyway? */
     353        if( write( fd, tabs, indent <= 8 ? indent : 8 ) != indent )
     354                return 0;
    355355       
    356356        va_start( params, fmt );
     
    404404        pass_buf = base64_encode( (char*) pass_md5, 21 );
    405405       
    406         if( !xml_printf( fd, "<user nick=\"%s\" password=\"%s\" version=\"%d\">\n", irc->nick, pass_buf, XML_FORMAT_VERSION ) )
     406        if( !xml_printf( fd, 0, "<user nick=\"%s\" password=\"%s\" version=\"%d\">\n", irc->nick, pass_buf, XML_FORMAT_VERSION ) )
    407407                goto write_error;
    408408       
     
    411411        for( set = irc->set; set; set = set->next )
    412412                if( set->value && set->def )
    413                         if( !xml_printf( fd, "\t<setting name=\"%s\">%s</setting>\n", set->key, set->value ) )
     413                        if( !xml_printf( fd, 1, "<setting name=\"%s\">%s</setting>\n", set->key, set->value ) )
    414414                                goto write_error;
    415415       
     
    423423                g_free( pass_rc4 );
    424424               
    425                 if( !xml_printf( fd, "\t<account protocol=\"%s\" handle=\"%s\" password=\"%s\" autoconnect=\"%d\"", acc->prpl->name, acc->user, pass_b64, acc->auto_connect ) )
     425                if( !xml_printf( fd, 1, "<account protocol=\"%s\" handle=\"%s\" password=\"%s\" autoconnect=\"%d\"", acc->prpl->name, acc->user, pass_b64, acc->auto_connect ) )
    426426                {
    427427                        g_free( pass_b64 );
     
    430430                g_free( pass_b64 );
    431431               
    432                 if( acc->server && acc->server[0] && !xml_printf( fd, " server=\"%s\"", acc->server ) )
     432                if( acc->server && acc->server[0] && !xml_printf( fd, 0, " server=\"%s\"", acc->server ) )
    433433                        goto write_error;
    434                 if( !xml_printf( fd, ">\n" ) )
     434                if( !xml_printf( fd, 0, ">\n" ) )
    435435                        goto write_error;
     436               
     437                for( set = acc->set; set; set = set->next )
     438                        if( set->value && set->def && !( set->flags & ACC_SET_NOSAVE ) )
     439                                if( !xml_printf( fd, 2, "<setting name=\"%s\">%s</setting>\n", set->key, set->value ) )
     440                                        goto write_error;
    436441               
    437442                for( nick = irc->nicks; nick; nick = nick->next )
    438443                        if( nick->proto == acc->prpl )
    439                                 if( !xml_printf( fd, "\t\t<buddy handle=\"%s\" nick=\"%s\" />\n", nick->handle, nick->nick ) )
     444                                if( !xml_printf( fd, 2, "<buddy handle=\"%s\" nick=\"%s\" />\n", nick->handle, nick->nick ) )
    440445                                        goto write_error;
    441446               
    442                 if( !xml_printf( fd, "\t</account>\n" ) )
     447                if( !xml_printf( fd, 1, "</account>\n" ) )
    443448                        goto write_error;
    444449        }
    445450       
    446         if( !xml_printf( fd, "</user>\n" ) )
     451        if( !xml_printf( fd, 0, "</user>\n" ) )
    447452                goto write_error;
    448453       
Note: See TracChangeset for help on using the changeset viewer.