pidgin 2.14.14dev
|
Connection API. More...
Go to the source code of this file.
Data Structures | |
struct | PurpleConnectionErrorInfo |
Holds the type of an error along with its description. More... | |
struct | PurpleConnectionUiOps |
Connection UI operations. More... | |
struct | _PurpleConnection |
Typedefs | |
typedef struct _PurpleConnection | PurpleConnection |
Functions | |
UI Registration Functions <br> | |
void | purple_connections_set_ui_ops (PurpleConnectionUiOps *ops) |
Sets the UI operations structure to be used for connections. | |
PurpleConnectionUiOps * | purple_connections_get_ui_ops (void) |
Returns the UI operations structure used for connections. | |
Connections Subsystem <br> | |
void | purple_connections_init (void) |
Initializes the connections subsystem. | |
void | purple_connections_uninit (void) |
Uninitializes the connections subsystem. | |
void * | purple_connections_get_handle (void) |
Returns the handle to the connections subsystem. | |
Connection API <br> | |
#define | PURPLE_CONNECTION_IS_CONNECTED(gc) (purple_connection_get_state(gc) == PURPLE_CONNECTED) |
Returns TRUE if the account is connected, otherwise returns FALSE. | |
void | purple_connection_new (PurpleAccount *account, gboolean regist, const char *password) |
This function should only be called by purple_account_connect() in account.c. | |
void | purple_connection_new_unregister (PurpleAccount *account, const char *password, PurpleAccountUnregistrationCb cb, void *user_data) |
This function should only be called by purple_account_unregister() in account.c. | |
void | purple_connection_destroy (PurpleConnection *gc) |
Disconnects and destroys a PurpleConnection. | |
void | purple_connection_set_state (PurpleConnection *gc, PurpleConnectionState state) |
Sets the connection state. | |
void | purple_connection_set_account (PurpleConnection *gc, PurpleAccount *account) |
Sets the connection's account. | |
void | purple_connection_set_display_name (PurpleConnection *gc, const char *name) |
Sets the connection's displayed name. | |
void | purple_connection_set_protocol_data (PurpleConnection *connection, void *proto_data) |
Sets the protocol data for a connection. | |
PurpleConnectionState | purple_connection_get_state (const PurpleConnection *gc) |
Returns the connection state. | |
PurpleAccount * | purple_connection_get_account (const PurpleConnection *gc) |
Returns the connection's account. | |
PurplePlugin * | purple_connection_get_prpl (const PurpleConnection *gc) |
Returns the protocol plugin managing a connection. | |
const char * | purple_connection_get_password (const PurpleConnection *gc) |
Returns the connection's password. | |
const char * | purple_connection_get_display_name (const PurpleConnection *gc) |
Returns the connection's displayed name. | |
void * | purple_connection_get_protocol_data (const PurpleConnection *connection) |
Gets the protocol data from a connection. | |
void | purple_connection_update_progress (PurpleConnection *gc, const char *text, size_t step, size_t count) |
Updates the connection progress. | |
void | purple_connection_notice (PurpleConnection *gc, const char *text) |
Displays a connection-specific notice. | |
void | purple_connection_error (PurpleConnection *gc, const char *reason) |
Closes a connection with an error. | |
void | purple_connection_error_reason (PurpleConnection *gc, PurpleConnectionError reason, const char *description) |
Closes a connection with an error and a human-readable description of the error. | |
void | purple_connection_ssl_error (PurpleConnection *gc, PurpleSslErrorType ssl_error) |
Closes a connection due to an SSL error; this is basically a shortcut to turning the PurpleSslErrorType into a PurpleConnectionError and a human-readable string and then calling purple_connection_error_reason(). | |
gboolean | purple_connection_error_is_fatal (PurpleConnectionError reason) |
Reports whether a disconnection reason is fatal (in which case the account should probably not be automatically reconnected) or transient (so auto-reconnection is a good idea). | |
Connections API <br> | |
#define | PURPLE_CONNECTION_IS_VALID(gc) (g_list_find(purple_connections_get_all(), (gc)) != NULL) |
Checks if gc is still a valid pointer to a gc. | |
void | purple_connections_disconnect_all (void) |
Disconnects from all connections. | |
GList * | purple_connections_get_all (void) |
Returns a list of all active connections. | |
GList * | purple_connections_get_connecting (void) |
Returns a list of all connections in the process of connecting. | |
#define PURPLE_CONNECTION_IS_CONNECTED | ( | gc | ) | (purple_connection_get_state(gc) == PURPLE_CONNECTED) |
Returns TRUE if the account is connected, otherwise returns FALSE.
Definition at line 396 of file connection.h.
#define PURPLE_CONNECTION_IS_VALID | ( | gc | ) | (g_list_find(purple_connections_get_all(), (gc)) != NULL) |
Checks if gc is still a valid pointer to a gc.
TRUE
if gc is valid.Definition at line 572 of file connection.h.
typedef struct _PurpleConnection PurpleConnection |
Definition at line 31 of file connection.h.
Possible errors that can cause a connection to be closed.
Enumerator | |
---|---|
PURPLE_CONNECTION_ERROR_NETWORK_ERROR | There was an error sending or receiving on the network socket, or there was some protocol error (such as the server sending malformed data). |
PURPLE_CONNECTION_ERROR_INVALID_USERNAME | The username supplied was not valid. |
PURPLE_CONNECTION_ERROR_AUTHENTICATION_FAILED | The username, password or some other credential was incorrect. Use PURPLE_CONNECTION_ERROR_INVALID_USERNAME instead if the username is known to be invalid. |
PURPLE_CONNECTION_ERROR_AUTHENTICATION_IMPOSSIBLE | libpurple doesn't speak any of the authentication methods the server offered. |
PURPLE_CONNECTION_ERROR_NO_SSL_SUPPORT | libpurple was built without SSL support, and the connection needs SSL. |
PURPLE_CONNECTION_ERROR_ENCRYPTION_ERROR | There was an error negotiating SSL on this connection, or the server does not support encryption but an account option was set to require it. |
PURPLE_CONNECTION_ERROR_NAME_IN_USE | Someone is already connected to the server using the name you are trying to connect with. |
PURPLE_CONNECTION_ERROR_INVALID_SETTINGS | The username/server/other preference for the account isn't valid. For instance, on IRC the username cannot contain white space. This reason should not be used for incorrect passwords etc: use PURPLE_CONNECTION_ERROR_AUTHENTICATION_FAILED for that.
|
PURPLE_CONNECTION_ERROR_CERT_NOT_PROVIDED | The server did not provide a SSL certificate. |
PURPLE_CONNECTION_ERROR_CERT_UNTRUSTED | The server's SSL certificate could not be trusted. |
PURPLE_CONNECTION_ERROR_CERT_EXPIRED | The server's SSL certificate has expired. |
PURPLE_CONNECTION_ERROR_CERT_NOT_ACTIVATED | The server's SSL certificate is not yet valid. |
PURPLE_CONNECTION_ERROR_CERT_HOSTNAME_MISMATCH | The server's SSL certificate did not match its hostname. |
PURPLE_CONNECTION_ERROR_CERT_FINGERPRINT_MISMATCH | The server's SSL certificate does not have the expected fingerprint. |
PURPLE_CONNECTION_ERROR_CERT_SELF_SIGNED | The server's SSL certificate is self-signed.
|
PURPLE_CONNECTION_ERROR_CERT_OTHER_ERROR | There was some other error validating the server's SSL certificate. |
PURPLE_CONNECTION_ERROR_OTHER_ERROR | Some other error occurred which fits into none of the other categories. |
Definition at line 65 of file connection.h.
Flags to change behavior of the client for a given connection.
Definition at line 36 of file connection.h.
Enumerator | |
---|---|
PURPLE_DISCONNECTED | Disconnected. |
PURPLE_CONNECTED | Connected.
|
PURPLE_CONNECTING | Connecting.
|
Definition at line 52 of file connection.h.
void purple_connection_destroy | ( | PurpleConnection * | gc | ) |
Disconnects and destroys a PurpleConnection.
This function should only be called by purple_account_disconnect() in account.c. If you're trying to sign off an account, use that function instead.
gc | The purple connection to destroy. |
void purple_connection_error | ( | PurpleConnection * | gc, |
const char * | reason | ||
) |
Closes a connection with an error.
gc | The connection. |
reason | The error text, which may not be NULL . |
purple_connection_error(gc, text)
is equivalent to calling purple_connection_error_reason(gc, reason, text)
where reason
is PURPLE_CONNECTION_ERROR_OTHER_ERROR if gc->wants_to_die
is TRUE
, and PURPLE_CONNECTION_ERROR_NETWORK_ERROR if not. (This is to keep auto-reconnection behaviour the same when using old prpls which don't use reasons yet.) gboolean purple_connection_error_is_fatal | ( | PurpleConnectionError | reason | ) |
Reports whether a disconnection reason is fatal (in which case the account should probably not be automatically reconnected) or transient (so auto-reconnection is a good idea).
For instance, PURPLE_CONNECTION_ERROR_NETWORK_ERROR is a temporary error, which might be caused by losing the network connection, so purple_connection_error_is_fatal (PURPLE_CONNECTION_ERROR_NETWORK_ERROR)
is FALSE
. On the other hand, PURPLE_CONNECTION_ERROR_AUTHENTICATION_FAILED probably indicates a misconfiguration of the account which needs the user to go fix it up, so purple_connection_error_is_fatal (PURPLE_CONNECTION_ERROR_AUTHENTICATION_FAILED)
is TRUE
.
(This function is meant to replace checking PurpleConnection.wants_to_die.)
TRUE
if the account should not be automatically reconnected, and FALSE
otherwise.void purple_connection_error_reason | ( | PurpleConnection * | gc, |
PurpleConnectionError | reason, | ||
const char * | description | ||
) |
Closes a connection with an error and a human-readable description of the error.
It also sets gc->wants_to_die
to the value of purple_connection_error_is_fatal(reason), mainly for backwards-compatibility.
gc | the connection which is closing. |
reason | why the connection is closing. |
description | a non-NULL localized description of the error. |
PurpleAccount * purple_connection_get_account | ( | const PurpleConnection * | gc | ) |
Returns the connection's account.
gc | The connection. |
const char * purple_connection_get_display_name | ( | const PurpleConnection * | gc | ) |
Returns the connection's displayed name.
gc | The connection. |
const char * purple_connection_get_password | ( | const PurpleConnection * | gc | ) |
Returns the connection's password.
gc | The connection. |
void * purple_connection_get_protocol_data | ( | const PurpleConnection * | connection | ) |
Gets the protocol data from a connection.
connection | The PurpleConnection. |
PurplePlugin * purple_connection_get_prpl | ( | const PurpleConnection * | gc | ) |
Returns the protocol plugin managing a connection.
gc | The connection. |
PurpleConnectionState purple_connection_get_state | ( | const PurpleConnection * | gc | ) |
Returns the connection state.
gc | The connection. |
void purple_connection_new | ( | PurpleAccount * | account, |
gboolean | regist, | ||
const char * | password | ||
) |
This function should only be called by purple_account_connect() in account.c.
If you're trying to sign on an account, use that function instead.
Creates a connection to the specified account and either connects or attempts to register a new account. If you are logging in, the connection uses the current active status for this account. So if you want to sign on as "away," for example, you need to have called purple_account_set_status(account, "away"). (And this will call purple_account_connect() automatically).
account | The account the connection should be connecting to. |
regist | Whether we are registering a new account or just trying to do a normal signon. |
password | The password to use. |
void purple_connection_new_unregister | ( | PurpleAccount * | account, |
const char * | password, | ||
PurpleAccountUnregistrationCb | cb, | ||
void * | user_data | ||
) |
This function should only be called by purple_account_unregister() in account.c.
Tries to unregister the account on the server. If the account is not connected, also creates a new connection.
account | The account to unregister |
password | The password to use. |
cb | Optional callback to be called when unregistration is complete |
user_data | user data to pass to the callback |
void purple_connection_notice | ( | PurpleConnection * | gc, |
const char * | text | ||
) |
Displays a connection-specific notice.
gc | The connection. |
text | The notice text. |
void purple_connection_set_account | ( | PurpleConnection * | gc, |
PurpleAccount * | account | ||
) |
Sets the connection's account.
gc | The connection. |
account | The account. |
void purple_connection_set_display_name | ( | PurpleConnection * | gc, |
const char * | name | ||
) |
Sets the connection's displayed name.
gc | The connection. |
name | The displayed name. |
void purple_connection_set_protocol_data | ( | PurpleConnection * | connection, |
void * | proto_data | ||
) |
Sets the protocol data for a connection.
connection | The PurpleConnection. |
proto_data | The protocol data to set for the connection. |
void purple_connection_set_state | ( | PurpleConnection * | gc, |
PurpleConnectionState | state | ||
) |
Sets the connection state.
PRPLs should call this and pass in the state PURPLE_CONNECTED when the account is completely signed on. What does it mean to be completely signed on? If the core can call prpl->set_status, and it successfully changes your status, then the account is online.
gc | The connection. |
state | The connection state. |
void purple_connection_ssl_error | ( | PurpleConnection * | gc, |
PurpleSslErrorType | ssl_error | ||
) |
Closes a connection due to an SSL error; this is basically a shortcut to turning the PurpleSslErrorType into a PurpleConnectionError and a human-readable string and then calling purple_connection_error_reason().
void purple_connection_update_progress | ( | PurpleConnection * | gc, |
const char * | text, | ||
size_t | step, | ||
size_t | count | ||
) |
Updates the connection progress.
gc | The connection. |
text | Information on the current step. |
step | The current step. |
count | The total number of steps. |
GList * purple_connections_get_all | ( | void | ) |
Returns a list of all active connections.
This does not include connections that are in the process of connecting.
GList * purple_connections_get_connecting | ( | void | ) |
Returns a list of all connections in the process of connecting.
void * purple_connections_get_handle | ( | void | ) |
Returns the handle to the connections subsystem.
PurpleConnectionUiOps * purple_connections_get_ui_ops | ( | void | ) |
Returns the UI operations structure used for connections.
void purple_connections_set_ui_ops | ( | PurpleConnectionUiOps * | ops | ) |
Sets the UI operations structure to be used for connections.
ops | The UI operations structure. |