mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Show available resources for current account with "/account"
This commit is contained in:
parent
f1693278cb
commit
502d7dc9fe
@ -184,9 +184,9 @@ static struct cmd_t main_commands[] =
|
|||||||
NULL } } },
|
NULL } } },
|
||||||
|
|
||||||
{ "/account",
|
{ "/account",
|
||||||
_cmd_account, parse_args, 1, 4,
|
_cmd_account, parse_args, 0, 4,
|
||||||
{ "/account command [account] [property] [value]", "Manage accounts.",
|
{ "/account [command] [account] [property] [value]", "Manage accounts.",
|
||||||
{ "/account command [account] [property] [value]",
|
{ "/account [command] [account] [property] [value]",
|
||||||
"---------------------------------------------",
|
"---------------------------------------------",
|
||||||
"Commands for creating and managing accounts.",
|
"Commands for creating and managing accounts.",
|
||||||
"list : List all accounts.",
|
"list : List all accounts.",
|
||||||
@ -197,6 +197,7 @@ static struct cmd_t main_commands[] =
|
|||||||
"rename account newname : Rename account to newname.",
|
"rename account newname : Rename account to newname.",
|
||||||
"set account property value : Set 'property' of 'account' to 'value'.",
|
"set account property value : Set 'property' of 'account' to 'value'.",
|
||||||
"",
|
"",
|
||||||
|
"When connected, the /account command can be called with no arguments, to info about the current account.",
|
||||||
"The 'property' may be one of.",
|
"The 'property' may be one of.",
|
||||||
"jid : The Jabber ID of the account, the account name will be used if this property is not set.",
|
"jid : The Jabber ID of the account, the account name will be used if this property is not set.",
|
||||||
"server : The chat service server, if different to the domain part of the JID.",
|
"server : The chat service server, if different to the domain part of the JID.",
|
||||||
@ -1079,7 +1080,15 @@ _cmd_account(gchar **args, struct cmd_help_t help)
|
|||||||
{
|
{
|
||||||
char *command = args[0];
|
char *command = args[0];
|
||||||
|
|
||||||
if (strcmp(command, "list") == 0) {
|
if (command == NULL) {
|
||||||
|
if (jabber_get_connection_status() != JABBER_CONNECTED) {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
} else {
|
||||||
|
ProfAccount *account = accounts_get_account(jabber_get_account_name());
|
||||||
|
cons_show_account(account);
|
||||||
|
accounts_free_account(account);
|
||||||
|
}
|
||||||
|
} else if (strcmp(command, "list") == 0) {
|
||||||
gchar **accounts = accounts_get_list();
|
gchar **accounts = accounts_get_list();
|
||||||
cons_show_account_list(accounts);
|
cons_show_account_list(accounts);
|
||||||
g_strfreev(accounts);
|
g_strfreev(accounts);
|
||||||
|
138
src/ui/windows.c
138
src/ui/windows.c
@ -1331,6 +1331,114 @@ cons_show_account_list(gchar **accounts)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
cons_show_account(ProfAccount *account)
|
||||||
|
{
|
||||||
|
cons_show("");
|
||||||
|
cons_show("Account %s:", account->name);
|
||||||
|
if (account->enabled) {
|
||||||
|
cons_show ("enabled : TRUE");
|
||||||
|
} else {
|
||||||
|
cons_show ("enabled : FALSE");
|
||||||
|
}
|
||||||
|
cons_show ("jid : %s", account->jid);
|
||||||
|
if (account->resource != NULL) {
|
||||||
|
cons_show ("resource : %s", account->resource);
|
||||||
|
}
|
||||||
|
if (account->server != NULL) {
|
||||||
|
cons_show ("server : %s", account->server);
|
||||||
|
}
|
||||||
|
if (account->last_presence != NULL) {
|
||||||
|
cons_show ("Last presence : %s", account->last_presence);
|
||||||
|
}
|
||||||
|
if (account->login_presence != NULL) {
|
||||||
|
cons_show ("Login presence : %s", account->login_presence);
|
||||||
|
}
|
||||||
|
cons_show ("Priority : chat:%d, online:%d, away:%d, xa:%d, dnd:%d",
|
||||||
|
account->priority_chat, account->priority_online, account->priority_away,
|
||||||
|
account->priority_xa, account->priority_dnd);
|
||||||
|
|
||||||
|
GList *resources = jabber_get_available_resources();
|
||||||
|
GList *ordered_resources = NULL;
|
||||||
|
|
||||||
|
WINDOW *win = console->win;
|
||||||
|
if (resources != NULL) {
|
||||||
|
_win_show_time(win, '-');
|
||||||
|
wprintw(win, "Resources:\n");
|
||||||
|
|
||||||
|
// sort in order of availabiltiy
|
||||||
|
while (resources != NULL) {
|
||||||
|
Resource *resource = resources->data;
|
||||||
|
ordered_resources = g_list_insert_sorted(ordered_resources,
|
||||||
|
resource, (GCompareFunc)resource_compare_availability);
|
||||||
|
resources = g_list_next(resources);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
while (ordered_resources != NULL) {
|
||||||
|
Resource *resource = ordered_resources->data;
|
||||||
|
const char *resource_presence = string_from_resource_presence(resource->presence);
|
||||||
|
_win_show_time(win, '-');
|
||||||
|
_presence_colour_on(win, resource_presence);
|
||||||
|
wprintw(win, " %s (%d), %s", resource->name, resource->priority, resource_presence);
|
||||||
|
if (resource->status != NULL) {
|
||||||
|
wprintw(win, ", \"%s\"", resource->status);
|
||||||
|
}
|
||||||
|
wprintw(win, "\n");
|
||||||
|
_presence_colour_off(win, resource_presence);
|
||||||
|
|
||||||
|
if (resource->caps_str != NULL) {
|
||||||
|
Capabilities *caps = caps_get(resource->caps_str);
|
||||||
|
if (caps != NULL) {
|
||||||
|
// show identity
|
||||||
|
if ((caps->category != NULL) || (caps->type != NULL) || (caps->name != NULL)) {
|
||||||
|
_win_show_time(win, '-');
|
||||||
|
wprintw(win, " Identity: ");
|
||||||
|
if (caps->name != NULL) {
|
||||||
|
wprintw(win, "%s", caps->name);
|
||||||
|
if ((caps->category != NULL) || (caps->type != NULL)) {
|
||||||
|
wprintw(win, " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (caps->type != NULL) {
|
||||||
|
wprintw(win, "%s", caps->type);
|
||||||
|
if (caps->category != NULL) {
|
||||||
|
wprintw(win, " ");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (caps->category != NULL) {
|
||||||
|
wprintw(win, "%s", caps->category);
|
||||||
|
}
|
||||||
|
wprintw(win, "\n");
|
||||||
|
}
|
||||||
|
if (caps->software != NULL) {
|
||||||
|
_win_show_time(win, '-');
|
||||||
|
wprintw(win, " Software: %s", caps->software);
|
||||||
|
}
|
||||||
|
if (caps->software_version != NULL) {
|
||||||
|
wprintw(win, ", %s", caps->software_version);
|
||||||
|
}
|
||||||
|
if ((caps->software != NULL) || (caps->software_version != NULL)) {
|
||||||
|
wprintw(win, "\n");
|
||||||
|
}
|
||||||
|
if (caps->os != NULL) {
|
||||||
|
_win_show_time(win, '-');
|
||||||
|
wprintw(win, " OS: %s", caps->os);
|
||||||
|
}
|
||||||
|
if (caps->os_version != NULL) {
|
||||||
|
wprintw(win, ", %s", caps->os_version);
|
||||||
|
}
|
||||||
|
if ((caps->os != NULL) || (caps->os_version != NULL)) {
|
||||||
|
wprintw(win, "\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ordered_resources = g_list_next(ordered_resources);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
win_show_status(void)
|
win_show_status(void)
|
||||||
{
|
{
|
||||||
@ -1372,36 +1480,6 @@ win_room_show_status(const char * const contact)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
cons_show_account(ProfAccount *account)
|
|
||||||
{
|
|
||||||
cons_show("%s account details:", account->name);
|
|
||||||
if (account->enabled) {
|
|
||||||
cons_show ("enabled : TRUE");
|
|
||||||
} else {
|
|
||||||
cons_show ("enabled : FALSE");
|
|
||||||
}
|
|
||||||
cons_show ("jid : %s", account->jid);
|
|
||||||
if (account->resource != NULL) {
|
|
||||||
cons_show ("resource : %s", account->resource);
|
|
||||||
}
|
|
||||||
if (account->server != NULL) {
|
|
||||||
cons_show ("server : %s", account->server);
|
|
||||||
}
|
|
||||||
if (account->last_presence != NULL) {
|
|
||||||
cons_show ("Last presence : %s", account->last_presence);
|
|
||||||
}
|
|
||||||
if (account->login_presence != NULL) {
|
|
||||||
cons_show ("Login presence : %s", account->login_presence);
|
|
||||||
}
|
|
||||||
cons_show ("Priority (chat) : %d", account->priority_chat);
|
|
||||||
cons_show ("Priority (online) : %d", account->priority_online);
|
|
||||||
cons_show ("Priority (away) : %d", account->priority_away);
|
|
||||||
cons_show ("Priority (xa) : %d", account->priority_xa);
|
|
||||||
cons_show ("Priority (dnd) : %d", account->priority_dnd);
|
|
||||||
cons_show("");
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
void
|
||||||
cons_show_ui_prefs(void)
|
cons_show_ui_prefs(void)
|
||||||
{
|
{
|
||||||
|
@ -52,6 +52,8 @@ static struct _jabber_conn_t {
|
|||||||
int tls_disabled;
|
int tls_disabled;
|
||||||
} jabber_conn;
|
} jabber_conn;
|
||||||
|
|
||||||
|
static GHashTable *available_resources;
|
||||||
|
|
||||||
// for auto reconnect
|
// for auto reconnect
|
||||||
static struct {
|
static struct {
|
||||||
char *name;
|
char *name;
|
||||||
@ -92,6 +94,8 @@ jabber_init(const int disable_tls)
|
|||||||
jabber_conn.tls_disabled = disable_tls;
|
jabber_conn.tls_disabled = disable_tls;
|
||||||
presence_init();
|
presence_init();
|
||||||
caps_init();
|
caps_init();
|
||||||
|
available_resources = g_hash_table_new_full(g_str_hash, g_str_equal, free,
|
||||||
|
(GDestroyNotify)resource_destroy);
|
||||||
}
|
}
|
||||||
|
|
||||||
jabber_conn_status_t
|
jabber_conn_status_t
|
||||||
@ -201,6 +205,12 @@ jabber_set_autoping(const int seconds)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GList *
|
||||||
|
jabber_get_available_resources(void)
|
||||||
|
{
|
||||||
|
return g_hash_table_get_values(available_resources);
|
||||||
|
}
|
||||||
|
|
||||||
jabber_conn_status_t
|
jabber_conn_status_t
|
||||||
jabber_get_connection_status(void)
|
jabber_get_connection_status(void)
|
||||||
{
|
{
|
||||||
@ -252,6 +262,18 @@ connection_set_priority(const int priority)
|
|||||||
jabber_conn.priority = priority;
|
jabber_conn.priority = priority;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
connection_add_available_resource(Resource *resource)
|
||||||
|
{
|
||||||
|
g_hash_table_replace(available_resources, strdup(resource->name), resource);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
connection_remove_available_resource(const char * const resource)
|
||||||
|
{
|
||||||
|
g_hash_table_remove(available_resources, resource);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
connection_free_resources(void)
|
connection_free_resources(void)
|
||||||
{
|
{
|
||||||
@ -261,6 +283,7 @@ connection_free_resources(void)
|
|||||||
FREE_SET_NULL(saved_details.altdomain);
|
FREE_SET_NULL(saved_details.altdomain);
|
||||||
FREE_SET_NULL(saved_account.name);
|
FREE_SET_NULL(saved_account.name);
|
||||||
FREE_SET_NULL(saved_account.passwd);
|
FREE_SET_NULL(saved_account.passwd);
|
||||||
|
g_hash_table_destroy(available_resources);
|
||||||
chat_sessions_clear();
|
chat_sessions_clear();
|
||||||
presence_free_sub_requests();
|
presence_free_sub_requests();
|
||||||
xmpp_conn_release(jabber_conn.conn);
|
xmpp_conn_release(jabber_conn.conn);
|
||||||
|
@ -32,5 +32,7 @@ int connection_error_handler(xmpp_conn_t * const conn,
|
|||||||
xmpp_stanza_t * const stanza, void * const userdata);
|
xmpp_stanza_t * const stanza, void * const userdata);
|
||||||
void connection_set_priority(int priority);
|
void connection_set_priority(int priority);
|
||||||
void connection_set_presence_message(const char * const message);
|
void connection_set_presence_message(const char * const message);
|
||||||
|
void connection_add_available_resource(Resource *resource);
|
||||||
|
void connection_remove_available_resource(const char * const resource);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -343,6 +343,8 @@ _unavailable_handler(xmpp_conn_t * const conn,
|
|||||||
|
|
||||||
if (strcmp(my_jid->barejid, from_jid->barejid) !=0) {
|
if (strcmp(my_jid->barejid, from_jid->barejid) !=0) {
|
||||||
prof_handle_contact_offline(from_jid->barejid, from_jid->resourcepart, status_str);
|
prof_handle_contact_offline(from_jid->barejid, from_jid->resourcepart, status_str);
|
||||||
|
} else {
|
||||||
|
connection_remove_available_resource(from_jid->resourcepart);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(my_jid);
|
jid_destroy(my_jid);
|
||||||
@ -425,6 +427,12 @@ _available_handler(xmpp_conn_t * const conn,
|
|||||||
Resource *resource = resource_new(from_jid->resourcepart, presence,
|
Resource *resource = resource_new(from_jid->resourcepart, presence,
|
||||||
status_str, priority, caps_key);
|
status_str, priority, caps_key);
|
||||||
prof_handle_contact_online(from_jid->barejid, resource, last_activity);
|
prof_handle_contact_online(from_jid->barejid, resource, last_activity);
|
||||||
|
} else {
|
||||||
|
// handle self presence
|
||||||
|
resource_presence_t presence = resource_presence_from_string(show_str);
|
||||||
|
Resource *resource = resource_new(from_jid->resourcepart, presence,
|
||||||
|
status_str, priority, caps_key);
|
||||||
|
connection_add_available_resource(resource);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(my_jid);
|
jid_destroy(my_jid);
|
||||||
|
@ -70,6 +70,7 @@ jabber_conn_status_t jabber_get_connection_status(void);
|
|||||||
char * jabber_get_presence_message(void);
|
char * jabber_get_presence_message(void);
|
||||||
void jabber_set_autoping(int seconds);
|
void jabber_set_autoping(int seconds);
|
||||||
char* jabber_get_account_name(void);
|
char* jabber_get_account_name(void);
|
||||||
|
GList * jabber_get_available_resources(void);
|
||||||
|
|
||||||
// message functions
|
// message functions
|
||||||
void message_send(const char * const msg, const char * const recipient);
|
void message_send(const char * const msg, const char * const recipient);
|
||||||
|
Loading…
Reference in New Issue
Block a user