const struct poptOption *opt,
const char *arg, void *data)
{
- if (strcmp(opt->longName, "show-key") == 0) {
- /* Dump the key */
- silc_cipher_register_default();
- silc_pkcs_register_default();
- silc_hash_register_default();
- silc_hmac_register_default();
- silc_show_public_key((char *)arg);
- exit(0);
- }
-
if (strcmp(opt->longName, "list-ciphers") == 0) {
silc_cipher_register_default();
silc_client_list_ciphers();
NULL, NULL, NULL, NULL, TRUE);
exit(0);
}
+
+ if (strcmp(opt->longName, "passphrase-change") == 0) {
+ /* Change the passphrase of the private key file */
+ silc_cipher_register_default();
+ silc_pkcs_register_default();
+ silc_hash_register_default();
+ silc_hmac_register_default();
+ silc_change_private_key_passphrase(arg, NULL, NULL);
+ exit(0);
+ }
+
+ if (strcmp(opt->longName, "show-key") == 0) {
+ /* Dump the key */
+ silc_cipher_register_default();
+ silc_pkcs_register_default();
+ silc_hash_register_default();
+ silc_hmac_register_default();
+ silc_show_public_key((char *)arg);
+ exit(0);
+ }
}
static void sig_init_finished(void)
{
static struct poptOption silc_options[] = {
{ NULL, '\0', POPT_ARG_CALLBACK, (void *)&silc_opt_callback, '\0', NULL },
- { "show-key", 'S', POPT_ARG_STRING, NULL, 0,
- "Show the contents of the public key", "FILE" },
{ "list-ciphers", 0, POPT_ARG_NONE, NULL, 0,
"List supported ciphers", NULL },
{ "list-hash-funcs", 0, POPT_ARG_NONE, NULL, 0,
"List supported HMACs", NULL },
{ "list-pkcs", 0, POPT_ARG_NONE, NULL, 0,
"List supported PKCSs", NULL },
+#ifdef SILC_DEBUG
{ "debug", 'd', POPT_ARG_STRING, NULL, 0,
"Enable debugging", "STRING" },
+#endif /* SILC_DEBUG */
{ "create-key-pair", 'C', POPT_ARG_NONE, NULL, 0,
"Create new public key pair", NULL },
{ "pkcs", 0, POPT_ARG_STRING, &opt_pkcs, 0,
"Set the PKCS of the public key pair (-C)", "PKCS" },
{ "bits", 0, POPT_ARG_INT, &opt_bits, 0,
"Set the length of the public key pair (-C)", "VALUE" },
+ { "passphrase-change", 'P', POPT_ARG_STRING, NULL, 0,
+ "Change the passphrase of private key file", "FILE" },
+ { "show-key", 'S', POPT_ARG_STRING, NULL, 0,
+ "Show the contents of the public key", "FILE" },
{ NULL, '\0', 0, NULL }
};
settings_add_int("server", "key_exchange_rekey_secs", 3600);
settings_add_int("server", "connauth_request_secs", 2);
settings_add_int("server", "heartbeat", 300);
+ settings_add_bool("server", "ignore_message_signatures", FALSE);
/* Requested Attributes settings */
settings_add_bool("silc", "attr_allow", TRUE);
g_free(silc_client->username);
g_free(silc_client->realname);
+ silc_free(silc_client->hostname);
+ silc_pkcs_free(silc_client->pkcs);
+ silc_pkcs_private_key_free(silc_client->private_key);
+ silc_pkcs_public_key_free(silc_client->public_key);
silc_client_free(silc_client);
}