summaryrefslogtreecommitdiffhomepage
path: root/cli-runopts.c
diff options
context:
space:
mode:
authorMatt Johnston <matt@ucc.asn.au>2015-01-24 00:05:26 +0800
committerMatt Johnston <matt@ucc.asn.au>2015-01-24 00:05:26 +0800
commit6165f53fcd6be9bb06fc3cd29e8640bb14d95111 (patch)
tree3319421458308184edfd0bdd945be7d62c299b87 /cli-runopts.c
parent4122cac66b139492d5b7fa6a1b8afcb1bfc529f7 (diff)
Default client key path ~/.ssh/id_dropbear
Diffstat (limited to 'cli-runopts.c')
-rw-r--r--cli-runopts.c27
1 files changed, 21 insertions, 6 deletions
diff --git a/cli-runopts.c b/cli-runopts.c
index bad991f..11c6890 100644
--- a/cli-runopts.c
+++ b/cli-runopts.c
@@ -38,7 +38,7 @@ static void parse_hostname(const char* orighostarg);
static void parse_multihop_hostname(const char* orighostarg, const char* argv0);
static void fill_own_user();
#ifdef ENABLE_CLI_PUBKEY_AUTH
-static void loadidentityfile(const char* filename);
+static void loadidentityfile(const char* filename, int warnfail);
#endif
#ifdef ENABLE_CLI_ANYTCPFWD
static void addforward(const char* str, m_list *fwdlist);
@@ -65,7 +65,7 @@ static void printhelp() {
"-y -y Don't perform any remote host key checking (caution)\n"
"-s Request a subsystem (use by external sftp)\n"
#ifdef ENABLE_CLI_PUBKEY_AUTH
- "-i <identityfile> (multiple allowed)\n"
+ "-i <identityfile> (multiple allowed, default %s)\n"
#endif
#ifdef ENABLE_CLI_AGENTFWD
"-A Enable agent auth forwarding\n"
@@ -95,6 +95,9 @@ static void printhelp() {
"-v verbose (compiled with DEBUG_TRACE)\n"
#endif
,DROPBEAR_VERSION, cli_opts.progname,
+#ifdef ENABLE_CLI_PUBKEY_AUTH
+ DROPBEAR_DEFAULT_CLI_AUTHKEY,
+#endif
DEFAULT_RECV_WINDOW, DEFAULT_KEEPALIVE, DEFAULT_IDLE_TIMEOUT);
}
@@ -174,7 +177,7 @@ void cli_getopts(int argc, char ** argv) {
#ifdef ENABLE_CLI_PUBKEY_AUTH
if (nextiskey) {
/* Load a hostkey since the previous argument was "-i" */
- loadidentityfile(argv[i]);
+ loadidentityfile(argv[i], 1);
nextiskey = 0;
continue;
}
@@ -231,7 +234,7 @@ void cli_getopts(int argc, char ** argv) {
case 'i': /* an identityfile */
/* Keep scp happy when it changes "-i file" to "-ifile" */
if (strlen(argv[i]) > 2) {
- loadidentityfile(&argv[i][2]);
+ loadidentityfile(&argv[i][2], 1);
} else {
nextiskey = 1;
}
@@ -444,6 +447,14 @@ void cli_getopts(int argc, char ** argv) {
}
#endif
+#ifdef DROPBEAR_DEFAULT_CLI_AUTHKEY
+ {
+ char *expand_path = expand_tilde(DROPBEAR_DEFAULT_CLI_AUTHKEY);
+ loadidentityfile(expand_path, 0);
+ m_free(expand_path);
+ }
+#endif
+
/* The hostname gets set up last, since
* in multi-hop mode it will require knowledge
* of other flags such as -i */
@@ -455,14 +466,18 @@ void cli_getopts(int argc, char ** argv) {
}
#ifdef ENABLE_CLI_PUBKEY_AUTH
-static void loadidentityfile(const char* filename) {
+static void loadidentityfile(const char* filename, int warnfail) {
sign_key *key;
enum signkey_type keytype;
+ TRACE(("loadidentityfile %s", filename))
+
key = new_sign_key();
keytype = DROPBEAR_SIGNKEY_ANY;
if ( readhostkey(filename, key, &keytype) != DROPBEAR_SUCCESS ) {
- fprintf(stderr, "Failed loading keyfile '%s'\n", filename);
+ if (warnfail) {
+ fprintf(stderr, "Failed loading keyfile '%s'\n", filename);
+ }
sign_key_free(key);
} else {
key->type = keytype;