mirror of
https://github.com/profanity-im/profanity.git
synced 2024-11-03 19:37:16 -05:00
Dynamically bind xmpp module api
This commit is contained in:
parent
f47bd58a1c
commit
81909ef000
@ -61,8 +61,8 @@ bookmark_request(void)
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
|
||||
void
|
||||
bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
||||
static void
|
||||
_bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
||||
{
|
||||
/* TODO: send request */
|
||||
/* TODO: manage bookmark_list */
|
||||
@ -71,9 +71,10 @@ bookmark_add(const char *jid, const char *nick, gboolean autojoin)
|
||||
autocomplete_remove(bookmark_ac, jid);
|
||||
autocomplete_add(bookmark_ac, jid);
|
||||
}
|
||||
void (*bookmark_add)(const char *, const char *, gboolean) = _bookmark_add;
|
||||
|
||||
void
|
||||
bookmark_remove(const char *jid, gboolean autojoin)
|
||||
static void
|
||||
_bookmark_remove(const char *jid, gboolean autojoin)
|
||||
{
|
||||
/* TODO: manage bookmark_list */
|
||||
if (autojoin) {
|
||||
@ -83,26 +84,30 @@ bookmark_remove(const char *jid, gboolean autojoin)
|
||||
autocomplete_remove(bookmark_ac, jid);
|
||||
}
|
||||
}
|
||||
void (*bookmark_remove)(const char *, gboolean) = _bookmark_remove;
|
||||
|
||||
const GList *
|
||||
bookmark_get_list(void)
|
||||
static const GList *
|
||||
_bookmark_get_list(void)
|
||||
{
|
||||
return bookmark_list;
|
||||
}
|
||||
const GList * (*bookmark_get_list)(void) = _bookmark_get_list;
|
||||
|
||||
char *
|
||||
bookmark_find(char *search_str)
|
||||
static char *
|
||||
_bookmark_find(char *search_str)
|
||||
{
|
||||
return autocomplete_complete(bookmark_ac, search_str);
|
||||
}
|
||||
char * (*bookmark_find)(char *) = _bookmark_find;
|
||||
|
||||
void
|
||||
bookmark_autocomplete_reset(void)
|
||||
static void
|
||||
_bookmark_autocomplete_reset(void)
|
||||
{
|
||||
if (bookmark_ac != NULL) {
|
||||
autocomplete_reset(bookmark_ac);
|
||||
}
|
||||
}
|
||||
void (*bookmark_autocomplete_reset)(void) = _bookmark_autocomplete_reset;
|
||||
|
||||
static int
|
||||
_bookmark_handle_result(xmpp_conn_t * const conn,
|
||||
|
@ -107,11 +107,12 @@ caps_contains(const char * const caps_str)
|
||||
return (g_hash_table_lookup(capabilities, caps_str) != NULL);
|
||||
}
|
||||
|
||||
Capabilities *
|
||||
caps_get(const char * const caps_str)
|
||||
static Capabilities *
|
||||
_caps_get(const char * const caps_str)
|
||||
{
|
||||
return g_hash_table_lookup(capabilities, caps_str);
|
||||
}
|
||||
Capabilities * (*caps_get)(const char * const) = _caps_get;
|
||||
|
||||
char *
|
||||
caps_create_sha1_str(xmpp_stanza_t * const query)
|
||||
@ -303,11 +304,12 @@ caps_create_query_response_stanza(xmpp_ctx_t * const ctx)
|
||||
return query;
|
||||
}
|
||||
|
||||
void
|
||||
caps_close(void)
|
||||
static void
|
||||
_caps_close(void)
|
||||
{
|
||||
g_hash_table_destroy(capabilities);
|
||||
}
|
||||
void (*caps_close)(void) = _caps_close;
|
||||
|
||||
static void
|
||||
_caps_destroy(Capabilities *caps)
|
||||
|
@ -91,8 +91,8 @@ void _connection_free_saved_account(void);
|
||||
void _connection_free_saved_details(void);
|
||||
void _connection_free_session_data(void);
|
||||
|
||||
void
|
||||
jabber_init(const int disable_tls)
|
||||
static void
|
||||
_jabber_init(const int disable_tls)
|
||||
{
|
||||
log_info("Initialising XMPP");
|
||||
jabber_conn.conn_status = JABBER_STARTED;
|
||||
@ -107,9 +107,10 @@ jabber_init(const int disable_tls)
|
||||
(GDestroyNotify)resource_destroy);
|
||||
xmpp_initialize();
|
||||
}
|
||||
void (*jabber_init)(const int) = _jabber_init;
|
||||
|
||||
jabber_conn_status_t
|
||||
jabber_connect_with_account(const ProfAccount * const account)
|
||||
static jabber_conn_status_t
|
||||
_jabber_connect_with_account(const ProfAccount * const account)
|
||||
{
|
||||
assert(account != NULL);
|
||||
|
||||
@ -127,9 +128,10 @@ jabber_connect_with_account(const ProfAccount * const account)
|
||||
|
||||
return result;
|
||||
}
|
||||
jabber_conn_status_t (*jabber_connect_with_account)(const ProfAccount * const) = _jabber_connect_with_account;
|
||||
|
||||
jabber_conn_status_t
|
||||
jabber_connect_with_details(const char * const jid,
|
||||
static jabber_conn_status_t
|
||||
_jabber_connect_with_details(const char * const jid,
|
||||
const char * const passwd, const char * const altdomain)
|
||||
{
|
||||
assert(jid != NULL);
|
||||
@ -159,9 +161,11 @@ jabber_connect_with_details(const char * const jid,
|
||||
log_info("Connecting without account, JID: %s", saved_details.jid);
|
||||
return _jabber_connect(saved_details.jid, passwd, saved_details.altdomain);
|
||||
}
|
||||
jabber_conn_status_t (*jabber_connect_with_details)(const char * const,
|
||||
const char * const, const char * const) = _jabber_connect_with_details;
|
||||
|
||||
void
|
||||
jabber_disconnect(void)
|
||||
static void
|
||||
_jabber_disconnect(void)
|
||||
{
|
||||
// if connected, send end stream and wait for response
|
||||
if (jabber_conn.conn_status == JABBER_CONNECTED) {
|
||||
@ -189,15 +193,17 @@ jabber_disconnect(void)
|
||||
FREE_SET_NULL(jabber_conn.presence_message);
|
||||
FREE_SET_NULL(jabber_conn.domain);
|
||||
}
|
||||
void (*jabber_disconnect)(void) = _jabber_disconnect;
|
||||
|
||||
void
|
||||
jabber_shutdown(void)
|
||||
static void
|
||||
_jabber_shutdown(void)
|
||||
{
|
||||
xmpp_shutdown();
|
||||
}
|
||||
void (*jabber_shutdown)(void) = _jabber_shutdown;
|
||||
|
||||
void
|
||||
jabber_process_events(void)
|
||||
static void
|
||||
_jabber_process_events(void)
|
||||
{
|
||||
// run xmpp event loop if connected, connecting or disconnecting
|
||||
if (jabber_conn.conn_status == JABBER_CONNECTED
|
||||
@ -216,9 +222,10 @@ jabber_process_events(void)
|
||||
}
|
||||
|
||||
}
|
||||
void (*jabber_process_events)(void) = _jabber_process_events;
|
||||
|
||||
void
|
||||
jabber_set_autoping(const int seconds)
|
||||
static void
|
||||
_jabber_set_autoping(const int seconds)
|
||||
{
|
||||
if (jabber_conn.conn_status == JABBER_CONNECTED) {
|
||||
xmpp_timed_handler_delete(jabber_conn.conn, _ping_timed_handler);
|
||||
@ -230,18 +237,21 @@ jabber_set_autoping(const int seconds)
|
||||
}
|
||||
}
|
||||
}
|
||||
void (*jabber_set_autoping)(const int) = _jabber_set_autoping;
|
||||
|
||||
GList *
|
||||
jabber_get_available_resources(void)
|
||||
static GList *
|
||||
_jabber_get_available_resources(void)
|
||||
{
|
||||
return g_hash_table_get_values(available_resources);
|
||||
}
|
||||
GList * (*jabber_get_available_resources)(void) = _jabber_get_available_resources;
|
||||
|
||||
jabber_conn_status_t
|
||||
jabber_get_connection_status(void)
|
||||
static jabber_conn_status_t
|
||||
_jabber_get_connection_status(void)
|
||||
{
|
||||
return (jabber_conn.conn_status);
|
||||
}
|
||||
jabber_conn_status_t (*jabber_get_connection_status)(void) = _jabber_get_connection_status;
|
||||
|
||||
xmpp_conn_t *
|
||||
connection_get_conn(void)
|
||||
@ -255,29 +265,33 @@ connection_get_ctx(void)
|
||||
return jabber_conn.ctx;
|
||||
}
|
||||
|
||||
const char *
|
||||
jabber_get_fulljid(void)
|
||||
static const char *
|
||||
_jabber_get_fulljid(void)
|
||||
{
|
||||
return xmpp_conn_get_jid(jabber_conn.conn);
|
||||
}
|
||||
const char * (*jabber_get_fulljid)(void) = _jabber_get_fulljid;
|
||||
|
||||
const char *
|
||||
jabber_get_domain(void)
|
||||
static const char *
|
||||
_jabber_get_domain(void)
|
||||
{
|
||||
return jabber_conn.domain;
|
||||
}
|
||||
const char * (*jabber_get_domain)(void) = _jabber_get_domain;
|
||||
|
||||
char *
|
||||
jabber_get_presence_message(void)
|
||||
static char *
|
||||
_jabber_get_presence_message(void)
|
||||
{
|
||||
return jabber_conn.presence_message;
|
||||
}
|
||||
char * (*jabber_get_presence_message)(void) = _jabber_get_presence_message;
|
||||
|
||||
char *
|
||||
jabber_get_account_name(void)
|
||||
static char *
|
||||
_jabber_get_account_name(void)
|
||||
{
|
||||
return saved_account.name;
|
||||
}
|
||||
char * (*jabber_get_account_name)(void) = _jabber_get_account_name;
|
||||
|
||||
void
|
||||
connection_set_presence_message(const char * const message)
|
||||
|
@ -75,8 +75,8 @@ iq_add_handlers(void)
|
||||
HANDLE(STANZA_NS_PING, STANZA_TYPE_GET, _iq_handle_ping_get);
|
||||
}
|
||||
|
||||
void
|
||||
iq_room_list_request(gchar *conferencejid)
|
||||
static void
|
||||
_iq_room_list_request(gchar *conferencejid)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -84,9 +84,10 @@ iq_room_list_request(gchar *conferencejid)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*iq_room_list_request)(gchar *) = _iq_room_list_request;
|
||||
|
||||
void
|
||||
iq_disco_info_request(gchar *jid)
|
||||
static void
|
||||
_iq_disco_info_request(gchar *jid)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -94,9 +95,10 @@ iq_disco_info_request(gchar *jid)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*iq_disco_info_request)(gchar *) = _iq_disco_info_request;
|
||||
|
||||
void
|
||||
iq_disco_items_request(gchar *jid)
|
||||
static void
|
||||
_iq_disco_items_request(gchar *jid)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -104,9 +106,10 @@ iq_disco_items_request(gchar *jid)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*iq_disco_items_request)(gchar *) = _iq_disco_items_request;
|
||||
|
||||
void
|
||||
iq_send_software_version(const char * const fulljid)
|
||||
static void
|
||||
_iq_send_software_version(const char * const fulljid)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -114,6 +117,7 @@ iq_send_software_version(const char * const fulljid)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*iq_send_software_version)(const char * const) = _iq_send_software_version;
|
||||
|
||||
static int
|
||||
_iq_handle_error(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
||||
|
@ -57,8 +57,8 @@ message_add_handlers(void)
|
||||
HANDLE(NULL, NULL, _conference_message_handler);
|
||||
}
|
||||
|
||||
void
|
||||
message_send(const char * const msg, const char * const recipient)
|
||||
static void
|
||||
_message_send(const char * const msg, const char * const recipient)
|
||||
{
|
||||
const char * jid = NULL;
|
||||
|
||||
@ -89,9 +89,10 @@ message_send(const char * const msg, const char * const recipient)
|
||||
xmpp_send(conn, message);
|
||||
xmpp_stanza_release(message);
|
||||
}
|
||||
void (*message_send)(const char * const, const char * const) = _message_send;
|
||||
|
||||
void
|
||||
message_send_groupchat(const char * const msg, const char * const recipient)
|
||||
static void
|
||||
_message_send_groupchat(const char * const msg, const char * const recipient)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -101,9 +102,10 @@ message_send_groupchat(const char * const msg, const char * const recipient)
|
||||
xmpp_send(conn, message);
|
||||
xmpp_stanza_release(message);
|
||||
}
|
||||
void (*message_send_groupchat)(const char * const, const char * const) = _message_send_groupchat;
|
||||
|
||||
void
|
||||
message_send_duck(const char * const query)
|
||||
static void
|
||||
_message_send_duck(const char * const query)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -113,9 +115,10 @@ message_send_duck(const char * const query)
|
||||
xmpp_send(conn, message);
|
||||
xmpp_stanza_release(message);
|
||||
}
|
||||
void (*message_send_duck)(const char * const) = _message_send_duck;
|
||||
|
||||
void
|
||||
message_send_invite(const char * const room, const char * const contact,
|
||||
static void
|
||||
_message_send_invite(const char * const room, const char * const contact,
|
||||
const char * const reason)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
@ -125,9 +128,11 @@ message_send_invite(const char * const room, const char * const contact,
|
||||
xmpp_send(conn, stanza);
|
||||
xmpp_stanza_release(stanza);
|
||||
}
|
||||
void (*message_send_invite)(const char * const, const char * const,
|
||||
const char * const) = _message_send_invite;
|
||||
|
||||
void
|
||||
message_send_composing(const char * const recipient)
|
||||
static void
|
||||
_message_send_composing(const char * const recipient)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -138,9 +143,10 @@ message_send_composing(const char * const recipient)
|
||||
xmpp_stanza_release(stanza);
|
||||
chat_session_set_sent(recipient);
|
||||
}
|
||||
void (*message_send_composing)(const char * const) = _message_send_composing;
|
||||
|
||||
void
|
||||
message_send_paused(const char * const recipient)
|
||||
static void
|
||||
_message_send_paused(const char * const recipient)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -151,9 +157,10 @@ message_send_paused(const char * const recipient)
|
||||
xmpp_stanza_release(stanza);
|
||||
chat_session_set_sent(recipient);
|
||||
}
|
||||
void (*message_send_paused)(const char * const) = _message_send_paused;
|
||||
|
||||
void
|
||||
message_send_inactive(const char * const recipient)
|
||||
static void
|
||||
_message_send_inactive(const char * const recipient)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -164,9 +171,10 @@ message_send_inactive(const char * const recipient)
|
||||
xmpp_stanza_release(stanza);
|
||||
chat_session_set_sent(recipient);
|
||||
}
|
||||
void (*message_send_inactive)(const char * const) = _message_send_inactive;
|
||||
|
||||
void
|
||||
message_send_gone(const char * const recipient)
|
||||
static void
|
||||
_message_send_gone(const char * const recipient)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -177,6 +185,7 @@ message_send_gone(const char * const recipient)
|
||||
xmpp_stanza_release(stanza);
|
||||
chat_session_set_sent(recipient);
|
||||
}
|
||||
void (*message_send_gone)(const char * const) = _message_send_gone;
|
||||
|
||||
static int
|
||||
_conference_message_handler(xmpp_conn_t * const conn,
|
||||
|
@ -80,8 +80,8 @@ presence_add_handlers(void)
|
||||
HANDLE(NULL, NULL, _available_handler);
|
||||
}
|
||||
|
||||
void
|
||||
presence_subscription(const char * const jid, const jabber_subscr_t action)
|
||||
static void
|
||||
_presence_subscription(const char * const jid, const jabber_subscr_t action)
|
||||
{
|
||||
assert(jid != NULL);
|
||||
|
||||
@ -121,18 +121,21 @@ presence_subscription(const char * const jid, const jabber_subscr_t action)
|
||||
|
||||
jid_destroy(jidp);
|
||||
}
|
||||
void (*presence_subscription)(const char * const, const jabber_subscr_t) = _presence_subscription;
|
||||
|
||||
GSList *
|
||||
presence_get_subscription_requests(void)
|
||||
static GSList *
|
||||
_presence_get_subscription_requests(void)
|
||||
{
|
||||
return autocomplete_get_list(sub_requests_ac);
|
||||
}
|
||||
GSList * (*presence_get_subscription_requests)(void) = _presence_get_subscription_requests;
|
||||
|
||||
gint
|
||||
presence_sub_request_count(void)
|
||||
static gint
|
||||
_presence_sub_request_count(void)
|
||||
{
|
||||
return autocomplete_length(sub_requests_ac);
|
||||
}
|
||||
gint (*presence_sub_request_count)(void) = _presence_sub_request_count;
|
||||
|
||||
void
|
||||
presence_free_sub_requests(void)
|
||||
@ -146,14 +149,15 @@ presence_clear_sub_requests(void)
|
||||
autocomplete_clear(sub_requests_ac);
|
||||
}
|
||||
|
||||
char *
|
||||
presence_sub_request_find(char * search_str)
|
||||
static char *
|
||||
_presence_sub_request_find(char * search_str)
|
||||
{
|
||||
return autocomplete_complete(sub_requests_ac, search_str);
|
||||
}
|
||||
char * (*presence_sub_request_find)(char *) = _presence_sub_request_find;
|
||||
|
||||
gboolean
|
||||
presence_sub_request_exists(const char * const bare_jid)
|
||||
static gboolean
|
||||
_presence_sub_request_exists(const char * const bare_jid)
|
||||
{
|
||||
gboolean result = FALSE;
|
||||
GSList *requests_p = autocomplete_get_list(sub_requests_ac);
|
||||
@ -173,15 +177,17 @@ presence_sub_request_exists(const char * const bare_jid)
|
||||
|
||||
return result;
|
||||
}
|
||||
gboolean (*presence_sub_request_exists)(const char * const) = _presence_sub_request_exists;
|
||||
|
||||
void
|
||||
presence_reset_sub_request_search(void)
|
||||
static void
|
||||
_presence_reset_sub_request_search(void)
|
||||
{
|
||||
autocomplete_reset(sub_requests_ac);
|
||||
}
|
||||
void (*presence_reset_sub_request_search)(void) = _presence_reset_sub_request_search;
|
||||
|
||||
void
|
||||
presence_update(const resource_presence_t presence_type, const char * const msg,
|
||||
static void
|
||||
_presence_update(const resource_presence_t presence_type, const char * const msg,
|
||||
const int idle)
|
||||
{
|
||||
if (jabber_get_connection_status() != JABBER_CONNECTED) {
|
||||
@ -224,6 +230,8 @@ presence_update(const resource_presence_t presence_type, const char * const msg,
|
||||
}
|
||||
accounts_set_last_presence(jabber_get_account_name(), last);
|
||||
}
|
||||
void (*presence_update)(const resource_presence_t, const char * const,
|
||||
const int) = _presence_update;
|
||||
|
||||
static void
|
||||
_send_room_presence(xmpp_conn_t *conn, xmpp_stanza_t *presence)
|
||||
@ -252,8 +260,8 @@ _send_room_presence(xmpp_conn_t *conn, xmpp_stanza_t *presence)
|
||||
}
|
||||
}
|
||||
|
||||
void
|
||||
presence_join_room(Jid *jid)
|
||||
static void
|
||||
_presence_join_room(Jid *jid)
|
||||
{
|
||||
assert(jid != NULL);
|
||||
assert(jid->fulljid != NULL);
|
||||
@ -279,9 +287,10 @@ presence_join_room(Jid *jid)
|
||||
|
||||
muc_join_room(jid->barejid, jid->resourcepart);
|
||||
}
|
||||
void (*presence_join_room)(Jid *) = _presence_join_room;
|
||||
|
||||
void
|
||||
presence_change_room_nick(const char * const room, const char * const nick)
|
||||
static void
|
||||
_presence_change_room_nick(const char * const room, const char * const nick)
|
||||
{
|
||||
assert(room != NULL);
|
||||
assert(nick != NULL);
|
||||
@ -309,9 +318,10 @@ presence_change_room_nick(const char * const room, const char * const nick)
|
||||
|
||||
free(full_room_jid);
|
||||
}
|
||||
void (*presence_change_room_nick)(const char * const, const char * const) = _presence_change_room_nick;
|
||||
|
||||
void
|
||||
presence_leave_chat_room(const char * const room_jid)
|
||||
static void
|
||||
_presence_leave_chat_room(const char * const room_jid)
|
||||
{
|
||||
assert(room_jid != NULL);
|
||||
|
||||
@ -327,6 +337,7 @@ presence_leave_chat_room(const char * const room_jid)
|
||||
xmpp_stanza_release(presence);
|
||||
}
|
||||
}
|
||||
void (*presence_leave_chat_room)(const char * const) = _presence_leave_chat_room;
|
||||
|
||||
static int
|
||||
_unsubscribed_handler(xmpp_conn_t * const conn,
|
||||
|
@ -81,8 +81,8 @@ roster_request(void)
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
|
||||
void
|
||||
roster_add_new(const char * const barejid, const char * const name)
|
||||
static void
|
||||
_roster_add_new(const char * const barejid, const char * const name)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -90,9 +90,10 @@ roster_add_new(const char * const barejid, const char * const name)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*roster_add_new)(const char * const, const char * const) = _roster_add_new;
|
||||
|
||||
void
|
||||
roster_send_remove(const char * const barejid)
|
||||
static void
|
||||
_roster_send_remove(const char * const barejid)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -100,9 +101,10 @@ roster_send_remove(const char * const barejid)
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*roster_send_remove)(const char * const) = _roster_send_remove;
|
||||
|
||||
void
|
||||
roster_send_name_change(const char * const barejid, const char * const new_name, GSList *groups)
|
||||
static void
|
||||
_roster_send_name_change(const char * const barejid, const char * const new_name, GSList *groups)
|
||||
{
|
||||
xmpp_conn_t * const conn = connection_get_conn();
|
||||
xmpp_ctx_t * const ctx = connection_get_ctx();
|
||||
@ -111,9 +113,11 @@ roster_send_name_change(const char * const barejid, const char * const new_name,
|
||||
xmpp_send(conn, iq);
|
||||
xmpp_stanza_release(iq);
|
||||
}
|
||||
void (*roster_send_name_change)(const char * const, const char * const,
|
||||
GSList *) = _roster_send_name_change;
|
||||
|
||||
void
|
||||
roster_send_add_to_group(const char * const group, PContact contact)
|
||||
static void
|
||||
_roster_send_add_to_group(const char * const group, PContact contact)
|
||||
{
|
||||
GSList *groups = p_contact_groups(contact);
|
||||
GSList *new_groups = NULL;
|
||||
@ -142,6 +146,7 @@ roster_send_add_to_group(const char * const group, PContact contact)
|
||||
xmpp_stanza_release(iq);
|
||||
free(unique_id);
|
||||
}
|
||||
void (*roster_send_add_to_group)(const char * const, PContact) = _roster_send_add_to_group;
|
||||
|
||||
static int
|
||||
_group_add_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
||||
@ -157,8 +162,8 @@ _group_add_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
||||
return 0;
|
||||
}
|
||||
|
||||
void
|
||||
roster_send_remove_from_group(const char * const group, PContact contact)
|
||||
static void
|
||||
_roster_send_remove_from_group(const char * const group, PContact contact)
|
||||
{
|
||||
GSList *groups = p_contact_groups(contact);
|
||||
GSList *new_groups = NULL;
|
||||
@ -189,6 +194,7 @@ roster_send_remove_from_group(const char * const group, PContact contact)
|
||||
xmpp_stanza_release(iq);
|
||||
free(unique_id);
|
||||
}
|
||||
void (*roster_send_remove_from_group)(const char * const, PContact) = _roster_send_remove_from_group;
|
||||
|
||||
static int
|
||||
_group_remove_handler(xmpp_conn_t * const conn, xmpp_stanza_t * const stanza,
|
||||
|
@ -75,65 +75,65 @@ typedef struct disco_identity_t {
|
||||
} DiscoIdentity;
|
||||
|
||||
// connection functions
|
||||
void jabber_init(const int disable_tls);
|
||||
jabber_conn_status_t jabber_connect_with_details(const char * const jid,
|
||||
void (*jabber_init)(const int disable_tls);
|
||||
jabber_conn_status_t (*jabber_connect_with_details)(const char * const jid,
|
||||
const char * const passwd, const char * const altdomain);
|
||||
jabber_conn_status_t jabber_connect_with_account(const ProfAccount * const account);
|
||||
void jabber_disconnect(void);
|
||||
void jabber_shutdown(void);
|
||||
void jabber_process_events(void);
|
||||
const char * jabber_get_fulljid(void);
|
||||
const char * jabber_get_domain(void);
|
||||
jabber_conn_status_t jabber_get_connection_status(void);
|
||||
char * jabber_get_presence_message(void);
|
||||
void jabber_set_autoping(int seconds);
|
||||
char* jabber_get_account_name(void);
|
||||
GList * jabber_get_available_resources(void);
|
||||
jabber_conn_status_t (*jabber_connect_with_account)(const ProfAccount * const account);
|
||||
void (*jabber_disconnect)(void);
|
||||
void (*jabber_shutdown)(void);
|
||||
void (*jabber_process_events)(void);
|
||||
const char * (*jabber_get_fulljid)(void);
|
||||
const char * (*jabber_get_domain)(void);
|
||||
jabber_conn_status_t (*jabber_get_connection_status)(void);
|
||||
char * (*jabber_get_presence_message)(void);
|
||||
void (*jabber_set_autoping)(int seconds);
|
||||
char* (*jabber_get_account_name)(void);
|
||||
GList * (*jabber_get_available_resources)(void);
|
||||
|
||||
// message functions
|
||||
void message_send(const char * const msg, const char * const recipient);
|
||||
void message_send_groupchat(const char * const msg, const char * const recipient);
|
||||
void message_send_inactive(const char * const recipient);
|
||||
void message_send_composing(const char * const recipient);
|
||||
void message_send_paused(const char * const recipient);
|
||||
void message_send_gone(const char * const recipient);
|
||||
void message_send_invite(const char * const room, const char * const contact,
|
||||
void (*message_send)(const char * const msg, const char * const recipient);
|
||||
void (*message_send_groupchat)(const char * const msg, const char * const recipient);
|
||||
void (*message_send_inactive)(const char * const recipient);
|
||||
void (*message_send_composing)(const char * const recipient);
|
||||
void (*message_send_paused)(const char * const recipient);
|
||||
void (*message_send_gone)(const char * const recipient);
|
||||
void (*message_send_invite)(const char * const room, const char * const contact,
|
||||
const char * const reason);
|
||||
void message_send_duck(const char * const query);
|
||||
void (*message_send_duck)(const char * const query);
|
||||
|
||||
// presence functions
|
||||
void presence_subscription(const char * const jid, const jabber_subscr_t action);
|
||||
GSList* presence_get_subscription_requests(void);
|
||||
gint presence_sub_request_count(void);
|
||||
void presence_reset_sub_request_search(void);
|
||||
char * presence_sub_request_find(char * search_str);
|
||||
void presence_join_room(Jid *jid);
|
||||
void presence_change_room_nick(const char * const room, const char * const nick);
|
||||
void presence_leave_chat_room(const char * const room_jid);
|
||||
void presence_update(resource_presence_t status, const char * const msg,
|
||||
void (*presence_subscription)(const char * const jid, const jabber_subscr_t action);
|
||||
GSList* (*presence_get_subscription_requests)(void);
|
||||
gint (*presence_sub_request_count)(void);
|
||||
void (*presence_reset_sub_request_search)(void);
|
||||
char * (*presence_sub_request_find)(char * search_str);
|
||||
void (*presence_join_room)(Jid *jid);
|
||||
void (*presence_change_room_nick)(const char * const room, const char * const nick);
|
||||
void (*presence_leave_chat_room)(const char * const room_jid);
|
||||
void (*presence_update)(resource_presence_t status, const char * const msg,
|
||||
int idle);
|
||||
gboolean presence_sub_request_exists(const char * const bare_jid);
|
||||
gboolean (*presence_sub_request_exists)(const char * const bare_jid);
|
||||
|
||||
// iq functions
|
||||
void iq_send_software_version(const char * const fulljid);
|
||||
void iq_room_list_request(gchar *conferencejid);
|
||||
void iq_disco_info_request(gchar *jid);
|
||||
void iq_disco_items_request(gchar *jid);
|
||||
void (*iq_send_software_version)(const char * const fulljid);
|
||||
void (*iq_room_list_request)(gchar *conferencejid);
|
||||
void (*iq_disco_info_request)(gchar *jid);
|
||||
void (*iq_disco_items_request)(gchar *jid);
|
||||
|
||||
// caps functions
|
||||
Capabilities* caps_get(const char * const caps_str);
|
||||
void caps_close(void);
|
||||
Capabilities* (*caps_get)(const char * const caps_str);
|
||||
void (*caps_close)(void);
|
||||
|
||||
void bookmark_add(const char *jid, const char *nick, gboolean autojoin);
|
||||
void bookmark_remove(const char *jid, gboolean autojoin);
|
||||
const GList *bookmark_get_list(void);
|
||||
char *bookmark_find(char *search_str);
|
||||
void bookmark_autocomplete_reset(void);
|
||||
void (*bookmark_add)(const char *jid, const char *nick, gboolean autojoin);
|
||||
void (*bookmark_remove)(const char *jid, gboolean autojoin);
|
||||
const GList * (*bookmark_get_list)(void);
|
||||
char * (*bookmark_find)(char *search_str);
|
||||
void (*bookmark_autocomplete_reset)(void);
|
||||
|
||||
void roster_send_name_change(const char * const barejid, const char * const new_name, GSList *groups);
|
||||
void roster_send_add_to_group(const char * const group, PContact contact);
|
||||
void roster_send_remove_from_group(const char * const group, PContact contact);
|
||||
void roster_add_new(const char * const barejid, const char * const name);
|
||||
void roster_send_remove(const char * const barejid);
|
||||
void (*roster_send_name_change)(const char * const barejid, const char * const new_name, GSList *groups);
|
||||
void (*roster_send_add_to_group)(const char * const group, PContact contact);
|
||||
void (*roster_send_remove_from_group)(const char * const group, PContact contact);
|
||||
void (*roster_add_new)(const char * const barejid, const char * const name);
|
||||
void (*roster_send_remove)(const char * const barejid);
|
||||
|
||||
#endif
|
||||
|
Loading…
Reference in New Issue
Block a user