X-Git-Url: http://git.silcnet.org/gitweb/?p=silc.git;a=blobdiff_plain;f=lib%2Fsilcclient%2Fcommand.c;h=b5827f22819405d28285b296fdb10e15997d93c9;hp=d3220d54e58d9892d6700d57d54e56b6bf9e5f92;hb=HEAD;hpb=65bb39eb3f473859544469c209b6371e230ac9a2 diff --git a/lib/silcclient/command.c b/lib/silcclient/command.c index d3220d54..b5827f22 100644 --- a/lib/silcclient/command.c +++ b/lib/silcclient/command.c @@ -411,6 +411,7 @@ SilcUInt16 silc_client_command_call(SilcClient client, SilcUInt32 argc = 0; unsigned char **argv = NULL; SilcUInt32 *argv_lens = NULL, *argv_types = NULL; + SilcUInt16 cmd_ident; SilcClientCommand command; SilcClientCommandContext cmd; char *arg; @@ -480,7 +481,7 @@ SilcUInt16 silc_client_command_call(SilcClient client, cmd->argv = argv; cmd->argv_lens = argv_lens; cmd->argv_types = argv_types; - cmd->cmd_ident = silc_client_cmd_ident(conn); + cmd_ident = cmd->cmd_ident = silc_client_cmd_ident(conn); cmd->called = TRUE; cmd->verbose = TRUE; silc_list_init(cmd->reply_callbacks, @@ -492,7 +493,7 @@ SilcUInt16 silc_client_command_call(SilcClient client, silc_client_command_destructor, NULL, FALSE); silc_fsm_start_sync(&cmd->thread, command->command); - return cmd->cmd_ident; + return cmd_ident; } /* Generic function to send any command. The arguments must be sent already @@ -696,7 +697,7 @@ SILC_FSM_STATE(silc_client_command_whois) SilcAttributeObjPk obj; SilcPublicKey pk; - if (!silc_pkcs_load_public_key(pubkey, &pk)) { + if (!silc_pkcs_load_public_key(pubkey, SILC_PKCS_ANY, &pk)) { SAY(client, conn, SILC_CLIENT_MESSAGE_COMMAND_ERROR, "Could not load public key %s, check the filename", pubkey); @@ -731,9 +732,8 @@ SILC_FSM_STATE(silc_client_command_whois) } if (nick) { - silc_client_nickname_parse(client, conn, cmd->argv[1], &nickname); - if (!nickname) - nickname = strdup(cmd->argv[1]); + if (!silc_client_nickname_parse(client, conn, cmd->argv[1], &nickname)) + goto out; } /* Send command */ @@ -1051,7 +1051,10 @@ SILC_FSM_STATE(silc_client_command_invite) /* Parse the typed nickname. */ if (cmd->argc == 3) { if (cmd->argv[2][0] != '+' && cmd->argv[2][0] != '-') { - silc_client_nickname_parse(client, conn, cmd->argv[2], &nickname); + if (!silc_client_nickname_parse(client, conn, cmd->argv[2], &nickname)) { + silc_client_unref_channel(client, conn, channel); + goto out; + } /* Find client entry */ clients = silc_client_get_clients_local(client, conn, cmd->argv[2], @@ -1071,7 +1074,7 @@ SILC_FSM_STATE(silc_client_command_invite) action[0] = 0x01; /* Check if it is public key file to be added to invite list */ - silc_pkcs_load_public_key(cmd->argv[2] + 1, &pubkey); + silc_pkcs_load_public_key(cmd->argv[2] + 1, SILC_PKCS_ANY, &pubkey); invite = cmd->argv[2]; if (!pubkey) invite++; @@ -1501,6 +1504,7 @@ SILC_FSM_STATE(silc_client_command_join) pubkey, privkey, pubdata, sizeof(pubdata), conn->internal->sha1hash, + client->rng, conn->local_id, SILC_ID_CLIENT, silc_client_command_join_signed, @@ -1989,7 +1993,8 @@ SILC_FSM_STATE(silc_client_command_cmode) for (k = 3; k < cmd->argc; k++) { if (cmd->argv[k][0] == '+') chadd = TRUE; - if (!silc_pkcs_load_public_key(cmd->argv[k] + 1, &chpk)) { + if (!silc_pkcs_load_public_key(cmd->argv[k] + 1, SILC_PKCS_ANY, + &chpk)) { SAY(conn->client, conn, SILC_CLIENT_MESSAGE_COMMAND_ERROR, "Could not load public key %s, check the filename", cmd->argv[k]); @@ -2118,7 +2123,8 @@ SILC_FSM_STATE(silc_client_command_cumode) } /* Parse the typed nickname. */ - silc_client_nickname_parse(client, conn, cmd->argv[3], &nickname); + if (!silc_client_nickname_parse(client, conn, cmd->argv[3], &nickname)) + goto out; /* Find client entry */ clients = silc_client_get_clients_local(client, conn, cmd->argv[3], FALSE); @@ -2564,7 +2570,7 @@ SILC_FSM_STATE(silc_client_command_ban) action[0] = 0x01; /* Check if it is public key file to be added to invite list */ - silc_pkcs_load_public_key(cmd->argv[2] + 1, &pubkey); + silc_pkcs_load_public_key(cmd->argv[2] + 1, SILC_PKCS_ANY, &pubkey); ban = cmd->argv[2]; if (!pubkey) ban++; @@ -2664,7 +2670,7 @@ SILC_FSM_STATE(silc_client_command_watch) SilcPublicKey pk; SilcBuffer buffer; - if (!silc_pkcs_load_public_key(pubkey, &pk)) { + if (!silc_pkcs_load_public_key(pubkey, SILC_PKCS_ANY, &pk)) { SAY(conn->client, conn, SILC_CLIENT_MESSAGE_COMMAND_ERROR, "Could not load public key %s, check the filename", pubkey); COMMAND_ERROR(SILC_STATUS_ERR_NOT_ENOUGH_PARAMS);