mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Cleanup jid_destroy
to auto_jid
Remove unused variables Apply minor cleanups
This commit is contained in:
parent
8304ac86ff
commit
029f1caa52
@ -675,7 +675,7 @@ cmd_account_default(ProfWin* window, const char* const command, gchar** args)
|
|||||||
gboolean
|
gboolean
|
||||||
_account_set_jid(char* account_name, char* jid)
|
_account_set_jid(char* account_name, char* jid)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp == NULL) {
|
if (jidp == NULL) {
|
||||||
cons_show("Malformed jid: %s", jid);
|
cons_show("Malformed jid: %s", jid);
|
||||||
} else {
|
} else {
|
||||||
@ -687,7 +687,6 @@ _account_set_jid(char* account_name, char* jid)
|
|||||||
}
|
}
|
||||||
cons_show("");
|
cons_show("");
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -1259,7 +1258,7 @@ cmd_sub(ProfWin* window, const char* const command, gchar** args)
|
|||||||
jid = chatwin->barejid;
|
jid = chatwin->barejid;
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
|
|
||||||
if (strcmp(subcmd, "allow") == 0) {
|
if (strcmp(subcmd, "allow") == 0) {
|
||||||
presence_subscription(jidp->barejid, PRESENCE_SUBSCRIBED);
|
presence_subscription(jidp->barejid, PRESENCE_SUBSCRIBED);
|
||||||
@ -1304,8 +1303,6 @@ cmd_sub(ProfWin* window, const char* const command, gchar** args)
|
|||||||
cons_bad_cmd_usage(command);
|
cons_bad_cmd_usage(command);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2203,13 +2200,11 @@ cmd_msg(ProfWin* window, const char* const command, gchar** args)
|
|||||||
if (occupant) {
|
if (occupant) {
|
||||||
// in case of non-anon muc send regular chatmessage
|
// in case of non-anon muc send regular chatmessage
|
||||||
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
||||||
Jid* jidp = jid_create(occupant->jid);
|
auto_jid Jid* jidp = jid_create(occupant->jid);
|
||||||
|
|
||||||
_cmd_msg_chatwin(jidp->barejid, msg);
|
_cmd_msg_chatwin(jidp->barejid, msg);
|
||||||
win_println(window, THEME_DEFAULT, "-", "Starting direct message with occupant \"%s\" from room \"%s\" as \"%s\".", usr, mucwin->roomjid, jidp->barejid);
|
win_println(window, THEME_DEFAULT, "-", "Starting direct message with occupant \"%s\" from room \"%s\" as \"%s\".", usr, mucwin->roomjid, jidp->barejid);
|
||||||
cons_show("Starting direct message with occupant \"%s\" from room \"%s\" as \"%s\".", usr, mucwin->roomjid, jidp->barejid);
|
cons_show("Starting direct message with occupant \"%s\" from room \"%s\" as \"%s\".", usr, mucwin->roomjid, jidp->barejid);
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
// otherwise send mucpm
|
// otherwise send mucpm
|
||||||
GString* full_jid = g_string_new(mucwin->roomjid);
|
GString* full_jid = g_string_new(mucwin->roomjid);
|
||||||
@ -3299,14 +3294,13 @@ cmd_status_get(ProfWin* window, const char* const command, gchar** args)
|
|||||||
} else {
|
} else {
|
||||||
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
||||||
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
||||||
Jid* jid = jid_create(privatewin->fulljid);
|
auto_jid Jid* jid = jid_create(privatewin->fulljid);
|
||||||
Occupant* occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
Occupant* occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
||||||
if (occupant) {
|
if (occupant) {
|
||||||
win_show_occupant(window, occupant);
|
win_show_occupant(window, occupant);
|
||||||
} else {
|
} else {
|
||||||
win_println(window, THEME_DEFAULT, "-", "Error getting contact info.");
|
win_println(window, THEME_DEFAULT, "-", "Error getting contact info.");
|
||||||
}
|
}
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WIN_CONSOLE:
|
case WIN_CONSOLE:
|
||||||
@ -3389,14 +3383,13 @@ cmd_info(ProfWin* window, const char* const command, gchar** args)
|
|||||||
} else {
|
} else {
|
||||||
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
||||||
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
||||||
Jid* jid = jid_create(privatewin->fulljid);
|
auto_jid Jid* jid = jid_create(privatewin->fulljid);
|
||||||
Occupant* occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
Occupant* occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
||||||
if (occupant) {
|
if (occupant) {
|
||||||
win_show_occupant_info(window, jid->barejid, occupant);
|
win_show_occupant_info(window, jid->barejid, occupant);
|
||||||
} else {
|
} else {
|
||||||
win_println(window, THEME_DEFAULT, "-", "Error getting contact info.");
|
win_println(window, THEME_DEFAULT, "-", "Error getting contact info.");
|
||||||
}
|
}
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case WIN_CONSOLE:
|
case WIN_CONSOLE:
|
||||||
@ -3431,9 +3424,8 @@ cmd_caps(ProfWin* window, const char* const command, gchar** args)
|
|||||||
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
|
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
|
||||||
occupant = muc_roster_item(mucwin->roomjid, args[0]);
|
occupant = muc_roster_item(mucwin->roomjid, args[0]);
|
||||||
if (occupant) {
|
if (occupant) {
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(mucwin->roomjid, args[0]);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(mucwin->roomjid, args[0]);
|
||||||
cons_show_caps(jidp->fulljid, occupant->presence);
|
cons_show_caps(jidp->fulljid, occupant->presence);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
cons_show("No such participant \"%s\" in room.", args[0]);
|
cons_show("No such participant \"%s\" in room.", args[0]);
|
||||||
}
|
}
|
||||||
@ -3444,7 +3436,7 @@ cmd_caps(ProfWin* window, const char* const command, gchar** args)
|
|||||||
case WIN_CHAT:
|
case WIN_CHAT:
|
||||||
case WIN_CONSOLE:
|
case WIN_CONSOLE:
|
||||||
if (args[0]) {
|
if (args[0]) {
|
||||||
Jid* jid = jid_create(args[0]);
|
auto_jid Jid* jid = jid_create(args[0]);
|
||||||
|
|
||||||
if (jid->fulljid == NULL) {
|
if (jid->fulljid == NULL) {
|
||||||
cons_show("You must provide a full jid to the /caps command.");
|
cons_show("You must provide a full jid to the /caps command.");
|
||||||
@ -3461,7 +3453,6 @@ cmd_caps(ProfWin* window, const char* const command, gchar** args)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
jid_destroy(jid);
|
|
||||||
} else {
|
} else {
|
||||||
cons_show("You must provide a jid to the /caps command.");
|
cons_show("You must provide a jid to the /caps command.");
|
||||||
}
|
}
|
||||||
@ -3472,11 +3463,10 @@ cmd_caps(ProfWin* window, const char* const command, gchar** args)
|
|||||||
} else {
|
} else {
|
||||||
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
ProfPrivateWin* privatewin = (ProfPrivateWin*)window;
|
||||||
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
assert(privatewin->memcheck == PROFPRIVATEWIN_MEMCHECK);
|
||||||
Jid* jid = jid_create(privatewin->fulljid);
|
auto_jid Jid* jid = jid_create(privatewin->fulljid);
|
||||||
if (jid) {
|
if (jid) {
|
||||||
occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
occupant = muc_roster_item(jid->barejid, jid->resourcepart);
|
||||||
cons_show_caps(jid->resourcepart, occupant->presence);
|
cons_show_caps(jid->resourcepart, occupant->presence);
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -3491,7 +3481,7 @@ static void
|
|||||||
_send_software_version_iq_to_fulljid(char* request)
|
_send_software_version_iq_to_fulljid(char* request)
|
||||||
{
|
{
|
||||||
auto_char char* mybarejid = connection_get_barejid();
|
auto_char char* mybarejid = connection_get_barejid();
|
||||||
Jid* jid = jid_create(request);
|
auto_jid Jid* jid = jid_create(request);
|
||||||
|
|
||||||
if (jid == NULL || jid->fulljid == NULL) {
|
if (jid == NULL || jid->fulljid == NULL) {
|
||||||
cons_show("You must provide a full jid to the /software command.");
|
cons_show("You must provide a full jid to the /software command.");
|
||||||
@ -3500,7 +3490,6 @@ _send_software_version_iq_to_fulljid(char* request)
|
|||||||
} else {
|
} else {
|
||||||
iq_send_software_version(jid->fulljid);
|
iq_send_software_version(jid->fulljid);
|
||||||
}
|
}
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
@ -3520,9 +3509,8 @@ cmd_software(ProfWin* window, const char* const command, gchar** args)
|
|||||||
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
|
assert(mucwin->memcheck == PROFMUCWIN_MEMCHECK);
|
||||||
Occupant* occupant = muc_roster_item(mucwin->roomjid, args[0]);
|
Occupant* occupant = muc_roster_item(mucwin->roomjid, args[0]);
|
||||||
if (occupant) {
|
if (occupant) {
|
||||||
Jid* jid = jid_create_from_bare_and_resource(mucwin->roomjid, args[0]);
|
auto_jid Jid* jid = jid_create_from_bare_and_resource(mucwin->roomjid, args[0]);
|
||||||
iq_send_software_version(jid->fulljid);
|
iq_send_software_version(jid->fulljid);
|
||||||
jid_destroy(jid);
|
|
||||||
} else {
|
} else {
|
||||||
cons_show("No such participant \"%s\" in room.", args[0]);
|
cons_show("No such participant \"%s\" in room.", args[0]);
|
||||||
}
|
}
|
||||||
@ -3628,7 +3616,7 @@ cmd_join(ProfWin* window, const char* const command, gchar** args)
|
|||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* room_arg = jid_create(args[0]);
|
auto_jid Jid* room_arg = jid_create(args[0]);
|
||||||
if (room_arg == NULL) {
|
if (room_arg == NULL) {
|
||||||
cons_show_error("Specified room has incorrect format.");
|
cons_show_error("Specified room has incorrect format.");
|
||||||
cons_show("");
|
cons_show("");
|
||||||
@ -3663,7 +3651,6 @@ cmd_join(ProfWin* window, const char* const command, gchar** args)
|
|||||||
if (!parsed) {
|
if (!parsed) {
|
||||||
cons_bad_cmd_usage(command);
|
cons_bad_cmd_usage(command);
|
||||||
cons_show("");
|
cons_show("");
|
||||||
jid_destroy(room_arg);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3692,7 +3679,6 @@ cmd_join(ProfWin* window, const char* const command, gchar** args)
|
|||||||
ui_switch_to_room(room);
|
ui_switch_to_room(room);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(room_arg);
|
|
||||||
account_free(account);
|
account_free(account);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
@ -4889,9 +4875,8 @@ cmd_disco(ProfWin* window, const char* const command, gchar** args)
|
|||||||
if (args[1]) {
|
if (args[1]) {
|
||||||
jid = g_string_append(jid, args[1]);
|
jid = g_string_append(jid, args[1]);
|
||||||
} else {
|
} else {
|
||||||
Jid* jidp = jid_create(connection_get_fulljid());
|
auto_jid Jid* jidp = jid_create(connection_get_fulljid());
|
||||||
jid = g_string_append(jid, jidp->domainpart);
|
jid = g_string_append(jid, jidp->domainpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (g_strcmp0(args[0], "info") == 0) {
|
if (g_strcmp0(args[0], "info") == 0) {
|
||||||
@ -5089,13 +5074,12 @@ cmd_lastactivity(ProfWin* window, const char* const command, gchar** args)
|
|||||||
|
|
||||||
if ((g_strcmp0(args[0], "get") == 0)) {
|
if ((g_strcmp0(args[0], "get") == 0)) {
|
||||||
if (args[1] == NULL) {
|
if (args[1] == NULL) {
|
||||||
Jid* jidp = jid_create(connection_get_fulljid());
|
auto_jid Jid* jidp = jid_create(connection_get_fulljid());
|
||||||
GString* jid = g_string_new(jidp->domainpart);
|
GString* jid = g_string_new(jidp->domainpart);
|
||||||
|
|
||||||
iq_last_activity_request(jid->str);
|
iq_last_activity_request(jid->str);
|
||||||
|
|
||||||
g_string_free(jid, TRUE);
|
g_string_free(jid, TRUE);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
} else {
|
} else {
|
||||||
@ -10057,10 +10041,9 @@ cmd_vcard_get(ProfWin* window, const char* const command, gchar** args)
|
|||||||
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
||||||
// non-anon muc: get the user's jid and send vcard request to them
|
// non-anon muc: get the user's jid and send vcard request to them
|
||||||
Occupant* occupant = muc_roster_item(mucwin->roomjid, user);
|
Occupant* occupant = muc_roster_item(mucwin->roomjid, user);
|
||||||
Jid* jid_occupant = jid_create(occupant->jid);
|
auto_jid Jid* jid_occupant = jid_create(occupant->jid);
|
||||||
|
|
||||||
vcard_print(ctx, window, jid_occupant->barejid);
|
vcard_print(ctx, window, jid_occupant->barejid);
|
||||||
jid_destroy(jid_occupant);
|
|
||||||
} else {
|
} else {
|
||||||
// anon muc: send the vcard request through the MUC's server
|
// anon muc: send the vcard request through the MUC's server
|
||||||
GString* full_jid = g_string_new(mucwin->roomjid);
|
GString* full_jid = g_string_new(mucwin->roomjid);
|
||||||
@ -10126,10 +10109,9 @@ cmd_vcard_photo(ProfWin* window, const char* const command, gchar** args)
|
|||||||
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
if (muc_anonymity_type(mucwin->roomjid) == MUC_ANONYMITY_TYPE_NONANONYMOUS) {
|
||||||
// non-anon muc: get the user's jid and send vcard request to them
|
// non-anon muc: get the user's jid and send vcard request to them
|
||||||
Occupant* occupant = muc_roster_item(mucwin->roomjid, user);
|
Occupant* occupant = muc_roster_item(mucwin->roomjid, user);
|
||||||
Jid* jid_occupant = jid_create(occupant->jid);
|
auto_jid Jid* jid_occupant = jid_create(occupant->jid);
|
||||||
|
|
||||||
jid = g_strdup(jid_occupant->barejid);
|
jid = g_strdup(jid_occupant->barejid);
|
||||||
jid_destroy(jid_occupant);
|
|
||||||
} else {
|
} else {
|
||||||
// anon muc: send the vcard request through the MUC's server
|
// anon muc: send the vcard request through the MUC's server
|
||||||
jid = g_strdup_printf("%s/%s", mucwin->roomjid, user);
|
jid = g_strdup_printf("%s/%s", mucwin->roomjid, user);
|
||||||
|
@ -108,9 +108,8 @@ account_new(gchar* name, gchar* jid, gchar* password, gchar* eval_password, gboo
|
|||||||
new_account->muc_service = muc_service;
|
new_account->muc_service = muc_service;
|
||||||
|
|
||||||
if (muc_nick == NULL) {
|
if (muc_nick == NULL) {
|
||||||
Jid* jidp = jid_create(new_account->jid);
|
auto_jid Jid* jidp = jid_create(new_account->jid);
|
||||||
new_account->muc_nick = strdup(jidp->domainpart);
|
new_account->muc_nick = strdup(jidp->domainpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
new_account->muc_nick = muc_nick;
|
new_account->muc_nick = muc_nick;
|
||||||
}
|
}
|
||||||
|
@ -128,7 +128,7 @@ accounts_add(const char* account_name, const char* altdomain, const int port, co
|
|||||||
// set account name and resource
|
// set account name and resource
|
||||||
const char* barejid = account_name;
|
const char* barejid = account_name;
|
||||||
auto_gchar gchar* resource = jid_random_resource();
|
auto_gchar gchar* resource = jid_random_resource();
|
||||||
Jid* jid = jid_create(account_name);
|
auto_jid Jid* jid = jid_create(account_name);
|
||||||
if (jid) {
|
if (jid) {
|
||||||
barejid = jid->barejid;
|
barejid = jid->barejid;
|
||||||
if (jid->resourcepart) {
|
if (jid->resourcepart) {
|
||||||
@ -137,7 +137,6 @@ accounts_add(const char* account_name, const char* altdomain, const int port, co
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (g_key_file_has_group(accounts, account_name)) {
|
if (g_key_file_has_group(accounts, account_name)) {
|
||||||
jid_destroy(jid);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,7 +156,7 @@ accounts_add(const char* account_name, const char* altdomain, const int port, co
|
|||||||
g_key_file_set_string(accounts, account_name, "auth.policy", auth_policy);
|
g_key_file_set_string(accounts, account_name, "auth.policy", auth_policy);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create(barejid);
|
auto_jid Jid* jidp = jid_create(barejid);
|
||||||
|
|
||||||
if (jidp->localpart == NULL) {
|
if (jidp->localpart == NULL) {
|
||||||
g_key_file_set_string(accounts, account_name, "muc.nick", jidp->domainpart);
|
g_key_file_set_string(accounts, account_name, "muc.nick", jidp->domainpart);
|
||||||
@ -165,8 +164,6 @@ accounts_add(const char* account_name, const char* altdomain, const int port, co
|
|||||||
g_key_file_set_string(accounts, account_name, "muc.nick", jidp->localpart);
|
g_key_file_set_string(accounts, account_name, "muc.nick", jidp->localpart);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
g_key_file_set_string(accounts, account_name, "presence.last", "online");
|
g_key_file_set_string(accounts, account_name, "presence.last", "online");
|
||||||
g_key_file_set_string(accounts, account_name, "presence.login", "online");
|
g_key_file_set_string(accounts, account_name, "presence.login", "online");
|
||||||
g_key_file_set_integer(accounts, account_name, "priority.online", 0);
|
g_key_file_set_integer(accounts, account_name, "priority.online", 0);
|
||||||
@ -178,8 +175,6 @@ accounts_add(const char* account_name, const char* altdomain, const int port, co
|
|||||||
_save_accounts();
|
_save_accounts();
|
||||||
autocomplete_add(all_ac, account_name);
|
autocomplete_add(all_ac, account_name);
|
||||||
autocomplete_add(enabled_ac, account_name);
|
autocomplete_add(enabled_ac, account_name);
|
||||||
|
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -459,7 +454,7 @@ accounts_account_exists(const char* const account_name)
|
|||||||
void
|
void
|
||||||
accounts_set_jid(const char* const account_name, const char* const value)
|
accounts_set_jid(const char* const account_name, const char* const value)
|
||||||
{
|
{
|
||||||
Jid* jid = jid_create(value);
|
auto_jid Jid* jid = jid_create(value);
|
||||||
if (jid) {
|
if (jid) {
|
||||||
if (accounts_account_exists(account_name)) {
|
if (accounts_account_exists(account_name)) {
|
||||||
g_key_file_set_string(accounts, account_name, "jid", jid->barejid);
|
g_key_file_set_string(accounts, account_name, "jid", jid->barejid);
|
||||||
@ -475,8 +470,6 @@ accounts_set_jid(const char* const account_name, const char* const value)
|
|||||||
|
|
||||||
_save_accounts();
|
_save_accounts();
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,11 +153,9 @@ log_database_add_incoming(ProfMessage* message)
|
|||||||
if (message->to_jid) {
|
if (message->to_jid) {
|
||||||
_add_to_db(message, NULL, message->from_jid, message->to_jid);
|
_add_to_db(message, NULL, message->from_jid, message->to_jid);
|
||||||
} else {
|
} else {
|
||||||
Jid* myjid = jid_create(connection_get_fulljid());
|
auto_jid Jid* myjid = jid_create(connection_get_fulljid());
|
||||||
|
|
||||||
_add_to_db(message, NULL, message->from_jid, myjid);
|
_add_to_db(message, NULL, message->from_jid, myjid);
|
||||||
|
|
||||||
jid_destroy(myjid);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -173,11 +171,10 @@ _log_database_add_outgoing(char* type, const char* const id, const char* const b
|
|||||||
msg->timestamp = g_date_time_new_now_local(); // TODO: get from outside. best to have whole ProfMessage from outside
|
msg->timestamp = g_date_time_new_now_local(); // TODO: get from outside. best to have whole ProfMessage from outside
|
||||||
msg->enc = enc;
|
msg->enc = enc;
|
||||||
|
|
||||||
Jid* myjid = jid_create(connection_get_fulljid());
|
auto_jid Jid* myjid = jid_create(connection_get_fulljid());
|
||||||
|
|
||||||
_add_to_db(msg, type, myjid, msg->from_jid); // TODO: myjid now in profmessage
|
_add_to_db(msg, type, myjid, msg->from_jid); // TODO: myjid now in profmessage
|
||||||
|
|
||||||
jid_destroy(myjid);
|
|
||||||
message_free(msg);
|
message_free(msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -206,7 +203,7 @@ log_database_get_limits_info(const gchar* const contact_barejid, gboolean is_las
|
|||||||
sqlite3_stmt* stmt = NULL;
|
sqlite3_stmt* stmt = NULL;
|
||||||
gchar* query;
|
gchar* query;
|
||||||
const char* jid = connection_get_fulljid();
|
const char* jid = connection_get_fulljid();
|
||||||
Jid* myjid = jid_create(jid);
|
auto_jid Jid* myjid = jid_create(jid);
|
||||||
if (!myjid)
|
if (!myjid)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -221,8 +218,6 @@ log_database_get_limits_info(const gchar* const contact_barejid, gboolean is_las
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(myjid);
|
|
||||||
|
|
||||||
int rc = sqlite3_prepare_v2(g_chatlog_database, query, -1, &stmt, NULL);
|
int rc = sqlite3_prepare_v2(g_chatlog_database, query, -1, &stmt, NULL);
|
||||||
if (rc != SQLITE_OK) {
|
if (rc != SQLITE_OK) {
|
||||||
log_error("log_database_get_last_info(): unknown SQLite error");
|
log_error("log_database_get_last_info(): unknown SQLite error");
|
||||||
@ -252,7 +247,7 @@ log_database_get_previous_chat(const gchar* const contact_barejid, const char* s
|
|||||||
{
|
{
|
||||||
sqlite3_stmt* stmt = NULL;
|
sqlite3_stmt* stmt = NULL;
|
||||||
const char* jid = connection_get_fulljid();
|
const char* jid = connection_get_fulljid();
|
||||||
Jid* myjid = jid_create(jid);
|
auto_jid Jid* myjid = jid_create(jid);
|
||||||
if (!myjid)
|
if (!myjid)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
@ -270,8 +265,6 @@ log_database_get_previous_chat(const gchar* const contact_barejid, const char* s
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(myjid);
|
|
||||||
|
|
||||||
int rc = sqlite3_prepare_v2(g_chatlog_database, query, -1, &stmt, NULL);
|
int rc = sqlite3_prepare_v2(g_chatlog_database, query, -1, &stmt, NULL);
|
||||||
if (rc != SQLITE_OK) {
|
if (rc != SQLITE_OK) {
|
||||||
log_error("log_database_get_previous_chat(): unknown SQLite error");
|
log_error("log_database_get_previous_chat(): unknown SQLite error");
|
||||||
|
@ -395,10 +395,9 @@ sv_ev_room_message(ProfMessage* message)
|
|||||||
mucwin->last_msg_timestamp = g_date_time_new_now_local();
|
mucwin->last_msg_timestamp = g_date_time_new_now_local();
|
||||||
|
|
||||||
if (prefs_do_room_notify(is_current, mucwin->roomjid, mynick, message->from_jid->resourcepart, message->plain, mention, triggers != NULL)) {
|
if (prefs_do_room_notify(is_current, mucwin->roomjid, mynick, message->from_jid->resourcepart, message->plain, mention, triggers != NULL)) {
|
||||||
Jid* jidp = jid_create(mucwin->roomjid);
|
auto_jid Jid* jidp = jid_create(mucwin->roomjid);
|
||||||
if (jidp) {
|
if (jidp) {
|
||||||
notify_room_message(message->from_jid->resourcepart, jidp->localpart, num, message->plain);
|
notify_room_message(message->from_jid->resourcepart, jidp->localpart, num, message->plain);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -902,9 +901,8 @@ sv_ev_room_occupant_offline(const char* const room, const char* const nick,
|
|||||||
mucwin_occupant_offline(mucwin, nick);
|
mucwin_occupant_offline(mucwin, nick);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
||||||
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
if (privwin != NULL) {
|
if (privwin != NULL) {
|
||||||
privwin_occupant_offline(privwin);
|
privwin_occupant_offline(privwin);
|
||||||
}
|
}
|
||||||
@ -923,9 +921,8 @@ sv_ev_room_occupent_kicked(const char* const room, const char* const nick, const
|
|||||||
mucwin_occupant_kicked(mucwin, nick, actor, reason);
|
mucwin_occupant_kicked(mucwin, nick, actor, reason);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
||||||
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
if (privwin != NULL) {
|
if (privwin != NULL) {
|
||||||
privwin_occupant_kicked(privwin, actor, reason);
|
privwin_occupant_kicked(privwin, actor, reason);
|
||||||
}
|
}
|
||||||
@ -944,13 +941,11 @@ sv_ev_room_occupent_banned(const char* const room, const char* const nick, const
|
|||||||
mucwin_occupant_banned(mucwin, nick, actor, reason);
|
mucwin_occupant_banned(mucwin, nick, actor, reason);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(room, nick);
|
||||||
|
|
||||||
muc_members_remove(room, jidp->fulljid);
|
muc_members_remove(room, jidp->fulljid);
|
||||||
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (privwin != NULL) {
|
if (privwin != NULL) {
|
||||||
privwin_occupant_banned(privwin, actor, reason);
|
privwin_occupant_banned(privwin, actor, reason);
|
||||||
}
|
}
|
||||||
@ -1003,11 +998,10 @@ sv_ev_muc_self_online(const char* const room, const char* const nick, gboolean c
|
|||||||
ui_room_join(room, TRUE);
|
ui_room_join(room, TRUE);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create(room);
|
auto_jid Jid* jidp = jid_create(room);
|
||||||
if (jidp->domainpart) {
|
if (jidp->domainpart) {
|
||||||
muc_confserver_add(jidp->domainpart);
|
muc_confserver_add(jidp->domainpart);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
iq_room_info_request(room, FALSE);
|
iq_room_info_request(room, FALSE);
|
||||||
|
|
||||||
@ -1122,9 +1116,8 @@ sv_ev_muc_occupant_online(const char* const room, const char* const nick, const
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (mucwin) {
|
if (mucwin) {
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(mucwin->roomjid, nick);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(mucwin->roomjid, nick);
|
||||||
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
ProfPrivateWin* privwin = wins_get_private(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
if (privwin) {
|
if (privwin) {
|
||||||
privwin_occupant_online(privwin);
|
privwin_occupant_online(privwin);
|
||||||
}
|
}
|
||||||
@ -1230,7 +1223,7 @@ sv_ev_certfail(const char* const errormsg, const TLSCertificate* cert)
|
|||||||
void
|
void
|
||||||
sv_ev_lastactivity_response(const char* const from, const int seconds, const char* const msg)
|
sv_ev_lastactivity_response(const char* const from, const int seconds, const char* const msg)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(from);
|
auto_jid Jid* jidp = jid_create(from);
|
||||||
|
|
||||||
if (!jidp) {
|
if (!jidp) {
|
||||||
return;
|
return;
|
||||||
@ -1292,7 +1285,6 @@ sv_ev_lastactivity_response(const char* const from, const int seconds, const cha
|
|||||||
|
|
||||||
g_date_time_unref(now);
|
g_date_time_unref(now);
|
||||||
g_date_time_unref(active);
|
g_date_time_unref(active);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -447,9 +447,8 @@ omemo_start_muc_sessions(const char* const roomjid)
|
|||||||
GList* members = muc_members(roomjid);
|
GList* members = muc_members(roomjid);
|
||||||
GList* iter;
|
GList* iter;
|
||||||
for (iter = members; iter != NULL; iter = iter->next) {
|
for (iter = members; iter != NULL; iter = iter->next) {
|
||||||
Jid* jid = jid_create(iter->data);
|
auto_jid Jid* jid = jid_create(iter->data);
|
||||||
omemo_start_session(jid->barejid);
|
omemo_start_session(jid->barejid);
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
g_list_free(members);
|
g_list_free(members);
|
||||||
}
|
}
|
||||||
@ -547,7 +546,7 @@ void
|
|||||||
omemo_set_device_list(const char* const from, GList* device_list)
|
omemo_set_device_list(const char* const from, GList* device_list)
|
||||||
{
|
{
|
||||||
log_debug("[OMEMO] Setting device list for %s", STR_MAYBE_NULL(from));
|
log_debug("[OMEMO] Setting device list for %s", STR_MAYBE_NULL(from));
|
||||||
Jid* jid;
|
auto_jid Jid* jid;
|
||||||
if (from) {
|
if (from) {
|
||||||
jid = jid_create(from);
|
jid = jid_create(from);
|
||||||
} else {
|
} else {
|
||||||
@ -595,7 +594,6 @@ omemo_set_device_list(const char* const from, GList* device_list)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
GKeyFile*
|
GKeyFile*
|
||||||
@ -754,7 +752,7 @@ omemo_on_message_send(ProfWin* win, const char* const message, gboolean request_
|
|||||||
{
|
{
|
||||||
char* id = NULL;
|
char* id = NULL;
|
||||||
int res;
|
int res;
|
||||||
Jid* jid = jid_create(connection_get_fulljid());
|
auto_jid Jid* jid = jid_create(connection_get_fulljid());
|
||||||
GList* keys = NULL;
|
GList* keys = NULL;
|
||||||
|
|
||||||
unsigned char* key;
|
unsigned char* key;
|
||||||
@ -790,9 +788,8 @@ omemo_on_message_send(ProfWin* win, const char* const message, gboolean request_
|
|||||||
GList* members = muc_members(mucwin->roomjid);
|
GList* members = muc_members(mucwin->roomjid);
|
||||||
GList* iter;
|
GList* iter;
|
||||||
for (iter = members; iter != NULL; iter = iter->next) {
|
for (iter = members; iter != NULL; iter = iter->next) {
|
||||||
Jid* jid = jid_create(iter->data);
|
auto_jid Jid* jidp = jid_create(iter->data);
|
||||||
recipients = g_list_append(recipients, strdup(jid->barejid));
|
recipients = g_list_append(recipients, strdup(jidp->barejid));
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
g_list_free(members);
|
g_list_free(members);
|
||||||
} else {
|
} else {
|
||||||
@ -932,7 +929,6 @@ omemo_on_message_send(ProfWin* win, const char* const message, gboolean request_
|
|||||||
}
|
}
|
||||||
|
|
||||||
out:
|
out:
|
||||||
jid_destroy(jid);
|
|
||||||
g_list_free_full(keys, (GDestroyNotify)omemo_key_free);
|
g_list_free_full(keys, (GDestroyNotify)omemo_key_free);
|
||||||
free(ciphertext);
|
free(ciphertext);
|
||||||
gcry_free(key);
|
gcry_free(key);
|
||||||
@ -949,11 +945,11 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
const unsigned char* const payload, size_t payload_len, gboolean muc, gboolean* trusted)
|
const unsigned char* const payload, size_t payload_len, gboolean muc, gboolean* trusted)
|
||||||
{
|
{
|
||||||
unsigned char* plaintext = NULL;
|
unsigned char* plaintext = NULL;
|
||||||
Jid* sender = NULL;
|
auto_jid Jid* sender = NULL;
|
||||||
Jid* from = jid_create(from_jid);
|
auto_jid Jid* from = jid_create(from_jid);
|
||||||
if (!from) {
|
if (!from) {
|
||||||
log_error("[OMEMO][RECV] Invalid jid %s", from_jid);
|
log_error("[OMEMO][RECV] Invalid jid %s", from_jid);
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
int res;
|
int res;
|
||||||
@ -968,7 +964,7 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
|
|
||||||
if (!key) {
|
if (!key) {
|
||||||
log_warning("[OMEMO][RECV] received a message with no corresponding key");
|
log_warning("[OMEMO][RECV] received a message with no corresponding key");
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (muc) {
|
if (muc) {
|
||||||
@ -984,7 +980,7 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
g_list_free(roster);
|
g_list_free(roster);
|
||||||
if (!sender) {
|
if (!sender) {
|
||||||
log_warning("[OMEMO][RECV] cannot find MUC message sender fulljid");
|
log_warning("[OMEMO][RECV] cannot find MUC message sender fulljid");
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
sender = jid_create(from->barejid);
|
sender = jid_create(from->barejid);
|
||||||
@ -1001,7 +997,7 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
res = session_cipher_create(&cipher, omemo_ctx.store, &address, omemo_ctx.signal);
|
res = session_cipher_create(&cipher, omemo_ctx.store, &address, omemo_ctx.signal);
|
||||||
if (res != 0) {
|
if (res != 0) {
|
||||||
log_error("[OMEMO][RECV] cannot create session cipher");
|
log_error("[OMEMO][RECV] cannot create session cipher");
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key->prekey) {
|
if (key->prekey) {
|
||||||
@ -1060,13 +1056,13 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
session_cipher_free(cipher);
|
session_cipher_free(cipher);
|
||||||
if (res != 0) {
|
if (res != 0) {
|
||||||
log_error("[OMEMO][RECV] cannot decrypt message key");
|
log_error("[OMEMO][RECV] cannot decrypt message key");
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (signal_buffer_len(plaintext_key) != AES128_GCM_KEY_LENGTH + AES128_GCM_TAG_LENGTH) {
|
if (signal_buffer_len(plaintext_key) != AES128_GCM_KEY_LENGTH + AES128_GCM_TAG_LENGTH) {
|
||||||
log_error("[OMEMO][RECV] invalid key length");
|
log_error("[OMEMO][RECV] invalid key length");
|
||||||
signal_buffer_free(plaintext_key);
|
signal_buffer_free(plaintext_key);
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t plaintext_len = payload_len;
|
size_t plaintext_len = payload_len;
|
||||||
@ -1078,15 +1074,11 @@ omemo_on_message_recv(const char* const from_jid, uint32_t sid,
|
|||||||
if (res != 0) {
|
if (res != 0) {
|
||||||
log_error("[OMEMO][RECV] cannot decrypt message: %s", gcry_strerror(res));
|
log_error("[OMEMO][RECV] cannot decrypt message: %s", gcry_strerror(res));
|
||||||
free(plaintext);
|
free(plaintext);
|
||||||
plaintext = NULL;
|
return NULL;
|
||||||
goto out;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
plaintext[plaintext_len] = '\0';
|
plaintext[plaintext_len] = '\0';
|
||||||
|
|
||||||
out:
|
|
||||||
jid_destroy(from);
|
|
||||||
jid_destroy(sender);
|
|
||||||
return (char*)plaintext;
|
return (char*)plaintext;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -660,7 +660,7 @@ plugins_on_room_history_message(const char* const barejid, const char* const nic
|
|||||||
char*
|
char*
|
||||||
plugins_pre_priv_message_display(const char* const fulljid, const char* message)
|
plugins_pre_priv_message_display(const char* const fulljid, const char* message)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(fulljid);
|
auto_jid Jid* jidp = jid_create(fulljid);
|
||||||
char* new_message = NULL;
|
char* new_message = NULL;
|
||||||
char* curr_message = strdup(message);
|
char* curr_message = strdup(message);
|
||||||
|
|
||||||
@ -677,15 +677,13 @@ plugins_pre_priv_message_display(const char* const fulljid, const char* message)
|
|||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
g_list_free(values);
|
g_list_free(values);
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
return curr_message;
|
return curr_message;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
plugins_post_priv_message_display(const char* const fulljid, const char* message)
|
plugins_post_priv_message_display(const char* const fulljid, const char* message)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(fulljid);
|
auto_jid Jid* jidp = jid_create(fulljid);
|
||||||
|
|
||||||
GList* values = g_hash_table_get_values(plugins);
|
GList* values = g_hash_table_get_values(plugins);
|
||||||
GList* curr = values;
|
GList* curr = values;
|
||||||
@ -695,14 +693,12 @@ plugins_post_priv_message_display(const char* const fulljid, const char* message
|
|||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
g_list_free(values);
|
g_list_free(values);
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
char*
|
char*
|
||||||
plugins_pre_priv_message_send(const char* const fulljid, const char* const message)
|
plugins_pre_priv_message_send(const char* const fulljid, const char* const message)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(fulljid);
|
auto_jid Jid* jidp = jid_create(fulljid);
|
||||||
char* new_message = NULL;
|
char* new_message = NULL;
|
||||||
char* curr_message = strdup(message);
|
char* curr_message = strdup(message);
|
||||||
|
|
||||||
@ -719,7 +715,6 @@ plugins_pre_priv_message_send(const char* const fulljid, const char* const messa
|
|||||||
} else {
|
} else {
|
||||||
free(curr_message);
|
free(curr_message);
|
||||||
g_list_free(values);
|
g_list_free(values);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -728,14 +723,13 @@ plugins_pre_priv_message_send(const char* const fulljid, const char* const messa
|
|||||||
}
|
}
|
||||||
g_list_free(values);
|
g_list_free(values);
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
return curr_message;
|
return curr_message;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
plugins_post_priv_message_send(const char* const fulljid, const char* const message)
|
plugins_post_priv_message_send(const char* const fulljid, const char* const message)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(fulljid);
|
auto_jid Jid* jidp = jid_create(fulljid);
|
||||||
|
|
||||||
GList* values = g_hash_table_get_values(plugins);
|
GList* values = g_hash_table_get_values(plugins);
|
||||||
GList* curr = values;
|
GList* curr = values;
|
||||||
@ -744,9 +738,8 @@ plugins_post_priv_message_send(const char* const fulljid, const char* const mess
|
|||||||
plugin->post_priv_message_send(plugin, jidp->barejid, jidp->resourcepart, message);
|
plugin->post_priv_message_send(plugin, jidp->barejid, jidp->resourcepart, message);
|
||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
g_list_free(values);
|
|
||||||
|
|
||||||
jid_destroy(jidp);
|
g_list_free(values);
|
||||||
}
|
}
|
||||||
|
|
||||||
char*
|
char*
|
||||||
|
@ -1141,9 +1141,8 @@ cons_show_account(ProfAccount* account)
|
|||||||
win_append(console, presence_colour, ", \"%s\"", resource->status);
|
win_append(console, presence_colour, ", \"%s\"", resource->status);
|
||||||
}
|
}
|
||||||
win_appendln(console, THEME_DEFAULT, "");
|
win_appendln(console, THEME_DEFAULT, "");
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(account->jid, resource->name);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(account->jid, resource->name);
|
||||||
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (caps) {
|
if (caps) {
|
||||||
// show identity
|
// show identity
|
||||||
|
@ -1045,7 +1045,6 @@ ui_contact_offline(char* barejid, char* resource, char* status)
|
|||||||
{
|
{
|
||||||
auto_gchar gchar* show_console = prefs_get_string(PREF_STATUSES_CONSOLE);
|
auto_gchar gchar* show_console = prefs_get_string(PREF_STATUSES_CONSOLE);
|
||||||
auto_gchar gchar* show_chat_win = prefs_get_string(PREF_STATUSES_CHAT);
|
auto_gchar gchar* show_chat_win = prefs_get_string(PREF_STATUSES_CHAT);
|
||||||
Jid* jid = jid_create_from_bare_and_resource(barejid, resource);
|
|
||||||
PContact contact = roster_get_contact(barejid);
|
PContact contact = roster_get_contact(barejid);
|
||||||
if (p_contact_subscription(contact)) {
|
if (p_contact_subscription(contact)) {
|
||||||
if (strcmp(p_contact_subscription(contact), "none") != 0) {
|
if (strcmp(p_contact_subscription(contact), "none") != 0) {
|
||||||
@ -1080,8 +1079,6 @@ ui_contact_offline(char* barejid, char* resource, char* status)
|
|||||||
if (chatwin && chatwin->resource_override && (g_strcmp0(resource, chatwin->resource_override) == 0)) {
|
if (chatwin && chatwin->resource_override && (g_strcmp0(resource, chatwin->resource_override) == 0)) {
|
||||||
FREE_SET_NULL(chatwin->resource_override);
|
FREE_SET_NULL(chatwin->resource_override);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -1261,13 +1258,12 @@ void
|
|||||||
ui_show_software_version(const char* const jid, const char* const presence,
|
ui_show_software_version(const char* const jid, const char* const presence,
|
||||||
const char* const name, const char* const version, const char* const os)
|
const char* const name, const char* const version, const char* const os)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
ProfWin* window = NULL;
|
ProfWin* window = NULL;
|
||||||
ProfWin* chatwin = (ProfWin*)wins_get_chat(jidp->barejid);
|
ProfWin* chatwin = (ProfWin*)wins_get_chat(jidp->barejid);
|
||||||
ProfWin* mucwin = (ProfWin*)wins_get_muc(jidp->barejid);
|
ProfWin* mucwin = (ProfWin*)wins_get_muc(jidp->barejid);
|
||||||
ProfWin* privwin = (ProfWin*)wins_get_private(jidp->fulljid);
|
ProfWin* privwin = (ProfWin*)wins_get_private(jidp->fulljid);
|
||||||
ProfWin* console = wins_get_console();
|
ProfWin* console = wins_get_console();
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (chatwin) {
|
if (chatwin) {
|
||||||
if (wins_is_current(chatwin)) {
|
if (wins_is_current(chatwin)) {
|
||||||
|
@ -85,9 +85,8 @@ _occuptantswin_occupant(ProfLayoutSplit* layout, GList* item, gboolean showjid,
|
|||||||
gboolean wrap = prefs_get_boolean(PREF_OCCUPANTS_WRAP);
|
gboolean wrap = prefs_get_boolean(PREF_OCCUPANTS_WRAP);
|
||||||
|
|
||||||
if (isoffline) {
|
if (isoffline) {
|
||||||
Jid* jid = jid_create(item->data);
|
auto_jid Jid* jid = jid_create(item->data);
|
||||||
g_string_append(msg, jid->barejid);
|
g_string_append(msg, jid->barejid);
|
||||||
jid_destroy(jid);
|
|
||||||
} else {
|
} else {
|
||||||
g_string_append(msg, occupant->nick);
|
g_string_append(msg, occupant->nick);
|
||||||
}
|
}
|
||||||
@ -208,7 +207,7 @@ occupantswin_occupants(const char* const roomjid)
|
|||||||
g_string_free(role, TRUE);
|
g_string_free(role, TRUE);
|
||||||
roster_curr = members;
|
roster_curr = members;
|
||||||
while (roster_curr) {
|
while (roster_curr) {
|
||||||
Jid* jid = jid_create(roster_curr->data);
|
auto_jid Jid* jid = jid_create(roster_curr->data);
|
||||||
gboolean found = false;
|
gboolean found = false;
|
||||||
GList* iter = online_occupants;
|
GList* iter = online_occupants;
|
||||||
for (; iter != NULL; iter = iter->next) {
|
for (; iter != NULL; iter = iter->next) {
|
||||||
@ -223,7 +222,6 @@ occupantswin_occupants(const char* const roomjid)
|
|||||||
offline_occupants = g_list_append(offline_occupants, jid->barejid);
|
offline_occupants = g_list_append(offline_occupants, jid->barejid);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jid);
|
|
||||||
roster_curr = g_list_next(roster_curr);
|
roster_curr = g_list_next(roster_curr);
|
||||||
}
|
}
|
||||||
g_list_free(members);
|
g_list_free(members);
|
||||||
|
@ -59,7 +59,7 @@ privwin_incoming_msg(ProfPrivateWin* privatewin, ProfMessage* message)
|
|||||||
ProfWin* window = (ProfWin*)privatewin;
|
ProfWin* window = (ProfWin*)privatewin;
|
||||||
int num = wins_get_num(window);
|
int num = wins_get_num(window);
|
||||||
|
|
||||||
Jid* jidp = jid_create(privatewin->fulljid);
|
auto_jid Jid* jidp = jid_create(privatewin->fulljid);
|
||||||
if (jidp == NULL) {
|
if (jidp == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -97,8 +97,6 @@ privwin_incoming_msg(ProfPrivateWin* privatewin, ProfMessage* message)
|
|||||||
if (notify) {
|
if (notify) {
|
||||||
notify_message(jidp->resourcepart, num, message->plain);
|
notify_message(jidp->resourcepart, num, message->plain);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -133,9 +131,8 @@ privwin_occupant_offline(ProfPrivateWin* privwin)
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->occupant_offline = TRUE;
|
privwin->occupant_offline = TRUE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_OFFLINE, "-", "<- %s has left the room.", jidp->resourcepart);
|
win_println((ProfWin*)privwin, THEME_OFFLINE, "-", "<- %s has left the room.", jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -144,9 +141,8 @@ privwin_occupant_kicked(ProfPrivateWin* privwin, const char* const actor, const
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->occupant_offline = TRUE;
|
privwin->occupant_offline = TRUE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
GString* message = g_string_new(jidp->resourcepart);
|
GString* message = g_string_new(jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
g_string_append(message, " has been kicked from the room");
|
g_string_append(message, " has been kicked from the room");
|
||||||
if (actor) {
|
if (actor) {
|
||||||
g_string_append(message, " by ");
|
g_string_append(message, " by ");
|
||||||
@ -167,9 +163,8 @@ privwin_occupant_banned(ProfPrivateWin* privwin, const char* const actor, const
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->occupant_offline = TRUE;
|
privwin->occupant_offline = TRUE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
GString* message = g_string_new(jidp->resourcepart);
|
GString* message = g_string_new(jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
g_string_append(message, " has been banned from the room");
|
g_string_append(message, " has been banned from the room");
|
||||||
if (actor) {
|
if (actor) {
|
||||||
g_string_append(message, " by ");
|
g_string_append(message, " by ");
|
||||||
@ -190,9 +185,8 @@ privwin_occupant_online(ProfPrivateWin* privwin)
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->occupant_offline = FALSE;
|
privwin->occupant_offline = FALSE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_ONLINE, "-", "-- %s has joined the room.", jidp->resourcepart);
|
win_println((ProfWin*)privwin, THEME_ONLINE, "-", "-- %s has joined the room.", jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -201,9 +195,8 @@ privwin_room_destroyed(ProfPrivateWin* privwin)
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->room_left = TRUE;
|
privwin->room_left = TRUE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- %s has been destroyed.", jidp->barejid);
|
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- %s has been destroyed.", jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -212,9 +205,8 @@ privwin_room_joined(ProfPrivateWin* privwin)
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->room_left = FALSE;
|
privwin->room_left = FALSE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- You have joined %s.", jidp->barejid);
|
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- You have joined %s.", jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -223,9 +215,8 @@ privwin_room_left(ProfPrivateWin* privwin)
|
|||||||
assert(privwin != NULL);
|
assert(privwin != NULL);
|
||||||
|
|
||||||
privwin->room_left = TRUE;
|
privwin->room_left = TRUE;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- You have left %s.", jidp->barejid);
|
win_println((ProfWin*)privwin, THEME_OFFLINE, "!", "-- You have left %s.", jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -235,9 +226,8 @@ privwin_room_kicked(ProfPrivateWin* privwin, const char* const actor, const char
|
|||||||
|
|
||||||
privwin->room_left = TRUE;
|
privwin->room_left = TRUE;
|
||||||
GString* message = g_string_new("Kicked from ");
|
GString* message = g_string_new("Kicked from ");
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
g_string_append(message, jidp->barejid);
|
g_string_append(message, jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
if (actor) {
|
if (actor) {
|
||||||
g_string_append(message, " by ");
|
g_string_append(message, " by ");
|
||||||
g_string_append(message, actor);
|
g_string_append(message, actor);
|
||||||
@ -258,9 +248,8 @@ privwin_room_banned(ProfPrivateWin* privwin, const char* const actor, const char
|
|||||||
|
|
||||||
privwin->room_left = TRUE;
|
privwin->room_left = TRUE;
|
||||||
GString* message = g_string_new("Banned from ");
|
GString* message = g_string_new("Banned from ");
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
g_string_append(message, jidp->barejid);
|
g_string_append(message, jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
if (actor) {
|
if (actor) {
|
||||||
g_string_append(message, " by ");
|
g_string_append(message, " by ");
|
||||||
g_string_append(message, actor);
|
g_string_append(message, actor);
|
||||||
|
@ -113,11 +113,10 @@ rosterwin_roster(void)
|
|||||||
GList* curr = privchats;
|
GList* curr = privchats;
|
||||||
while (curr) {
|
while (curr) {
|
||||||
ProfPrivateWin* privwin = curr->data;
|
ProfPrivateWin* privwin = curr->data;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
if (!muc_active(jidp->barejid)) {
|
if (!muc_active(jidp->barejid)) {
|
||||||
orphaned_privchats = g_list_append(orphaned_privchats, privwin);
|
orphaned_privchats = g_list_append(orphaned_privchats, privwin);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -163,11 +162,10 @@ rosterwin_roster(void)
|
|||||||
GList* curr = privchats;
|
GList* curr = privchats;
|
||||||
while (curr) {
|
while (curr) {
|
||||||
ProfPrivateWin* privwin = curr->data;
|
ProfPrivateWin* privwin = curr->data;
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
if (!muc_active(jidp->barejid)) {
|
if (!muc_active(jidp->barejid)) {
|
||||||
orphaned_privchats = g_list_append(orphaned_privchats, privwin);
|
orphaned_privchats = g_list_append(orphaned_privchats, privwin);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -677,13 +675,12 @@ _rosterwin_rooms_by_service(ProfLayoutSplit* layout)
|
|||||||
GList* services = NULL;
|
GList* services = NULL;
|
||||||
while (curr) {
|
while (curr) {
|
||||||
char* roomjid = curr->data;
|
char* roomjid = curr->data;
|
||||||
Jid* jidp = jid_create(roomjid);
|
auto_jid Jid* jidp = jid_create(roomjid);
|
||||||
|
|
||||||
if (!g_list_find_custom(services, jidp->domainpart, (GCompareFunc)g_strcmp0)) {
|
if (!g_list_find_custom(services, jidp->domainpart, (GCompareFunc)g_strcmp0)) {
|
||||||
services = g_list_insert_sorted(services, strdup(jidp->domainpart), (GCompareFunc)g_strcmp0);
|
services = g_list_insert_sorted(services, strdup(jidp->domainpart), (GCompareFunc)g_strcmp0);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -695,13 +692,12 @@ _rosterwin_rooms_by_service(ProfLayoutSplit* layout)
|
|||||||
curr = rooms;
|
curr = rooms;
|
||||||
while (curr) {
|
while (curr) {
|
||||||
char* roomjid = curr->data;
|
char* roomjid = curr->data;
|
||||||
Jid* jidp = jid_create(roomjid);
|
auto_jid Jid* jidp = jid_create(roomjid);
|
||||||
|
|
||||||
if (g_strcmp0(curr_service->data, jidp->domainpart) == 0) {
|
if (g_strcmp0(curr_service->data, jidp->domainpart) == 0) {
|
||||||
filtered_rooms = g_list_append(filtered_rooms, strdup(jidp->barejid));
|
filtered_rooms = g_list_append(filtered_rooms, strdup(jidp->barejid));
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
curr = g_list_next(curr);
|
curr = g_list_next(curr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -754,9 +750,8 @@ _rosterwin_room(ProfLayoutSplit* layout, ProfMucWin* mucwin)
|
|||||||
|
|
||||||
if (g_strcmp0(roombypref, "service") == 0) {
|
if (g_strcmp0(roombypref, "service") == 0) {
|
||||||
if (mucwin->room_name == NULL || (g_strcmp0(use_as_name, "jid") == 0)) {
|
if (mucwin->room_name == NULL || (g_strcmp0(use_as_name, "jid") == 0)) {
|
||||||
Jid* jidp = jid_create(mucwin->roomjid);
|
auto_jid Jid* jidp = jid_create(mucwin->roomjid);
|
||||||
g_string_append(msg, jidp->localpart);
|
g_string_append(msg, jidp->localpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
g_string_append(msg, mucwin->room_name);
|
g_string_append(msg, mucwin->room_name);
|
||||||
}
|
}
|
||||||
@ -770,15 +765,13 @@ _rosterwin_room(ProfLayoutSplit* layout, ProfMucWin* mucwin)
|
|||||||
g_string_append(msg, mucwin->room_name);
|
g_string_append(msg, mucwin->room_name);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
Jid* jidp = jid_create(mucwin->roomjid);
|
auto_jid Jid* jidp = jid_create(mucwin->roomjid);
|
||||||
|
|
||||||
if (mucwin->room_name == NULL || (g_strcmp0(use_as_name, "jid") == 0)) {
|
if (mucwin->room_name == NULL || (g_strcmp0(use_as_name, "jid") == 0)) {
|
||||||
g_string_append(msg, jidp->localpart);
|
g_string_append(msg, jidp->localpart);
|
||||||
} else {
|
} else {
|
||||||
g_string_append(msg, mucwin->room_name);
|
g_string_append(msg, mucwin->room_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -937,9 +930,8 @@ _rosterwin_private_chats(ProfLayoutSplit* layout, GList* orphaned_privchats)
|
|||||||
g_string_append_printf(privmsg, " (%d)", privwin->unread);
|
g_string_append_printf(privmsg, " (%d)", privwin->unread);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create(privwin->fulljid);
|
auto_jid Jid* jidp = jid_create(privwin->fulljid);
|
||||||
Occupant* occupant = muc_roster_item(jidp->barejid, jidp->resourcepart);
|
Occupant* occupant = muc_roster_item(jidp->barejid, jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
const char* presence = "offline";
|
const char* presence = "offline";
|
||||||
if (occupant) {
|
if (occupant) {
|
||||||
|
@ -201,10 +201,9 @@ _create_tab(const int win, win_type_t wintype, char* identifier, gboolean highli
|
|||||||
if (pcontact_name) {
|
if (pcontact_name) {
|
||||||
tab->display_name = strdup(pcontact_name);
|
tab->display_name = strdup(pcontact_name);
|
||||||
} else {
|
} else {
|
||||||
Jid* jidp = jid_create(tab->identifier);
|
auto_jid Jid* jidp = jid_create(tab->identifier);
|
||||||
if (jidp) {
|
if (jidp) {
|
||||||
tab->display_name = jidp->localpart != NULL ? strdup(jidp->localpart) : strdup(jidp->barejid);
|
tab->display_name = jidp->localpart != NULL ? strdup(jidp->localpart) : strdup(jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
tab->display_name = strdup(tab->identifier);
|
tab->display_name = strdup(tab->identifier);
|
||||||
}
|
}
|
||||||
@ -543,15 +542,13 @@ _status_bar_draw_maintext(int pos)
|
|||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
if (g_strcmp0(pref, "user") == 0) {
|
if (g_strcmp0(pref, "user") == 0) {
|
||||||
Jid* jidp = jid_create(statusbar->fulljid);
|
auto_jid Jid* jidp = jid_create(statusbar->fulljid);
|
||||||
mvwprintw(statusbar_win, 0, pos, "%s", jidp->localpart);
|
mvwprintw(statusbar_win, 0, pos, "%s", jidp->localpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
if (g_strcmp0(pref, "barejid") == 0) {
|
if (g_strcmp0(pref, "barejid") == 0) {
|
||||||
Jid* jidp = jid_create(statusbar->fulljid);
|
auto_jid Jid* jidp = jid_create(statusbar->fulljid);
|
||||||
mvwprintw(statusbar_win, 0, pos, "%s", jidp->barejid);
|
mvwprintw(statusbar_win, 0, pos, "%s", jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
return pos;
|
return pos;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,9 +652,8 @@ _display_name(StatusBarTab* tab)
|
|||||||
} else if (tab->window_type == WIN_MUC) {
|
} else if (tab->window_type == WIN_MUC) {
|
||||||
auto_gchar gchar* pref = prefs_get_string(PREF_STATUSBAR_ROOM);
|
auto_gchar gchar* pref = prefs_get_string(PREF_STATUSBAR_ROOM);
|
||||||
if (g_strcmp0("room", pref) == 0) {
|
if (g_strcmp0("room", pref) == 0) {
|
||||||
Jid* jidp = jid_create(tab->identifier);
|
auto_jid Jid* jidp = jid_create(tab->identifier);
|
||||||
char* room = strdup(jidp->localpart);
|
char* room = strdup(jidp->localpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
fullname = room;
|
fullname = room;
|
||||||
} else {
|
} else {
|
||||||
fullname = strdup(tab->identifier);
|
fullname = strdup(tab->identifier);
|
||||||
@ -667,9 +663,8 @@ _display_name(StatusBarTab* tab)
|
|||||||
GString* display_str = g_string_new("");
|
GString* display_str = g_string_new("");
|
||||||
|
|
||||||
if (g_strcmp0("room", pref) == 0) {
|
if (g_strcmp0("room", pref) == 0) {
|
||||||
Jid* jidp = jid_create(tab->identifier);
|
auto_jid Jid* jidp = jid_create(tab->identifier);
|
||||||
g_string_append(display_str, jidp->localpart);
|
g_string_append(display_str, jidp->localpart);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
g_string_append(display_str, tab->identifier);
|
g_string_append(display_str, tab->identifier);
|
||||||
}
|
}
|
||||||
@ -682,11 +677,10 @@ _display_name(StatusBarTab* tab)
|
|||||||
auto_gchar gchar* pref = prefs_get_string(PREF_STATUSBAR_ROOM);
|
auto_gchar gchar* pref = prefs_get_string(PREF_STATUSBAR_ROOM);
|
||||||
if (g_strcmp0("room", pref) == 0) {
|
if (g_strcmp0("room", pref) == 0) {
|
||||||
GString* display_str = g_string_new("");
|
GString* display_str = g_string_new("");
|
||||||
Jid* jidp = jid_create(tab->identifier);
|
auto_jid Jid* jidp = jid_create(tab->identifier);
|
||||||
g_string_append(display_str, jidp->localpart);
|
g_string_append(display_str, jidp->localpart);
|
||||||
g_string_append(display_str, "/");
|
g_string_append(display_str, "/");
|
||||||
g_string_append(display_str, jidp->resourcepart);
|
g_string_append(display_str, jidp->resourcepart);
|
||||||
jid_destroy(jidp);
|
|
||||||
char* result = strdup(display_str->str);
|
char* result = strdup(display_str->str);
|
||||||
g_string_free(display_str, TRUE);
|
g_string_free(display_str, TRUE);
|
||||||
fullname = result;
|
fullname = result;
|
||||||
|
@ -976,9 +976,8 @@ win_show_occupant_info(ProfWin* window, const char* const room, Occupant* occupa
|
|||||||
win_println(window, THEME_DEFAULT, "!", " Affiliation: %s", occupant_affiliation);
|
win_println(window, THEME_DEFAULT, "!", " Affiliation: %s", occupant_affiliation);
|
||||||
win_println(window, THEME_DEFAULT, "!", " Role: %s", occupant_role);
|
win_println(window, THEME_DEFAULT, "!", " Role: %s", occupant_role);
|
||||||
|
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(room, occupant->nick);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(room, occupant->nick);
|
||||||
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (caps) {
|
if (caps) {
|
||||||
// show identity
|
// show identity
|
||||||
@ -1099,9 +1098,8 @@ win_show_info(ProfWin* window, PContact contact)
|
|||||||
}
|
}
|
||||||
win_newline(window);
|
win_newline(window);
|
||||||
|
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(barejid, resource->name);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(barejid, resource->name);
|
||||||
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
EntityCapabilities* caps = caps_lookup(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (caps) {
|
if (caps) {
|
||||||
// show identity
|
// show identity
|
||||||
@ -1496,7 +1494,7 @@ win_print_history(ProfWin* window, const ProfMessage* const message)
|
|||||||
auto_gchar gchar* display_name;
|
auto_gchar gchar* display_name;
|
||||||
int flags = 0;
|
int flags = 0;
|
||||||
const char* jid = connection_get_fulljid();
|
const char* jid = connection_get_fulljid();
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
|
|
||||||
if (g_strcmp0(jidp->barejid, message->from_jid->barejid) == 0) {
|
if (g_strcmp0(jidp->barejid, message->from_jid->barejid) == 0) {
|
||||||
display_name = strdup("me");
|
display_name = strdup("me");
|
||||||
@ -1505,8 +1503,6 @@ win_print_history(ProfWin* window, const ProfMessage* const message)
|
|||||||
flags = NO_ME;
|
flags = NO_ME;
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
buffer_append(window->layout->buffer, "-", 0, message->timestamp, flags, THEME_TEXT_HISTORY, display_name, NULL, message->plain, NULL, NULL);
|
buffer_append(window->layout->buffer, "-", 0, message->timestamp, flags, THEME_TEXT_HISTORY, display_name, NULL, message->plain, NULL, NULL);
|
||||||
wins_add_urls_ac(window, message, FALSE);
|
wins_add_urls_ac(window, message, FALSE);
|
||||||
wins_add_quotes_ac(window, message->plain, FALSE);
|
wins_add_quotes_ac(window, message->plain, FALSE);
|
||||||
@ -1521,10 +1517,10 @@ win_print_old_history(ProfWin* window, const ProfMessage* const message)
|
|||||||
{
|
{
|
||||||
g_date_time_ref(message->timestamp);
|
g_date_time_ref(message->timestamp);
|
||||||
|
|
||||||
auto_gchar gchar* display_name;
|
auto_char char* display_name;
|
||||||
int flags = 0;
|
int flags = 0;
|
||||||
const char* jid = connection_get_fulljid();
|
const char* jid = connection_get_fulljid();
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
|
|
||||||
if (g_strcmp0(jidp->barejid, message->from_jid->barejid) == 0) {
|
if (g_strcmp0(jidp->barejid, message->from_jid->barejid) == 0) {
|
||||||
display_name = strdup("me");
|
display_name = strdup("me");
|
||||||
@ -1533,8 +1529,6 @@ win_print_old_history(ProfWin* window, const ProfMessage* const message)
|
|||||||
flags = NO_ME;
|
flags = NO_ME;
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
buffer_prepend(window->layout->buffer, "-", 0, message->timestamp, flags, THEME_TEXT_HISTORY, display_name, NULL, message->plain, NULL, NULL);
|
buffer_prepend(window->layout->buffer, "-", 0, message->timestamp, flags, THEME_TEXT_HISTORY, display_name, NULL, message->plain, NULL, NULL);
|
||||||
wins_add_urls_ac(window, message, TRUE);
|
wins_add_urls_ac(window, message, TRUE);
|
||||||
wins_add_quotes_ac(window, message->plain, TRUE);
|
wins_add_quotes_ac(window, message->plain, TRUE);
|
||||||
|
@ -276,13 +276,13 @@ wins_get_private_chats(const char* const roomjid)
|
|||||||
void
|
void
|
||||||
wins_private_nick_change(const char* const roomjid, const char* const oldnick, const char* const newnick)
|
wins_private_nick_change(const char* const roomjid, const char* const oldnick, const char* const newnick)
|
||||||
{
|
{
|
||||||
Jid* oldjid = jid_create_from_bare_and_resource(roomjid, oldnick);
|
auto_jid Jid* oldjid = jid_create_from_bare_and_resource(roomjid, oldnick);
|
||||||
|
|
||||||
ProfPrivateWin* privwin = wins_get_private(oldjid->fulljid);
|
ProfPrivateWin* privwin = wins_get_private(oldjid->fulljid);
|
||||||
if (privwin) {
|
if (privwin) {
|
||||||
free(privwin->fulljid);
|
free(privwin->fulljid);
|
||||||
|
|
||||||
Jid* newjid = jid_create_from_bare_and_resource(roomjid, newnick);
|
auto_jid Jid* newjid = jid_create_from_bare_and_resource(roomjid, newnick);
|
||||||
privwin->fulljid = strdup(newjid->fulljid);
|
privwin->fulljid = strdup(newjid->fulljid);
|
||||||
win_println((ProfWin*)privwin, THEME_THEM, "!", "** %s is now known as %s.", oldjid->resourcepart, newjid->resourcepart);
|
win_println((ProfWin*)privwin, THEME_THEM, "!", "** %s is now known as %s.", oldjid->resourcepart, newjid->resourcepart);
|
||||||
|
|
||||||
@ -290,11 +290,7 @@ wins_private_nick_change(const char* const roomjid, const char* const oldnick, c
|
|||||||
autocomplete_remove(wins_close_ac, oldjid->fulljid);
|
autocomplete_remove(wins_close_ac, oldjid->fulljid);
|
||||||
autocomplete_add(wins_ac, newjid->fulljid);
|
autocomplete_add(wins_ac, newjid->fulljid);
|
||||||
autocomplete_add(wins_close_ac, newjid->fulljid);
|
autocomplete_add(wins_close_ac, newjid->fulljid);
|
||||||
|
|
||||||
jid_destroy(newjid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(oldjid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -93,11 +93,10 @@ bookmark_add(const char* jid, const char* nick, const char* password, const char
|
|||||||
{
|
{
|
||||||
assert(jid != NULL);
|
assert(jid != NULL);
|
||||||
|
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp->domainpart) {
|
if (jidp->domainpart) {
|
||||||
muc_confserver_add(jidp->domainpart);
|
muc_confserver_add(jidp->domainpart);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (g_hash_table_contains(bookmarks, jid)) {
|
if (g_hash_table_contains(bookmarks, jid)) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -334,11 +333,10 @@ _bookmark_result_id_handler(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
sv_ev_bookmark_autojoin(bookmark);
|
sv_ev_bookmark_autojoin(bookmark);
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* jidp = jid_create(barejid);
|
auto_jid Jid* jidp = jid_create(barejid);
|
||||||
if (jidp->domainpart) {
|
if (jidp->domainpart) {
|
||||||
muc_confserver_add(jidp->domainpart);
|
muc_confserver_add(jidp->domainpart);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
child = xmpp_stanza_get_next(child);
|
child = xmpp_stanza_get_next(child);
|
||||||
}
|
}
|
||||||
@ -387,11 +385,10 @@ _send_bookmarks(void)
|
|||||||
xmpp_stanza_set_attribute(conference, STANZA_ATTR_NAME, bookmark->name);
|
xmpp_stanza_set_attribute(conference, STANZA_ATTR_NAME, bookmark->name);
|
||||||
} else {
|
} else {
|
||||||
// use localpart of JID by if no name is specified
|
// use localpart of JID by if no name is specified
|
||||||
Jid* jidp = jid_create(bookmark->barejid);
|
auto_jid Jid* jidp = jid_create(bookmark->barejid);
|
||||||
if (jidp->localpart) {
|
if (jidp->localpart) {
|
||||||
xmpp_stanza_set_attribute(conference, STANZA_ATTR_NAME, jidp->localpart);
|
xmpp_stanza_set_attribute(conference, STANZA_ATTR_NAME, jidp->localpart);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bookmark->autojoin) {
|
if (bookmark->autojoin) {
|
||||||
|
@ -110,9 +110,8 @@ chat_session_get_jid(const char* const barejid)
|
|||||||
ChatSession* session = chat_session_get(barejid);
|
ChatSession* session = chat_session_get(barejid);
|
||||||
char* jid = NULL;
|
char* jid = NULL;
|
||||||
if (session) {
|
if (session) {
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(session->barejid, session->resource);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(session->barejid, session->resource);
|
||||||
jid = strdup(jidp->fulljid);
|
jid = strdup(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
jid = strdup(barejid);
|
jid = strdup(barejid);
|
||||||
}
|
}
|
||||||
|
@ -181,7 +181,7 @@ connection_shutdown(void)
|
|||||||
static gboolean
|
static gboolean
|
||||||
_conn_apply_settings(const char* const jid, const char* const passwd, const char* const tls_policy, const char* const auth_policy)
|
_conn_apply_settings(const char* const jid, const char* const passwd, const char* const tls_policy, const char* const auth_policy)
|
||||||
{
|
{
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp == NULL) {
|
if (jidp == NULL) {
|
||||||
log_error("Malformed JID not able to connect: %s", jid);
|
log_error("Malformed JID not able to connect: %s", jid);
|
||||||
conn.conn_status = JABBER_DISCONNECTED;
|
conn.conn_status = JABBER_DISCONNECTED;
|
||||||
@ -189,7 +189,6 @@ _conn_apply_settings(const char* const jid, const char* const passwd, const char
|
|||||||
}
|
}
|
||||||
|
|
||||||
_compute_identifier(jidp->barejid);
|
_compute_identifier(jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
xmpp_ctx_set_verbosity(conn.xmpp_ctx, 0);
|
xmpp_ctx_set_verbosity(conn.xmpp_ctx, 0);
|
||||||
xmpp_conn_set_jid(conn.xmpp_conn, jid);
|
xmpp_conn_set_jid(conn.xmpp_conn, jid);
|
||||||
|
@ -1080,11 +1080,10 @@ _room_list_id_handler(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
const char* item_jid = xmpp_stanza_get_attribute(child, STANZA_ATTR_JID);
|
const char* item_jid = xmpp_stanza_get_attribute(child, STANZA_ATTR_JID);
|
||||||
auto_gchar gchar* item_jid_lower = NULL;
|
auto_gchar gchar* item_jid_lower = NULL;
|
||||||
if (item_jid) {
|
if (item_jid) {
|
||||||
Jid* jidp = jid_create(item_jid);
|
auto_jid Jid* jidp = jid_create(item_jid);
|
||||||
if (jidp && jidp->localpart) {
|
if (jidp && jidp->localpart) {
|
||||||
item_jid_lower = g_utf8_strdown(jidp->localpart, -1);
|
item_jid_lower = g_utf8_strdown(jidp->localpart, -1);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
const char* item_name = xmpp_stanza_get_attribute(child, STANZA_ATTR_NAME);
|
const char* item_name = xmpp_stanza_get_attribute(child, STANZA_ATTR_NAME);
|
||||||
auto_gchar gchar* item_name_lower = NULL;
|
auto_gchar gchar* item_name_lower = NULL;
|
||||||
@ -1505,7 +1504,7 @@ _version_result_id_handler(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
|
|
||||||
xmpp_ctx_t* ctx = connection_get_ctx();
|
xmpp_ctx_t* ctx = connection_get_ctx();
|
||||||
|
|
||||||
Jid* jidp = jid_create((char*)userdata);
|
auto_jid Jid* jidp = jid_create((char*)userdata);
|
||||||
|
|
||||||
const char* presence = NULL;
|
const char* presence = NULL;
|
||||||
|
|
||||||
@ -1543,8 +1542,6 @@ _version_result_id_handler(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
ui_show_software_version(jidp->barejid, "online", name_str, version_str, os_str);
|
ui_show_software_version(jidp->barejid, "online", name_str, version_str, os_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
if (name_str)
|
if (name_str)
|
||||||
xmpp_free(ctx, name_str);
|
xmpp_free(ctx, name_str);
|
||||||
if (version_str)
|
if (version_str)
|
||||||
|
@ -495,11 +495,10 @@ muc_roster_add(const char* const room, const char* const nick, const char* const
|
|||||||
g_hash_table_replace(chat_room->roster, strdup(nick), occupant);
|
g_hash_table_replace(chat_room->roster, strdup(nick), occupant);
|
||||||
|
|
||||||
if (jid) {
|
if (jid) {
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp->barejid) {
|
if (jidp->barejid) {
|
||||||
autocomplete_add(chat_room->jid_ac, jidp->barejid);
|
autocomplete_add(chat_room->jid_ac, jidp->barejid);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -771,13 +770,12 @@ muc_jid_autocomplete_add_all(const char* const room, GSList* jids)
|
|||||||
GSList* curr_jid = jids;
|
GSList* curr_jid = jids;
|
||||||
while (curr_jid) {
|
while (curr_jid) {
|
||||||
const char* jid = curr_jid->data;
|
const char* jid = curr_jid->data;
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp) {
|
if (jidp) {
|
||||||
if (jidp->barejid) {
|
if (jidp->barejid) {
|
||||||
autocomplete_add(chat_room->jid_ac, jidp->barejid);
|
autocomplete_add(chat_room->jid_ac, jidp->barejid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
curr_jid = g_slist_next(curr_jid);
|
curr_jid = g_slist_next(curr_jid);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -389,21 +389,21 @@ omemo_receive_message(xmpp_stanza_t* const stanza, gboolean* trusted)
|
|||||||
size_t iv_len;
|
size_t iv_len;
|
||||||
iv_raw = g_base64_decode(iv_text, &iv_len);
|
iv_raw = g_base64_decode(iv_text, &iv_len);
|
||||||
if (!iv_raw) {
|
if (!iv_raw) {
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t* payload = xmpp_stanza_get_child_by_name(encrypted, "payload");
|
xmpp_stanza_t* payload = xmpp_stanza_get_child_by_name(encrypted, "payload");
|
||||||
if (!payload) {
|
if (!payload) {
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
payload_text = xmpp_stanza_get_text(payload);
|
payload_text = xmpp_stanza_get_text(payload);
|
||||||
if (!payload_text) {
|
if (!payload_text) {
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
size_t payload_len;
|
size_t payload_len;
|
||||||
payload_raw = g_base64_decode(payload_text, &payload_len);
|
payload_raw = g_base64_decode(payload_text, &payload_len);
|
||||||
if (!payload_raw) {
|
if (!payload_raw) {
|
||||||
goto out;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
xmpp_stanza_t* key_stanza;
|
xmpp_stanza_t* key_stanza;
|
||||||
@ -415,27 +415,26 @@ omemo_receive_message(xmpp_stanza_t* const stanza, gboolean* trusted)
|
|||||||
omemo_key_t* key = malloc(sizeof(omemo_key_t));
|
omemo_key_t* key = malloc(sizeof(omemo_key_t));
|
||||||
char* key_text = xmpp_stanza_get_text(key_stanza);
|
char* key_text = xmpp_stanza_get_text(key_stanza);
|
||||||
if (!key_text) {
|
if (!key_text) {
|
||||||
goto skip;
|
free(key);
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* rid_text = xmpp_stanza_get_attribute(key_stanza, "rid");
|
const char* rid_text = xmpp_stanza_get_attribute(key_stanza, "rid");
|
||||||
key->device_id = strtoul(rid_text, NULL, 10);
|
key->device_id = strtoul(rid_text, NULL, 10);
|
||||||
if (!key->device_id) {
|
if (!key->device_id) {
|
||||||
goto skip;
|
free(key);
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
key->data = g_base64_decode(key_text, &key->length);
|
key->data = g_base64_decode(key_text, &key->length);
|
||||||
free(key_text);
|
free(key_text);
|
||||||
if (!key->data) {
|
if (!key->data) {
|
||||||
goto skip;
|
free(key);
|
||||||
|
continue;
|
||||||
}
|
}
|
||||||
key->prekey = g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "true") == 0
|
key->prekey = g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "true") == 0
|
||||||
|| g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "1") == 0;
|
|| g_strcmp0(xmpp_stanza_get_attribute(key_stanza, "prekey"), "1") == 0;
|
||||||
keys = g_list_append(keys, key);
|
keys = g_list_append(keys, key);
|
||||||
continue;
|
|
||||||
|
|
||||||
skip:
|
|
||||||
free(key);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* from = xmpp_stanza_get_from(stanza);
|
const char* from = xmpp_stanza_get_from(stanza);
|
||||||
@ -444,7 +443,6 @@ skip:
|
|||||||
keys, payload_raw, payload_len,
|
keys, payload_raw, payload_len,
|
||||||
g_strcmp0(type, STANZA_TYPE_GROUPCHAT) == 0, trusted);
|
g_strcmp0(type, STANZA_TYPE_GROUPCHAT) == 0, trusted);
|
||||||
|
|
||||||
out:
|
|
||||||
if (keys) {
|
if (keys) {
|
||||||
g_list_free_full(keys, (GDestroyNotify)omemo_key_free);
|
g_list_free_full(keys, (GDestroyNotify)omemo_key_free);
|
||||||
}
|
}
|
||||||
@ -610,8 +608,8 @@ _omemo_devicelist_configure_submit(xmpp_stanza_t* const stanza, void* const user
|
|||||||
form_set_value(form, "pubsub#access_model", "open");
|
form_set_value(form, "pubsub#access_model", "open");
|
||||||
|
|
||||||
xmpp_ctx_t* const ctx = connection_get_ctx();
|
xmpp_ctx_t* const ctx = connection_get_ctx();
|
||||||
Jid* jid = jid_create(connection_get_fulljid());
|
auto_jid Jid* jid = jid_create(connection_get_fulljid());
|
||||||
char* id = connection_create_stanza_id();
|
auto_char char* id = connection_create_stanza_id();
|
||||||
xmpp_stanza_t* iq = stanza_create_pubsub_configure_submit(ctx, id, jid->barejid, STANZA_NS_OMEMO_DEVICELIST, form);
|
xmpp_stanza_t* iq = stanza_create_pubsub_configure_submit(ctx, id, jid->barejid, STANZA_NS_OMEMO_DEVICELIST, form);
|
||||||
|
|
||||||
iq_id_handler_add(id, _omemo_devicelist_configure_result, NULL, NULL);
|
iq_id_handler_add(id, _omemo_devicelist_configure_result, NULL, NULL);
|
||||||
@ -619,8 +617,6 @@ _omemo_devicelist_configure_submit(xmpp_stanza_t* const stanza, void* const user
|
|||||||
iq_send_stanza(iq);
|
iq_send_stanza(iq);
|
||||||
|
|
||||||
xmpp_stanza_release(iq);
|
xmpp_stanza_release(iq);
|
||||||
free(id);
|
|
||||||
jid_destroy(jid);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -664,8 +660,8 @@ _omemo_bundle_publish_result(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
|
|
||||||
log_debug("[OMEMO] cannot publish bundle with open access model, trying to configure node");
|
log_debug("[OMEMO] cannot publish bundle with open access model, trying to configure node");
|
||||||
xmpp_ctx_t* const ctx = connection_get_ctx();
|
xmpp_ctx_t* const ctx = connection_get_ctx();
|
||||||
Jid* jid = jid_create(connection_get_fulljid());
|
auto_jid Jid* jid = jid_create(connection_get_fulljid());
|
||||||
char* id = connection_create_stanza_id();
|
auto_char char* id = connection_create_stanza_id();
|
||||||
auto_gchar gchar* node = g_strdup_printf("%s:%d", STANZA_NS_OMEMO_BUNDLES, omemo_device_id());
|
auto_gchar gchar* node = g_strdup_printf("%s:%d", STANZA_NS_OMEMO_BUNDLES, omemo_device_id());
|
||||||
log_debug("[OMEMO] node: %s", node);
|
log_debug("[OMEMO] node: %s", node);
|
||||||
|
|
||||||
@ -676,8 +672,6 @@ _omemo_bundle_publish_result(xmpp_stanza_t* const stanza, void* const userdata)
|
|||||||
iq_send_stanza(iq);
|
iq_send_stanza(iq);
|
||||||
|
|
||||||
xmpp_stanza_release(iq);
|
xmpp_stanza_release(iq);
|
||||||
free(id);
|
|
||||||
jid_destroy(jid);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -706,8 +700,8 @@ _omemo_bundle_publish_configure(xmpp_stanza_t* const stanza, void* const userdat
|
|||||||
form_set_value(form, "pubsub#access_model", "open");
|
form_set_value(form, "pubsub#access_model", "open");
|
||||||
|
|
||||||
xmpp_ctx_t* const ctx = connection_get_ctx();
|
xmpp_ctx_t* const ctx = connection_get_ctx();
|
||||||
Jid* jid = jid_create(connection_get_fulljid());
|
auto_jid Jid* jid = jid_create(connection_get_fulljid());
|
||||||
char* id = connection_create_stanza_id();
|
auto_char char* id = connection_create_stanza_id();
|
||||||
auto_gchar gchar* node = g_strdup_printf("%s:%d", STANZA_NS_OMEMO_BUNDLES, omemo_device_id());
|
auto_gchar gchar* node = g_strdup_printf("%s:%d", STANZA_NS_OMEMO_BUNDLES, omemo_device_id());
|
||||||
xmpp_stanza_t* iq = stanza_create_pubsub_configure_submit(ctx, id, jid->barejid, node, form);
|
xmpp_stanza_t* iq = stanza_create_pubsub_configure_submit(ctx, id, jid->barejid, node, form);
|
||||||
|
|
||||||
@ -716,8 +710,6 @@ _omemo_bundle_publish_configure(xmpp_stanza_t* const stanza, void* const userdat
|
|||||||
iq_send_stanza(iq);
|
iq_send_stanza(iq);
|
||||||
|
|
||||||
xmpp_stanza_release(iq);
|
xmpp_stanza_release(iq);
|
||||||
free(id);
|
|
||||||
jid_destroy(jid);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +96,7 @@ presence_subscription(const char* const jid, const jabber_subscr_t action)
|
|||||||
{
|
{
|
||||||
assert(jid != NULL);
|
assert(jid != NULL);
|
||||||
|
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
autocomplete_remove(sub_requests_ac, jidp->barejid);
|
autocomplete_remove(sub_requests_ac, jidp->barejid);
|
||||||
|
|
||||||
const char* type = NULL;
|
const char* type = NULL;
|
||||||
@ -129,7 +129,6 @@ presence_subscription(const char* const jid, const jabber_subscr_t action)
|
|||||||
|
|
||||||
xmpp_stanza_set_type(presence, type);
|
xmpp_stanza_set_type(presence, type);
|
||||||
xmpp_stanza_set_to(presence, jidp->barejid);
|
xmpp_stanza_set_to(presence, jidp->barejid);
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
_send_presence_stanza(presence);
|
_send_presence_stanza(presence);
|
||||||
|
|
||||||
@ -278,7 +277,7 @@ _send_room_presence(xmpp_stanza_t* presence)
|
|||||||
void
|
void
|
||||||
presence_join_room(const char* const room, const char* const nick, const char* const passwd)
|
presence_join_room(const char* const room, const char* const nick, const char* const passwd)
|
||||||
{
|
{
|
||||||
Jid* jid = jid_create_from_bare_and_resource(room, nick);
|
auto_jid Jid* jid = jid_create_from_bare_and_resource(room, nick);
|
||||||
log_debug("Sending room join presence to: %s", jid->fulljid);
|
log_debug("Sending room join presence to: %s", jid->fulljid);
|
||||||
|
|
||||||
resource_presence_t presence_type = accounts_get_last_presence(session_get_account_name());
|
resource_presence_t presence_type = accounts_get_last_presence(session_get_account_name());
|
||||||
@ -296,7 +295,6 @@ presence_join_room(const char* const room, const char* const nick, const char* c
|
|||||||
_send_presence_stanza(presence);
|
_send_presence_stanza(presence);
|
||||||
|
|
||||||
xmpp_stanza_release(presence);
|
xmpp_stanza_release(presence);
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -415,13 +413,12 @@ _presence_error_handler(xmpp_stanza_t* const stanza)
|
|||||||
error_cond = "unknown";
|
error_cond = "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* fulljid = jid_create(from);
|
auto_jid Jid* fulljid = jid_create(from);
|
||||||
log_info("Error joining room: %s, reason: %s", fulljid->barejid, error_cond);
|
log_info("Error joining room: %s, reason: %s", fulljid->barejid, error_cond);
|
||||||
if (muc_active(fulljid->barejid)) {
|
if (muc_active(fulljid->barejid)) {
|
||||||
muc_leave(fulljid->barejid);
|
muc_leave(fulljid->barejid);
|
||||||
}
|
}
|
||||||
cons_show_error("Error joining room %s, reason: %s", fulljid->barejid, error_cond);
|
cons_show_error("Error joining room %s, reason: %s", fulljid->barejid, error_cond);
|
||||||
jid_destroy(fulljid);
|
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -472,11 +469,9 @@ _unsubscribed_handler(xmpp_stanza_t* const stanza)
|
|||||||
}
|
}
|
||||||
log_debug("Unsubscribed presence handler fired for %s", from);
|
log_debug("Unsubscribed presence handler fired for %s", from);
|
||||||
|
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
sv_ev_subscription(from_jid->barejid, PRESENCE_UNSUBSCRIBED);
|
sv_ev_subscription(from_jid->barejid, PRESENCE_UNSUBSCRIBED);
|
||||||
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
||||||
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -489,11 +484,9 @@ _subscribed_handler(xmpp_stanza_t* const stanza)
|
|||||||
}
|
}
|
||||||
log_debug("Subscribed presence handler fired for %s", from);
|
log_debug("Subscribed presence handler fired for %s", from);
|
||||||
|
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
sv_ev_subscription(from_jid->barejid, PRESENCE_SUBSCRIBED);
|
sv_ev_subscription(from_jid->barejid, PRESENCE_SUBSCRIBED);
|
||||||
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
autocomplete_remove(sub_requests_ac, from_jid->barejid);
|
||||||
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -505,15 +498,13 @@ _subscribe_handler(xmpp_stanza_t* const stanza)
|
|||||||
}
|
}
|
||||||
log_debug("Subscribe presence handler fired for %s", from);
|
log_debug("Subscribe presence handler fired for %s", from);
|
||||||
|
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
if (from_jid == NULL) {
|
if (from_jid == NULL) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
sv_ev_subscription(from_jid->barejid, PRESENCE_SUBSCRIBE);
|
sv_ev_subscription(from_jid->barejid, PRESENCE_SUBSCRIBE);
|
||||||
autocomplete_add(sub_requests_ac, from_jid->barejid);
|
autocomplete_add(sub_requests_ac, from_jid->barejid);
|
||||||
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -529,11 +520,9 @@ _unavailable_handler(xmpp_stanza_t* const stanza)
|
|||||||
}
|
}
|
||||||
log_debug("Unavailable presence handler fired for %s", from);
|
log_debug("Unavailable presence handler fired for %s", from);
|
||||||
|
|
||||||
Jid* my_jid = jid_create(jid);
|
auto_jid Jid* my_jid = jid_create(jid);
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
if (my_jid == NULL || from_jid == NULL) {
|
if (my_jid == NULL || from_jid == NULL) {
|
||||||
jid_destroy(my_jid);
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -551,9 +540,6 @@ _unavailable_handler(xmpp_stanza_t* const stanza)
|
|||||||
connection_remove_available_resource(from_jid->resourcepart);
|
connection_remove_available_resource(from_jid->resourcepart);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(my_jid);
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -634,7 +620,7 @@ _available_handler(xmpp_stanza_t* const stanza)
|
|||||||
|
|
||||||
xmpp_conn_t* conn = connection_get_conn();
|
xmpp_conn_t* conn = connection_get_conn();
|
||||||
const char* my_jid_str = xmpp_conn_get_jid(conn);
|
const char* my_jid_str = xmpp_conn_get_jid(conn);
|
||||||
Jid* my_jid = jid_create(my_jid_str);
|
auto_jid Jid* my_jid = jid_create(my_jid_str);
|
||||||
|
|
||||||
XMPPCaps* caps = stanza_parse_caps(stanza);
|
XMPPCaps* caps = stanza_parse_caps(stanza);
|
||||||
if ((g_strcmp0(my_jid->fulljid, xmpp_presence->jid->fulljid) != 0) && caps) {
|
if ((g_strcmp0(my_jid->fulljid, xmpp_presence->jid->fulljid) != 0) && caps) {
|
||||||
@ -721,7 +707,6 @@ _available_handler(xmpp_stanza_t* const stanza)
|
|||||||
xmpp_free(ctx, pgpsig);
|
xmpp_free(ctx, pgpsig);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(my_jid);
|
|
||||||
stanza_free_presence(xmpp_presence);
|
stanza_free_presence(xmpp_presence);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -752,7 +737,7 @@ static void
|
|||||||
_muc_user_self_handler(xmpp_stanza_t* stanza)
|
_muc_user_self_handler(xmpp_stanza_t* stanza)
|
||||||
{
|
{
|
||||||
const char* from = xmpp_stanza_get_from(stanza);
|
const char* from = xmpp_stanza_get_from(stanza);
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
|
|
||||||
log_debug("Room self presence received from %s", from_jid->fulljid);
|
log_debug("Room self presence received from %s", from_jid->fulljid);
|
||||||
|
|
||||||
@ -823,8 +808,6 @@ _muc_user_self_handler(xmpp_stanza_t* stanza)
|
|||||||
}
|
}
|
||||||
sv_ev_muc_self_online(room, nick, config_required, role, affiliation, actor, reason, jid, show_str, status_str);
|
sv_ev_muc_self_online(room, nick, config_required, role, affiliation, actor, reason, jid, show_str, status_str);
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
@ -921,13 +904,11 @@ _muc_user_handler(xmpp_stanza_t* const stanza)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
if (from_jid == NULL || from_jid->resourcepart == NULL) {
|
if (from_jid == NULL || from_jid->resourcepart == NULL) {
|
||||||
log_warning("MUC User stanza received with invalid from attribute: %s", from);
|
log_warning("MUC User stanza received with invalid from attribute: %s", from);
|
||||||
jid_destroy(from_jid);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
jid_destroy(from_jid);
|
|
||||||
|
|
||||||
if (stanza_is_muc_self_presence(stanza, connection_get_fulljid())) {
|
if (stanza_is_muc_self_presence(stanza, connection_get_fulljid())) {
|
||||||
_muc_user_self_handler(stanza);
|
_muc_user_self_handler(stanza);
|
||||||
|
@ -151,9 +151,8 @@ roster_update_presence(const char* const barejid, Resource* resource, GDateTime*
|
|||||||
p_contact_set_last_activity(contact, last_activity);
|
p_contact_set_last_activity(contact, last_activity);
|
||||||
}
|
}
|
||||||
p_contact_set_presence(contact, resource);
|
p_contact_set_presence(contact, resource);
|
||||||
Jid* jid = jid_create_from_bare_and_resource(barejid, resource->name);
|
auto_jid Jid* jid = jid_create_from_bare_and_resource(barejid, resource->name);
|
||||||
autocomplete_add(roster->fulljid_ac, jid->fulljid);
|
autocomplete_add(roster->fulljid_ac, jid->fulljid);
|
||||||
jid_destroy(jid);
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -237,9 +236,8 @@ roster_contact_offline(const char* const barejid, const char* const resource, co
|
|||||||
} else {
|
} else {
|
||||||
gboolean result = p_contact_remove_resource(contact, resource);
|
gboolean result = p_contact_remove_resource(contact, resource);
|
||||||
if (result == TRUE) {
|
if (result == TRUE) {
|
||||||
Jid* jid = jid_create_from_bare_and_resource(barejid, resource);
|
auto_jid Jid* jid = jid_create_from_bare_and_resource(barejid, resource);
|
||||||
autocomplete_remove(roster->fulljid_ac, jid->fulljid);
|
autocomplete_remove(roster->fulljid_ac, jid->fulljid);
|
||||||
jid_destroy(jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
|
@ -123,9 +123,8 @@ session_connect_with_account(const ProfAccount* const account)
|
|||||||
|
|
||||||
auto_char char* jid = NULL;
|
auto_char char* jid = NULL;
|
||||||
if (account->resource) {
|
if (account->resource) {
|
||||||
Jid* jidp = jid_create_from_bare_and_resource(account->jid, account->resource);
|
auto_jid Jid* jidp = jid_create_from_bare_and_resource(account->jid, account->resource);
|
||||||
jid = strdup(jidp->fulljid);
|
jid = strdup(jidp->fulljid);
|
||||||
jid_destroy(jidp);
|
|
||||||
} else {
|
} else {
|
||||||
jid = strdup(account->jid);
|
jid = strdup(account->jid);
|
||||||
}
|
}
|
||||||
@ -175,16 +174,15 @@ session_connect_with_details(const char* const jid, const char* const passwd, co
|
|||||||
}
|
}
|
||||||
|
|
||||||
// use 'profanity' when no resourcepart in provided jid
|
// use 'profanity' when no resourcepart in provided jid
|
||||||
Jid* jidp = jid_create(jid);
|
auto_jid Jid* jidp = jid_create(jid);
|
||||||
if (jidp->resourcepart == NULL) {
|
if (jidp->resourcepart == NULL) {
|
||||||
jid_destroy(jidp);
|
|
||||||
auto_gchar gchar* resource = jid_random_resource();
|
auto_gchar gchar* resource = jid_random_resource();
|
||||||
|
jid_destroy(jidp);
|
||||||
jidp = jid_create_from_bare_and_resource(jid, resource);
|
jidp = jid_create_from_bare_and_resource(jid, resource);
|
||||||
saved_details.jid = strdup(jidp->fulljid);
|
saved_details.jid = strdup(jidp->fulljid);
|
||||||
} else {
|
} else {
|
||||||
saved_details.jid = strdup(jid);
|
saved_details.jid = strdup(jid);
|
||||||
}
|
}
|
||||||
jid_destroy(jidp);
|
|
||||||
|
|
||||||
// connect with fulljid
|
// connect with fulljid
|
||||||
log_info("Connecting without account, JID: %s", saved_details.jid);
|
log_info("Connecting without account, JID: %s", saved_details.jid);
|
||||||
|
@ -1395,11 +1395,10 @@ stanza_is_muc_self_presence(xmpp_stanza_t* const stanza,
|
|||||||
// check if 'from' attribute identifies this user
|
// check if 'from' attribute identifies this user
|
||||||
const char* from = xmpp_stanza_get_from(stanza);
|
const char* from = xmpp_stanza_get_from(stanza);
|
||||||
if (from) {
|
if (from) {
|
||||||
Jid* from_jid = jid_create(from);
|
auto_jid Jid* from_jid = jid_create(from);
|
||||||
if (muc_active(from_jid->barejid)) {
|
if (muc_active(from_jid->barejid)) {
|
||||||
char* nick = muc_nick(from_jid->barejid);
|
char* nick = muc_nick(from_jid->barejid);
|
||||||
if (g_strcmp0(from_jid->resourcepart, nick) == 0) {
|
if (g_strcmp0(from_jid->resourcepart, nick) == 0) {
|
||||||
jid_destroy(from_jid);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1411,13 +1410,10 @@ stanza_is_muc_self_presence(xmpp_stanza_t* const stanza,
|
|||||||
char* nick = muc_nick(from_jid->barejid);
|
char* nick = muc_nick(from_jid->barejid);
|
||||||
char* old_nick = muc_old_nick(from_jid->barejid, new_nick);
|
char* old_nick = muc_old_nick(from_jid->barejid, new_nick);
|
||||||
if (g_strcmp0(old_nick, nick) == 0) {
|
if (g_strcmp0(old_nick, nick) == 0) {
|
||||||
jid_destroy(from_jid);
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
jid_destroy(from_jid);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// self presence not found
|
// self presence not found
|
||||||
|
Loading…
Reference in New Issue
Block a user