SILC_SERVER_CMD_REPLY(users, USERS),
SILC_SERVER_CMD_REPLY(getkey, GETKEY),
SILC_SERVER_CMD_REPLY(list, LIST),
+ SILC_SERVER_CMD_REPLY(watch, WATCH),
{ NULL, 0 },
};
if (tmp) {
silc_free(client->attrs);
client->attrs = silc_memdup(tmp, len);
+ client->attrs_len = len;
}
return TRUE;
if (tmp && client) {
silc_free(client->attrs);
client->attrs = silc_memdup(tmp, len);
+ client->attrs_len = len;
}
+ client->data.status &= ~SILC_IDLIST_STATUS_RESOLVING;
+
return TRUE;
}
silc_free(id);
goto out;
}
+ hmac = NULL;
server->stat.my_channels++;
server->stat.channels++;
} else {
founder_key = NULL;
}
- if (entry->hmac_name && hmac) {
+ if (entry->hmac_name && (hmac || (!hmac && entry->hmac))) {
silc_free(entry->hmac_name);
- entry->hmac_name = strdup(silc_hmac_get_name(hmac));
+ entry->hmac_name = strdup(silc_hmac_get_name(hmac ? hmac : entry->hmac));
}
/* Get the ban list */
out:
SILC_SERVER_PENDING_EXEC(cmd, SILC_COMMAND_JOIN);
err:
+ if (hmac)
+ silc_hmac_free(hmac);
silc_free(client_id);
silc_server_command_reply_free(cmd);
/* Get statistics structure */
tmp = silc_argument_get_arg_type(cmd->args, 3, &tmp_len);
- if (server->server_type == SILC_SERVER && tmp) {
+ if (server->server_type != SILC_ROUTER && tmp) {
silc_buffer_set(&buf, tmp, tmp_len);
silc_buffer_unformat(&buf,
SILC_STR_UI_INT(NULL),