mirror of
https://github.com/clearml/dropbear
synced 2025-04-06 21:54:24 +00:00
don't fail fatally if the client can't get homedir from getpwuid(), fallback
to $HOME. --HG-- extra : convert_revision : 279bd16a3e639764df14dce868fdeea7d6a0f317
This commit is contained in:
parent
719b47e3aa
commit
c1b602145f
58
cli-kex.c
58
cli-kex.c
@ -145,6 +145,7 @@ static void checkhostkey(unsigned char* keyblob, unsigned int keybloblen) {
|
|||||||
FILE *hostsfile = NULL;
|
FILE *hostsfile = NULL;
|
||||||
int readonly = 0;
|
int readonly = 0;
|
||||||
struct passwd *pw = NULL;
|
struct passwd *pw = NULL;
|
||||||
|
char * homedir = NULL;
|
||||||
unsigned int hostlen, algolen;
|
unsigned int hostlen, algolen;
|
||||||
unsigned long len;
|
unsigned long len;
|
||||||
const char *algoname = NULL;
|
const char *algoname = NULL;
|
||||||
@ -153,41 +154,50 @@ static void checkhostkey(unsigned char* keyblob, unsigned int keybloblen) {
|
|||||||
|
|
||||||
pw = getpwuid(getuid());
|
pw = getpwuid(getuid());
|
||||||
|
|
||||||
if (pw == NULL) {
|
if (pw)
|
||||||
dropbear_exit("Failed to get homedir");
|
homedir = pw->pw_dir;
|
||||||
|
}
|
||||||
|
pw = NULL;
|
||||||
|
|
||||||
|
if (!homedir)
|
||||||
|
homedir = getenv("HOME");
|
||||||
}
|
}
|
||||||
|
|
||||||
len = strlen(pw->pw_dir);
|
if (homedir) {
|
||||||
filename = m_malloc(len + 18); /* "/.ssh/known_hosts" and null-terminator*/
|
|
||||||
|
|
||||||
snprintf(filename, len+18, "%s/.ssh", pw->pw_dir);
|
len = strlen(homedir);
|
||||||
/* Check that ~/.ssh exists - easiest way is just to mkdir */
|
filename = m_malloc(len + 18); /* "/.ssh/known_hosts" and null-terminator*/
|
||||||
if (mkdir(filename, S_IRWXU) != 0) {
|
|
||||||
if (errno != EEXIST) {
|
snprintf(filename, len+18, "%s/.ssh", homedir);
|
||||||
dropbear_log(LOG_INFO, "Warning: failed creating ~/.ssh: %s",
|
/* Check that ~/.ssh exists - easiest way is just to mkdir */
|
||||||
strerror(errno));
|
if (mkdir(filename, S_IRWXU) != 0) {
|
||||||
TRACE(("mkdir didn't work: %s", strerror(errno)))
|
if (errno != EEXIST) {
|
||||||
ask_to_confirm(keyblob, keybloblen);
|
dropbear_log(LOG_INFO, "Warning: failed creating ~/.ssh: %s",
|
||||||
goto out; /* only get here on success */
|
strerror(errno));
|
||||||
|
TRACE(("mkdir didn't work: %s", strerror(errno)))
|
||||||
|
ask_to_confirm(keyblob, keybloblen);
|
||||||
|
goto out; /* only get here on success */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
snprintf(filename, len+18, "%s/.ssh/known_hosts", pw->pw_dir);
|
snprintf(filename, len+18, "%s/.ssh/known_hosts", homedir);
|
||||||
hostsfile = fopen(filename, "a+");
|
hostsfile = fopen(filename, "a+");
|
||||||
|
|
||||||
if (hostsfile != NULL) {
|
if (hostsfile != NULL) {
|
||||||
fseek(hostsfile, 0, SEEK_SET);
|
fseek(hostsfile, 0, SEEK_SET);
|
||||||
} else {
|
} else {
|
||||||
/* We mightn't have been able to open it if it was read-only */
|
/* We mightn't have been able to open it if it was read-only */
|
||||||
if (errno == EACCES || errno == EROFS) {
|
if (errno == EACCES || errno == EROFS) {
|
||||||
TRACE(("trying readonly: %s", strerror(errno)))
|
TRACE(("trying readonly: %s", strerror(errno)))
|
||||||
readonly = 1;
|
readonly = 1;
|
||||||
hostsfile = fopen(filename, "r");
|
hostsfile = fopen(filename, "r");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hostsfile == NULL) {
|
if (hostsfile == NULL) {
|
||||||
TRACE(("hostsfile didn't open: %s", strerror(errno)))
|
TRACE(("hostsfile didn't open: %s", strerror(errno)))
|
||||||
|
dropbear_log(LOG_WARNING, "Failed to open ~/.ssh/known_hosts");
|
||||||
ask_to_confirm(keyblob, keybloblen);
|
ask_to_confirm(keyblob, keybloblen);
|
||||||
goto out; /* We only get here on success */
|
goto out; /* We only get here on success */
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user