Index: src/protocols/silc/buddy.c =================================================================== RCS file: /cvsroot/gaim/gaim/src/protocols/silc/buddy.c,v retrieving revision 1.8 diff -u -p -r1.8 buddy.c --- src/protocols/silc/buddy.c 30 May 2004 20:53:02 -0000 1.8 +++ src/protocols/silc/buddy.c 5 Jun 2004 14:18:11 -0000 @@ -1471,23 +1471,23 @@ char *silcgaim_tooltip_text(GaimBuddy *b return NULL; if (client_entry->nickname) - g_string_append_printf(s, "%s: %s\n", _("Nickname"), + g_string_append_printf(s, "\n%s: %s", _("Nickname"), client_entry->nickname); if (client_entry->username && client_entry->hostname) - g_string_append_printf(s, "%s: %s@%s\n", _("Username"), + g_string_append_printf(s, "\n%s: %s@%s", _("Username"), client_entry->username, client_entry->hostname); if (client_entry->mode) { - g_string_append_printf(s, "%s: ", _("Modes")); + g_string_append_printf(s, "\n%s: ", _("Modes")); memset(tmp, 0, sizeof(tmp)); silcgaim_get_umode_string(client_entry->mode, tmp, sizeof(tmp) - strlen(tmp)); - g_string_append_printf(s, "%s\n", tmp); + g_string_append_printf(s, "%s", tmp); } attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_STATUS_MOOD); if (attr && silc_attribute_get_object(attr, &mood, sizeof(mood))) { if (mood) - g_string_append_printf(s, "%s: ", _("Mood")); + g_string_append_printf(s, "\n%s: ", _("Mood")); if (mood & SILC_ATTRIBUTE_MOOD_HAPPY) g_string_append_printf(s, "[%s] ", _("Happy")); if (mood & SILC_ATTRIBUTE_MOOD_SAD) @@ -1510,19 +1510,17 @@ char *silcgaim_tooltip_text(GaimBuddy *b g_string_append_printf(s, "[%s] ", _("Excited")); if (mood & SILC_ATTRIBUTE_MOOD_ANXIOUS) g_string_append_printf(s, "[%s] ", _("Anxious")); - if (mood) - g_string_append_printf(s, "\n"); } attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_STATUS_FREETEXT); memset(tmp, 0, sizeof(tmp)); if (attr && silc_attribute_get_object(attr, tmp, sizeof(tmp))) - g_string_append_printf(s, "%s: %s\n", _("Status Text"), tmp); + g_string_append_printf(s, "\n%s: %s", _("Status Text"), tmp); attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_PREFERRED_CONTACT); if (attr && silc_attribute_get_object(attr, &contact, sizeof(contact))) { if (contact) - g_string_append_printf(s, "%s: ", _("Preferred Contact")); + g_string_append_printf(s, "\n%s: ", _("Preferred Contact")); if (contact & SILC_ATTRIBUTE_CONTACT_CHAT) g_string_append_printf(s, "[%s] ", _("Chat")); if (contact & SILC_ATTRIBUTE_CONTACT_EMAIL) @@ -1537,18 +1535,17 @@ char *silcgaim_tooltip_text(GaimBuddy *b g_string_append_printf(s, "[%s] ", _("MMS")); if (contact & SILC_ATTRIBUTE_CONTACT_VIDEO) g_string_append_printf(s, "[%s] ", _("Video Conferencing")); - g_string_append_printf(s, "\n"); } attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_PREFERRED_LANGUAGE); memset(tmp, 0, sizeof(tmp)); if (attr && silc_attribute_get_object(attr, tmp, sizeof(tmp))) - g_string_append_printf(s, "%s: %s\n", _("Preferred Language"), tmp); + g_string_append_printf(s, "\n%s: %s", _("Preferred Language"), tmp); attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_DEVICE_INFO); memset(&device, 0, sizeof(device)); if (attr && silc_attribute_get_object(attr, &device, sizeof(device))) { - g_string_append_printf(s, "%s: ", _("Device")); + g_string_append_printf(s, "\n%s: ", _("Device")); if (device.type == SILC_ATTRIBUTE_DEVICE_COMPUTER) g_string_append_printf(s, "%s: ", _("Computer")); if (device.type == SILC_ATTRIBUTE_DEVICE_MOBILE_PHONE) @@ -1557,7 +1554,7 @@ char *silcgaim_tooltip_text(GaimBuddy *b g_string_append_printf(s, "%s: ", _("PDA")); if (device.type == SILC_ATTRIBUTE_DEVICE_TERMINAL) g_string_append_printf(s, "%s: ", _("Terminal")); - g_string_append_printf(s, "%s %s %s %s\n", + g_string_append_printf(s, "%s %s %s %s", device.manufacturer ? device.manufacturer : "", device.version ? device.version : "", device.model ? device.model : "", @@ -1567,12 +1564,12 @@ char *silcgaim_tooltip_text(GaimBuddy *b attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_TIMEZONE); memset(tmp, 0, sizeof(tmp)); if (attr && silc_attribute_get_object(attr, tmp, sizeof(tmp))) - g_string_append_printf(s, "%s: %s\n", _("Timezone"), tmp); + g_string_append_printf(s, "\n%s: %s", _("Timezone"), tmp); attr = silcgaim_get_attr(client_entry->attrs, SILC_ATTRIBUTE_GEOLOCATION); memset(&geo, 0, sizeof(geo)); if (attr && silc_attribute_get_object(attr, &geo, sizeof(geo))) - g_string_append_printf(s, "%s: %s %s %s (%s)\n", + g_string_append_printf(s, "\n%s: %s %s %s (%s)", _("Geolocation"), geo.longitude ? geo.longitude : "", geo.latitude ? geo.latitude : "", Index: src/protocols/silc/ops.c =================================================================== RCS file: /cvsroot/gaim/gaim/src/protocols/silc/ops.c,v retrieving revision 1.5 diff -u -p -r1.5 ops.c --- src/protocols/silc/ops.c 23 May 2004 20:06:10 -0000 1.5 +++ src/protocols/silc/ops.c 5 Jun 2004 14:18:11 -0000 @@ -653,7 +653,7 @@ silc_notify(SilcClient client, SilcClien /* Find buddy by nickname */ b = gaim_find_buddy(sg->account, client_entry->nickname); if (!b) { - fprintf(stderr, "WATCH for %s, unknown buddy", + gaim_debug_warning("silc", "WATCH for %s, unknown buddy", client_entry->nickname); break; } Index: src/protocols/silc/silc.c =================================================================== RCS file: /cvsroot/gaim/gaim/src/protocols/silc/silc.c,v retrieving revision 1.10 diff -u -p -r1.10 silc.c --- src/protocols/silc/silc.c 23 May 2004 20:06:10 -0000 1.10 +++ src/protocols/silc/silc.c 5 Jun 2004 14:18:11 -0000 @@ -278,8 +278,8 @@ silcgaim_login(GaimAccount *account) /* Load SILC key pair */ if (!silc_load_key_pair(gaim_prefs_get_string("/plugins/prpl/silc/pubkey"), gaim_prefs_get_string("/plugins/prpl/silc/privkey"), - "", &client->pkcs, &client->public_key, - &client->private_key)) { + (account->password == NULL) ? "" : account->password, &client->pkcs, + &client->public_key, &client->private_key)) { gaim_connection_error(gc, ("Could not load SILC key pair")); return; } @@ -318,21 +318,21 @@ silcgaim_close_final(gpointer *context) } static void -silcgaim_close_convos(GaimConversation *convo) -{ - if (convo) - gaim_conversation_destroy(convo); -} - -static void silcgaim_close(GaimConnection *gc) { + GList *l; + GaimConversation *conv; SilcGaim sg = gc->proto_data; if (!sg) return; - /* Close all conversations */ - gaim_conversation_foreach(silcgaim_close_convos); + /* Close all conversations for this connection */ + for (l = gaim_get_conversations(); l; l = l->next) + { + conv = l->data; + if (gc == conv->account->gc) + gaim_conversation_destroy(conv); + } /* Send QUIT */ silc_client_command_call(sg->client, sg->conn, NULL, @@ -729,6 +729,31 @@ silcgaim_view_motd(GaimPluginAction *act sg->motd, NULL, NULL); } +static void +silcgaim_change_pass(GaimPluginAction *action) +{ + GaimConnection *gc = (GaimConnection *) action->context; + gaim_account_request_change_password(gaim_connection_get_account(gc)); +} + +static void +silcgaim_change_passwd(GaimConnection *gc, const char *old, const char *new) +{ + silc_change_private_key_passphrase(gaim_prefs_get_string("/plugins/prpl/silc/privkey"), old, new); +} + +static void +silcgaim_show_set_info(GaimPluginAction *action) +{ + GaimConnection *gc = (GaimConnection *) action->context; + gaim_account_request_change_user_info(gaim_connection_get_account(gc)); +} + +static void +silcgaim_set_info(GaimConnection *gc, const char *text) +{ +} + static GList * silcgaim_actions(GaimPlugin *plugin, gpointer context) { @@ -750,6 +775,14 @@ silcgaim_actions(GaimPlugin *plugin, gpo silcgaim_view_motd); list = g_list_append(list, act); + act = gaim_plugin_action_new(_("Change Password..."), + silcgaim_change_pass); + list = g_list_append(list, act); + + act = gaim_plugin_action_new(_("Set User Info..."), + silcgaim_show_set_info); + list = g_list_append(list, act); + return list; } @@ -893,9 +926,87 @@ GList *silcgaim_blist_node_menu(GaimBlis } } +/********************************* Commands **********************************/ + +static GaimCmdRet silcgaim_cmd_chat_part(GaimConversation *conv, + const char *cmd, char **args, char **error) +{ + GaimConnection *gc; + int id = 0; + + gc = gaim_conversation_get_gc(conv); + id = gaim_conv_chat_get_id(GAIM_CONV_CHAT(conv)); + + if (gc == NULL || id == 0) + return GAIM_CMD_RET_FAILED; + + silcgaim_chat_leave(gc, id); + + return GAIM_CMD_RET_OK; + +} + +static GaimCmdRet silcgaim_cmd_chat_topic(GaimConversation *conv, + const char *cmd, char **args, char **error) +{ + GaimConnection *gc; + int id = 0; + + gc = gaim_conversation_get_gc(conv); + id = gaim_conv_chat_get_id(GAIM_CONV_CHAT(conv)); + + if (gc == NULL || id == 0) + return GAIM_CMD_RET_FAILED; + + silcgaim_chat_set_topic(gc, id, args ? args[0] : NULL); + + return GAIM_CMD_RET_OK; +} + +static GaimCmdRet silcgaim_cmd_chat_join(GaimConversation *conv, + const char *cmd, char **args, char **error) +{ + GHashTable *comp; + + if(!args || !args[0]) + return GAIM_CMD_RET_FAILED; + + comp = g_hash_table_new_full(g_str_hash, g_str_equal, NULL, NULL); + + g_hash_table_replace(comp, "channel", args[0]); + if(args[1]) + g_hash_table_replace(comp, "passphrase", args[1]); + + silcgaim_chat_join(gaim_conversation_get_gc(conv), comp); + + g_hash_table_destroy(comp); + return GAIM_CMD_RET_OK; +} + + /************************** Plugin Initialization ****************************/ +static void +silcgaim_register_commands(void) +{ + gaim_cmd_register("part", "", GAIM_CMD_P_PRPL, + GAIM_CMD_FLAG_CHAT | GAIM_CMD_FLAG_PRPL_ONLY, + "prpl-silc", silcgaim_cmd_chat_part, _("Leave the chat")); + gaim_cmd_register("leave", "", GAIM_CMD_P_PRPL, + GAIM_CMD_FLAG_CHAT | GAIM_CMD_FLAG_PRPL_ONLY, + "prpl-silc", silcgaim_cmd_chat_part, _("Leave the chat")); + gaim_cmd_register("topic", "s", GAIM_CMD_P_PRPL, + GAIM_CMD_FLAG_CHAT | GAIM_CMD_FLAG_PRPL_ONLY | + GAIM_CMD_FLAG_ALLOW_WRONG_ARGS, "prpl-silc", + silcgaim_cmd_chat_topic, _("View or change the topic")); + gaim_cmd_register("join", "ws", GAIM_CMD_P_PRPL, + GAIM_CMD_FLAG_IM | GAIM_CMD_FLAG_CHAT | + GAIM_CMD_FLAG_PRPL_ONLY | GAIM_CMD_FLAG_ALLOW_WRONG_ARGS, + "prpl-silc", silcgaim_cmd_chat_join, + _("Join a chat on this network")); +} + static GaimPluginPrefFrame * silcgaim_pref_frame(GaimPlugin *plugin) { @@ -968,12 +1079,12 @@ static GaimPluginProtocolInfo prpl_info silcgaim_login, silcgaim_close, silcgaim_send_im, - NULL, + silcgaim_set_info, NULL, silcgaim_get_info, silcgaim_set_away, silcgaim_idle_set, - NULL, + silcgaim_change_passwd, silcgaim_add_buddy, silcgaim_add_buddies, silcgaim_remove_buddy, @@ -1094,6 +1205,8 @@ init_plugin(GaimPlugin *plugin) g_snprintf(tmp, sizeof(tmp), "%s/private_key.prv", silcgaim_silcdir()); gaim_prefs_add_string("/plugins/prpl/silc/privkey", tmp); gaim_prefs_add_string("/plugins/prpl/silc/vcard", ""); + + silcgaim_register_commands(); } GAIM_INIT_PLUGIN(silc, init_plugin, info); Index: src/protocols/silc/silcgaim.h =================================================================== RCS file: /cvsroot/gaim/gaim/src/protocols/silc/silcgaim.h,v retrieving revision 1.2 diff -u -p -r1.2 silcgaim.h --- src/protocols/silc/silcgaim.h 23 May 2004 19:40:55 -0000 1.2 +++ src/protocols/silc/silcgaim.h 5 Jun 2004 14:18:11 -0000 @@ -33,6 +33,7 @@ #include "util.h" #include "roomlist.h" #include "ft.h" +#include "cmds.h" /* Default public and private key file names */ #define SILCGAIM_PUBLIC_KEY_NAME "public_key.pub" Index: src/protocols/silc/util.c =================================================================== RCS file: /cvsroot/gaim/gaim/src/protocols/silc/util.c,v retrieving revision 1.3 diff -u -p -r1.3 util.c --- src/protocols/silc/util.c 23 May 2004 20:06:10 -0000 1.3 +++ src/protocols/silc/util.c 5 Jun 2004 14:18:11 -0000 @@ -76,7 +76,7 @@ gboolean silcgaim_check_silc_dir(GaimCon pw = getpwuid(getuid()); if (!pw) { - fprintf(stderr, "silc: %s\n", strerror(errno)); + gaim_debug_error("silc", "silc: %s\n", strerror(errno)); return FALSE; } @@ -96,22 +96,22 @@ gboolean silcgaim_check_silc_dir(GaimCon if (errno == ENOENT) { if (pw->pw_uid == geteuid()) { if ((mkdir(filename, 0755)) == -1) { - fprintf(stderr, "Couldn't create `%s' directory\n", filename); + gaim_debug_error("silc", "Couldn't create '%s' directory\n", filename); return FALSE; } } else { - fprintf(stderr, "Couldn't create `%s' directory due to a wrong uid!\n", + gaim_debug_error("silc", "Couldn't create '%s' directory due to a wrong uid!\n", filename); return FALSE; } } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' directory, error: %s\n", filename, strerror(errno)); return FALSE; } } else { /* Check the owner of the dir */ if (st.st_uid != 0 && st.st_uid != pw->pw_uid) { - fprintf(stderr, "You don't seem to own `%s' directory\n", + gaim_debug_error("silc", "You don't seem to own '%s' directory\n", filename); return FALSE; } @@ -125,16 +125,17 @@ gboolean silcgaim_check_silc_dir(GaimCon if (errno == ENOENT) { if (pw->pw_uid == geteuid()) { if ((mkdir(servfilename, 0755)) == -1) { - fprintf(stderr, "Couldn't create `%s' directory\n", servfilename); + gaim_debug_error("silc", "Couldn't create '%s' directory\n", servfilename); return FALSE; } } else { - fprintf(stderr, "Couldn't create `%s' directory due to a wrong uid!\n", + gaim_debug_error("silc", "Couldn't create '%s' directory due to a wrong uid!\n", servfilename); return FALSE; } } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' directory, error: %s\n", + servfilename, strerror(errno)); return FALSE; } } @@ -147,16 +148,17 @@ gboolean silcgaim_check_silc_dir(GaimCon if (errno == ENOENT) { if (pw->pw_uid == geteuid()) { if ((mkdir(clientfilename, 0755)) == -1) { - fprintf(stderr, "Couldn't create `%s' directory\n", clientfilename); + gaim_debug_error("silc", "Couldn't create '%s' directory\n", clientfilename); return FALSE; } } else { - fprintf(stderr, "Couldn't create `%s' directory due to a wrong uid!\n", + gaim_debug_error("silc", "Couldn't create '%s' directory due to a wrong uid!\n", clientfilename); return FALSE; } } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' directory, error: %s\n", + clientfilename, strerror(errno)); return FALSE; } } @@ -169,16 +171,17 @@ gboolean silcgaim_check_silc_dir(GaimCon if (errno == ENOENT) { if (pw->pw_uid == geteuid()) { if ((mkdir(friendsfilename, 0755)) == -1) { - fprintf(stderr, "Couldn't create `%s' directory\n", friendsfilename); + gaim_debug_error("silc", "Couldn't create '%s' directory\n", friendsfilename); return FALSE; } } else { - fprintf(stderr, "Couldn't create `%s' directory due to a wrong uid!\n", + gaim_debug_error("silc", "Couldn't create '%s' directory due to a wrong uid!\n", friendsfilename); return FALSE; } } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' directory, error: %s\n", + friendsfilename, strerror(errno)); return FALSE; } } @@ -198,16 +201,19 @@ gboolean silcgaim_check_silc_dir(GaimCon silc_create_key_pair(SILCGAIM_DEF_PKCS, SILCGAIM_DEF_PKCS_LEN, file_public_key, file_private_key, NULL, - "", NULL, NULL, NULL, FALSE); + (gc->account->password == NULL) ? "" : gc->account->password, + NULL, NULL, NULL, FALSE); + stat(file_public_key, &st); } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' public key, error: %s\n", + file_public_key, strerror(errno)); return FALSE; } } /* Check the owner of the public key */ if (st.st_uid != 0 && st.st_uid != pw->pw_uid) { - fprintf(stderr, "You don't seem to own your public key!?\n"); + gaim_debug_error("silc", "You don't seem to own your public key!?\n"); return FALSE; } @@ -218,30 +224,33 @@ gboolean silcgaim_check_silc_dir(GaimCon silc_create_key_pair(SILCGAIM_DEF_PKCS, SILCGAIM_DEF_PKCS_LEN, file_public_key, file_private_key, NULL, - "", NULL, NULL, NULL, FALSE); + (gc->account->password == NULL) ? "" : gc->account->password, + NULL, NULL, NULL, FALSE); + stat(file_private_key, &st); } else { - fprintf(stderr, "%s\n", strerror(errno)); + gaim_debug_error("silc", "Couldn't stat '%s' private key, error: %s\n", + file_private_key, strerror(errno)); return FALSE; } } /* Check the owner of the private key */ if (st.st_uid != 0 && st.st_uid != pw->pw_uid) { - fprintf(stderr, "You don't seem to own your private key!?\n"); + gaim_debug_error("silc", "You don't seem to own your private key!?\n"); return FALSE; } /* Check the permissions for the private key */ if ((st.st_mode & 0777) != 0600) { - fprintf(stderr, "Wrong permissions in your private key file `%s'!\n" + gaim_debug_warning("silc", "Wrong permissions in your private key file `%s'!\n" "Trying to change them ... ", file_private_key); if ((chmod(file_private_key, 0600)) == -1) { - fprintf(stderr, + gaim_debug_error("silc", "Failed to change permissions for private key file!\n" "Permissions for your private key file must be 0600.\n"); return FALSE; } - fprintf(stderr, "Done.\n\n"); + gaim_debug_warning("silc", "Done.\n\n"); } return TRUE;