X-Git-Url: http://git.silcnet.org/gitweb/?a=blobdiff_plain;f=apps%2Fsilcd%2Fcommand_reply.c;h=3c4f490e4c46e4d9c6ead1999520079160318649;hb=a818c5b5411bbc4436d1c5f011236985c96bb787;hp=d9fbe6a8e603c85027c532c6714fffd6673b0540;hpb=38685840f29a35f1dab68be00406e1c90808def0;p=silc.git diff --git a/apps/silcd/command_reply.c b/apps/silcd/command_reply.c index d9fbe6a8..3c4f490e 100644 --- a/apps/silcd/command_reply.c +++ b/apps/silcd/command_reply.c @@ -72,7 +72,7 @@ void silc_server_command_reply_process(SilcServer server, SilcServerCommandReplyContext ctx; SilcCommandPayload payload; SilcCommand command; - uint16 ident; + SilcUInt16 ident; SILC_LOG_DEBUG(("Start")); @@ -139,7 +139,7 @@ silc_server_command_reply_whois_save(SilcServerCommandReplyContext cmd) SilcClientEntry client; char global = FALSE; char *nick; - uint32 mode = 0, len, id_len, flen; + SilcUInt32 mode = 0, len, id_len, flen; int expire = 0; id_data = silc_argument_get_arg_type(cmd->args, 2, &id_len); @@ -275,7 +275,7 @@ SILC_SERVER_CMD_REPLY_FUNC(whois) if (status == SILC_STATUS_ERR_NO_SUCH_CLIENT_ID && cmd->sock->type == SILC_SOCKET_TYPE_ROUTER) { SilcClientEntry client; - uint32 tmp_len; + SilcUInt32 tmp_len; unsigned char *tmp = silc_argument_get_arg_type(cmd->args, 2, &tmp_len); if (tmp) { SilcClientID *client_id = silc_id_payload_parse_id(tmp, tmp_len); @@ -304,7 +304,7 @@ static char silc_server_command_reply_whowas_save(SilcServerCommandReplyContext cmd) { SilcServer server = cmd->server; - uint32 len, id_len; + SilcUInt32 len, id_len; unsigned char *id_data; char *nickname, *username, *realname, *servername = NULL; SilcClientID *client_id; @@ -416,7 +416,7 @@ static char silc_server_command_reply_identify_save(SilcServerCommandReplyContext cmd) { SilcServer server = cmd->server; - uint32 len, id_len; + SilcUInt32 len, id_len; unsigned char *id_data; char *name, *info; SilcClientID *client_id = NULL; @@ -636,7 +636,7 @@ SILC_SERVER_CMD_REPLY_FUNC(identify) if (status == SILC_STATUS_ERR_NO_SUCH_CLIENT_ID && cmd->sock->type == SILC_SOCKET_TYPE_ROUTER) { SilcClientEntry client; - uint32 tmp_len; + SilcUInt32 tmp_len; unsigned char *tmp = silc_argument_get_arg_type(cmd->args, 2, &tmp_len); if (tmp) { SilcClientID *client_id = silc_id_payload_parse_id(tmp, tmp_len); @@ -668,7 +668,7 @@ SILC_SERVER_CMD_REPLY_FUNC(info) SilcCommandStatus status; SilcServerEntry entry; SilcServerID *server_id; - uint32 tmp_len; + SilcUInt32 tmp_len; unsigned char *tmp, *name; COMMAND_CHECK_STATUS; @@ -725,7 +725,7 @@ SILC_SERVER_CMD_REPLY_FUNC(motd) SilcCommandStatus status; SilcServerEntry entry = NULL; SilcServerID *server_id; - uint32 tmp_len; + SilcUInt32 tmp_len; unsigned char *tmp; COMMAND_CHECK_STATUS; @@ -776,10 +776,10 @@ SILC_SERVER_CMD_REPLY_FUNC(join) SilcClientID *client_id = NULL; SilcChannelEntry entry; SilcHmac hmac = NULL; - uint32 id_len, len, list_count; + SilcUInt32 id_len, len, list_count; unsigned char *id_string; char *channel_name, *tmp; - uint32 mode, created; + SilcUInt32 mode, created; SilcBuffer keyp = NULL, client_id_list = NULL, client_mode_list = NULL; COMMAND_CHECK_STATUS; @@ -895,8 +895,8 @@ SILC_SERVER_CMD_REPLY_FUNC(join) /* The entry exists. */ /* If ID has changed, then update it to the cache too. */ - if (!SILC_ID_CHANNEL_COMPARE(channel->id, id)) - silc_idlist_replace_channel_id(server->local_list, channel->id, id); + if (!SILC_ID_CHANNEL_COMPARE(entry->id, id)) + silc_idlist_replace_channel_id(server->local_list, entry->id, id); entry->disabled = FALSE; @@ -917,26 +917,21 @@ SILC_SERVER_CMD_REPLY_FUNC(join) /* Get the ban list */ tmp = silc_argument_get_arg_type(cmd->args, 8, &len); if (tmp) { - if (entry->ban_list) - silc_free(entry->ban_list); - entry->ban_list = silc_calloc(len, sizeof(*entry->ban_list)); - memcpy(entry->ban_list, tmp, len); + silc_free(entry->ban_list); + entry->ban_list = silc_memdup(tmp, len); } /* Get the invite list */ tmp = silc_argument_get_arg_type(cmd->args, 9, &len); if (tmp) { - if (entry->invite_list) - silc_free(entry->invite_list); - entry->invite_list = silc_calloc(len, sizeof(*entry->invite_list)); - memcpy(entry->invite_list, tmp, len); + silc_free(entry->invite_list); + entry->invite_list = silc_memdup(tmp, len); } /* Get the topic */ tmp = silc_argument_get_arg_type(cmd->args, 10, &len); if (tmp) { - if (entry->topic) - silc_free(entry->topic); + silc_free(entry->topic); entry->topic = strdup(tmp); } @@ -987,8 +982,8 @@ SILC_SERVER_CMD_REPLY_FUNC(users) SilcBuffer client_id_list; SilcBuffer client_mode_list; unsigned char *tmp; - uint32 tmp_len; - uint32 list_count; + SilcUInt32 tmp_len; + SilcUInt32 list_count; COMMAND_CHECK_STATUS; @@ -1077,8 +1072,8 @@ SILC_SERVER_CMD_REPLY_FUNC(getkey) SilcServerID *server_id = NULL; SilcSKEPKType type; unsigned char *tmp, *pk; - uint32 len; - uint16 pk_len; + SilcUInt32 len; + SilcUInt16 pk_len; SilcIDPayload idp = NULL; SilcIdType id_type; SilcPublicKey public_key = NULL; @@ -1159,9 +1154,9 @@ SILC_SERVER_CMD_REPLY_FUNC(list) SilcChannelID *channel_id = NULL; SilcChannelEntry channel; SilcIDCacheEntry cache; - uint32 len; + SilcUInt32 len; unsigned char *tmp, *name, *topic; - uint32 usercount = 0; + SilcUInt32 usercount = 0; bool global_list = FALSE; COMMAND_CHECK_STATUS_LIST; @@ -1204,6 +1199,8 @@ SILC_SERVER_CMD_REPLY_FUNC(list) cache->expire = time(NULL) + 60; } + channel->user_count = usercount; + if (topic) { silc_free(channel->topic); channel->topic = strdup(topic);