Mercurial > pidgin.yaz
changeset 3257:4c28751180f9
[gaim-migrate @ 3275]
Change password on Jabber server (Thanks, Nathan Walp)
committer: Tailor Script <tailor@pidgin.im>
author | Jim Seymour <jseymour> |
---|---|
date | Sat, 18 May 2002 15:42:01 +0000 |
parents | a7c241854218 |
children | c92dc6f0e497 |
files | ChangeLog src/protocols/jabber/jabber.c |
diffstat | 2 files changed, 53 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/ChangeLog Thu May 16 22:46:42 2002 +0000 +++ b/ChangeLog Sat May 18 15:42:01 2002 +0000 @@ -6,6 +6,8 @@ that crashed Gaim. In the process: found and eliminated some memory leaks. * Fixed a significant applet leak + * Can now change Jabber password on server (Thanks, + Nathan Walp) version 0.58 (05/13/2002): * Bulgarian translation added (Thanks, Igel Itzo)
--- a/src/protocols/jabber/jabber.c Thu May 16 22:46:42 2002 +0000 +++ b/src/protocols/jabber/jabber.c Sat May 18 15:42:01 2002 +0000 @@ -214,7 +214,8 @@ pool_free(p); /* no need for this anymore! */ return (NULL); } - gjc->pass = pstrdup(p, pass); + + gjc->pass = strdup(pass); gjc->state = JCONN_STATE_OFF; gjc->was_connected = 0; @@ -232,6 +233,7 @@ return; gjab_stop(gjc); + free(gjc->pass); pool_free(gjc->p); } @@ -703,6 +705,46 @@ } } +static void jabber_change_passwd(struct gaim_connection *gc, char *old, char *new) +{ + gjconn gjc = ((struct jabber_data *)gc->proto_data)->gjc; + + if(strcmp(old, gjc->pass)) + { + do_error_dialog(_("Incorrect current password! Password NOT Changed!"), + _("Password Change Error!")); + } + else if(!strcmp(old, new)) + { + do_error_dialog(_("New password same as old password! Password NOT Changed!"), + _("Password Change Error!")); + } + else + { + xmlnode x, y, z; + char *id; + + x = jutil_iqnew(JPACKET__SET, NS_REGISTER); + xmlnode_put_attrib(x, "to", gjc->user->server); + y = xmlnode_get_tag(x, "query"); + z = xmlnode_insert_tag(y, "username"); + xmlnode_insert_cdata(z, gjc->user->user, -1); + z = xmlnode_insert_tag(y, "password"); + xmlnode_insert_cdata(z, new, -1); + + id = gjab_getid(gjc); + xmlnode_put_attrib(x, "id", id); + + free(gjc->pass); + gjc->pass = strdup(new); + + g_hash_table_insert(gjc->queries, g_strdup(id), g_strdup("change_password")); + + gjab_send(gjc, x); + xmlnode_free(x); + } +} + /* * keep track of away msg same as yahoo plugin */ @@ -1551,6 +1593,11 @@ * way the user always gets some kind of response. */ jabber_handlevcard(gjc, NULL, from); + } else if(!strcmp((char *) val, "change_password")) { + char buf[BUF_LONG]; + sprintf(buf,_("Password successfully changed.")); + + do_error_dialog(buf, _("Password Change")); } } } @@ -3127,9 +3174,9 @@ /* } else if (!strcmp(act, _("Set Dir Info"))) { show_set_dir(gc); + */ } else if (!strcmp(act, _("Change Password"))) { show_change_passwd(gc); - */ } } @@ -3140,8 +3187,8 @@ m = g_list_append(m, _("Set User Info")); /* m = g_list_append(m, _("Set Dir Info")); + */ m = g_list_append(m, _("Change Password")); - */ return m; } @@ -3172,7 +3219,7 @@ ret->get_dir = NULL; ret->dir_search = NULL; ret->set_idle = jabber_set_idle; - ret->change_passwd = NULL; + ret->change_passwd = jabber_change_passwd; ret->add_buddy = jabber_add_buddy; ret->add_buddies = NULL; ret->remove_buddy = jabber_remove_buddy;