aboutsummaryrefslogtreecommitdiffstats
path: root/protocols/account.h
blob: a39be2e26da70bacf5a2764dbd342373a8a2aa80 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
  /********************************************************************\
  * BitlBee -- An IRC to other IM-networks gateway                     *
  *                                                                    *
  * Copyright 2002-2004 Wilmer van der Gaast and others                *
  \********************************************************************/

/* Account management functions                                         */

/*
  This program is free software; you can redistribute it and/or modify
  it under the terms of the GNU General Public License as published by
  the Free Software Foundation; either version 2 of the License, or
  (at your option) any later version.

  This program is distributed in the hope that it will be useful,
  but WITHOUT ANY WARRANTY; without even the implied warranty of
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  GNU General Public License for more details.

  You should have received a copy of the GNU General Public License with
  the Debian GNU/Linux distribution in /usr/share/common-licenses/GPL;
  if not, write to the Free Software Foundation, Inc., 59 Temple Place,
  Suite 330, Boston, MA  02111-1307  USA
*/

#ifndef _ACCOUNT_H
#define _ACCOUNT_H

typedef struct account
{
	struct prpl *prpl;
	char *user;
	char *pass;
	char *server;
	char *tag;
	
	int auto_connect;
	int auto_reconnect_delay;
	int reconnect;
	int flags;
	
	set_t *set;
	GHashTable *nicks;
	
	struct bee *bee;
	struct im_connection *ic;
	struct account *next;
} account_t;

account_t *account_add( bee_t *bee, struct prpl *prpl, char *user, char *pass );
account_t *account_get( bee_t *bee, const char *id );
account_t *account_by_tag( bee_t *bee, const char *tag );
void account_del( bee_t *bee, account_t *acc );
void account_on( bee_t *bee, account_t *a );
void account_off( bee_t *bee, account_t *a );

char *set_eval_account( set_t *set, char *value );
char *set_eval_account_reconnect_delay( set_t *set, char *value );
int account_reconnect_delay( account_t *a );

typedef enum
{
	ACC_SET_NOSAVE = 0x01,          /* Don't save this setting (i.e. stored elsewhere). */
	ACC_SET_OFFLINE_ONLY = 0x02,    /* Allow changes only if the acct is offline. */
	ACC_SET_ONLINE_ONLY = 0x04,     /* Allow changes only if the acct is online. */
} account_set_flag_t;

typedef enum
{
	ACC_FLAG_AWAY_MESSAGE = 0x01,   /* Supports away messages instead of just states. */
	ACC_FLAG_STATUS_MESSAGE = 0x02, /* Supports status messages (without being away). */
} account_flag_t;

#endif
w"> } if( irc->queries ) { query_t *l = irc->queries; while( l->next ) l = l->next; l->next = q; } else { irc->queries = q; } if( g_strcasecmp( set_getstr( &irc->set, "query_order" ), "lifo" ) == 0 || irc->queries == q ) query_display( irc, q ); return( q ); } void query_del( irc_t *irc, query_t *q ) { query_t *l; if( irc->queries == q ) { irc->queries = q->next; } else { for( l = irc->queries; l; l = l->next ) { if( l->next == q ) { l->next = q->next; break; } } if( !l ) return; /* Hrmmm... */ } g_free( q->question ); if( q->data ) g_free( q->data ); /* Memory leak... */ g_free( q ); } void query_del_by_conn( irc_t *irc, struct im_connection *ic ) { query_t *q, *n, *def; int count = 0; q = irc->queries; def = query_default( irc ); while( q ) { if( q->ic == ic ) { n = q->next; query_del( irc, q ); q = n; count ++; } else { q = q->next; } } if( count > 0 ) imcb_log( ic, "Flushed %d unanswered question(s) for this connection.", count ); q = query_default( irc ); if( q && q != def ) query_display( irc, q ); } void query_answer( irc_t *irc, query_t *q, int ans ) { int disp = 0; if( !q ) { q = query_default( irc ); disp = 1; } if( ans ) { imcb_log( q->ic, "Accepted: %s", q->question ); q->yes( NULL, q->data ); } else { imcb_log( q->ic, "Rejected: %s", q->question ); q->no( NULL, q->data ); } q->data = NULL; query_del( irc, q ); if( disp && ( q = query_default( irc ) ) ) query_display( irc, q ); } static void query_display( irc_t *irc, query_t *q ) { if( q->ic ) { imcb_log( q->ic, "New request: %s\nYou can use the \2yes\2/\2no\2 commands to accept/reject this request.", q->question ); } else { irc_usermsg( irc, "New request: %s\nYou can use the \2yes\2/\2no\2 commands to accept/reject this request.", q->question ); } } static query_t *query_default( irc_t *irc ) { query_t *q; if( g_strcasecmp( set_getstr( &irc->set, "query_order" ), "fifo" ) == 0 ) q = irc->queries; else for( q = irc->queries; q && q->next; q = q->next ); return( q ); }