1
1

misc: Properly check for errors returned from getpwuid_r()

Resolves: T118

Signed-off-by: Jakub Jelen <jjelen@redhat.com>
Reviewed-by: Andreas Schneider <asn@cryptomilk.org>
Этот коммит содержится в:
Jakub Jelen 2018-10-30 16:02:39 +01:00
родитель 9c4baa7fd5
Коммит d85bc347d3

Просмотреть файл

@ -217,12 +217,12 @@ char *ssh_get_user_home_dir(void)
{ {
char *szPath = NULL; char *szPath = NULL;
struct passwd pwd; struct passwd pwd;
struct passwd *pwdbuf; struct passwd *pwdbuf = NULL;
char buf[NSS_BUFLEN_PASSWD] = {0}; char buf[NSS_BUFLEN_PASSWD] = {0};
int rc; int rc;
rc = getpwuid_r(getuid(), &pwd, buf, NSS_BUFLEN_PASSWD, &pwdbuf); rc = getpwuid_r(getuid(), &pwd, buf, NSS_BUFLEN_PASSWD, &pwdbuf);
if (rc != 0) { if (rc != 0 || pwdbuf == NULL ) {
szPath = getenv("HOME"); szPath = getenv("HOME");
if (szPath == NULL) { if (szPath == NULL) {
return NULL; return NULL;
@ -250,13 +250,13 @@ int ssh_file_readaccess_ok(const char *file)
char *ssh_get_local_username(void) char *ssh_get_local_username(void)
{ {
struct passwd pwd; struct passwd pwd;
struct passwd *pwdbuf; struct passwd *pwdbuf = NULL;
char buf[NSS_BUFLEN_PASSWD]; char buf[NSS_BUFLEN_PASSWD];
char *name; char *name;
int rc; int rc;
rc = getpwuid_r(getuid(), &pwd, buf, NSS_BUFLEN_PASSWD, &pwdbuf); rc = getpwuid_r(getuid(), &pwd, buf, NSS_BUFLEN_PASSWD, &pwdbuf);
if (rc != 0) { if (rc != 0 || pwdbuf == NULL) {
return NULL; return NULL;
} }