diff options
author | Matt Johnston <matt@ucc.asn.au> | 2015-08-03 20:45:04 +0800 |
---|---|---|
committer | Matt Johnston <matt@ucc.asn.au> | 2015-08-03 20:45:04 +0800 |
commit | 941c067765fce8d8f9cf73bc77ffc4b8791395c0 (patch) | |
tree | 98521fb8db5ca97f5bdb6ebb4a47e98dce0d6468 | |
parent | 839e023ed88e7c8c42b8ea8bb9e11ffd46668d9c (diff) |
change DROPBEAR_DEFAULT_CLI_AUTHKEY to just prepend homedir
rather than doing ~ expansion
-rw-r--r-- | cli-runopts.c | 2 | ||||
-rw-r--r-- | dbutil.c | 11 | ||||
-rw-r--r-- | dbutil.h | 2 | ||||
-rw-r--r-- | options.h | 4 |
4 files changed, 10 insertions, 9 deletions
diff --git a/cli-runopts.c b/cli-runopts.c index 5bd4c55..58b64ce 100644 --- a/cli-runopts.c +++ b/cli-runopts.c @@ -449,7 +449,7 @@ void cli_getopts(int argc, char ** argv) { #if defined(DROPBEAR_DEFAULT_CLI_AUTHKEY) && defined(ENABLE_CLI_PUBKEY_AUTH) { - char *expand_path = expand_tilde(DROPBEAR_DEFAULT_CLI_AUTHKEY); + char *expand_path = expand_homedir_path(DROPBEAR_DEFAULT_CLI_AUTHKEY); loadidentityfile(expand_path, 0); m_free(expand_path); } @@ -613,15 +613,16 @@ int m_str_to_uint(const char* str, unsigned int *val) { } } -/* Returns malloced path. Only expands ~ in first character */ -char * expand_tilde(const char *inpath) { +/* Returns malloced path. inpath beginning with '/' is returned as-is, +otherwise home directory is prepended */ +char * expand_homedir_path(const char *inpath) { struct passwd *pw = NULL; - if (inpath[0] == '~') { + if (inpath[0] != '/') { pw = getpwuid(getuid()); if (pw && pw->pw_dir) { - int len = strlen(inpath) + strlen(pw->pw_dir) + 1; + int len = strlen(inpath) + strlen(pw->pw_dir) + 2; char *buf = m_malloc(len); - snprintf(buf, len, "%s/%s", pw->pw_dir, &inpath[1]); + snprintf(buf, len, "%s/%s", pw->pw_dir, inpath); return buf; } } @@ -97,6 +97,6 @@ int constant_time_memcmp(const void* a, const void *b, size_t n); a real-world clock */ time_t monotonic_now(); -char * expand_tilde(const char *inpath); +char * expand_homedir_path(const char *inpath); #endif /* DROPBEAR_DBUTIL_H_ */ @@ -222,8 +222,8 @@ If you test it please contact the Dropbear author */ #define ENABLE_CLI_INTERACT_AUTH /* A default argument for dbclient -i <privatekey>. - leading "~" is expanded */ -#define DROPBEAR_DEFAULT_CLI_AUTHKEY "~/.ssh/id_dropbear" +Homedir is prepended unless path begins with / */ +#define DROPBEAR_DEFAULT_CLI_AUTHKEY ".ssh/id_dropbear" /* This variable can be used to set a password for client * authentication on the commandline. Beware of platforms |