Fixed crash on startup when running in an environment that doesn't have /home/heinzi set (e.g. an empty env), https://github.com/cryfs/cryfs/issues/374

This commit is contained in:
Sebastian Messmer 2021-02-23 08:25:15 -08:00
parent 41ab58faf3
commit c6a69ae36b
2 changed files with 3 additions and 1 deletions

View File

@ -5,6 +5,7 @@ Fixed bugs:
* Fixed determining the user's homedir: If $HOME and the /etc/passwd entry for the current user contradict each other, now $HOME takes preference over /etc/passwd. * Fixed determining the user's homedir: If $HOME and the /etc/passwd entry for the current user contradict each other, now $HOME takes preference over /etc/passwd.
* Fix Android compilation, https://github.com/cryfs/cryfs/issues/345 * Fix Android compilation, https://github.com/cryfs/cryfs/issues/345
* Remove cryfs-stats tool which isn't ready yet and could destroy the file system * Remove cryfs-stats tool which isn't ready yet and could destroy the file system
* Fixed crash on startup when running in an environment that doesn't have $HOME set (e.g. an empty env), https://github.com/cryfs/cryfs/issues/374
Version 0.10.2 Version 0.10.2

View File

@ -9,7 +9,8 @@ using std::string;
#include <pwd.h> #include <pwd.h>
namespace { namespace {
bf::path _get_home_directory() { bf::path _get_home_directory() {
string homedir = getenv("HOME"); const char* homedir_ = getenv("HOME");
string homedir = (homedir_ == nullptr) ? "" : homedir_;
if (homedir == "") { if (homedir == "") {
// try the /etc/passwd entry // try the /etc/passwd entry
struct passwd* pwd = getpwuid(getuid()); struct passwd* pwd = getpwuid(getuid());