#pragma once #ifndef MESSMER_CRYFS_CLI_H #define MESSMER_CRYFS_CLI_H #include "program_options/ProgramOptions.h" #include "../config/CryConfigFile.h" #include #include #include #include "CallAfterTimeout.h" namespace cryfs { class Cli final { public: Cli(cpputils::RandomGenerator &keyGenerator, const cpputils::SCryptSettings &scryptSettings); int main(int argc, char *argv[]); private: void _runFilesystem(const program_options::ProgramOptions &options); CryConfigFile _loadOrCreateConfig(const program_options::ProgramOptions &options); boost::filesystem::path _determineConfigFile(const program_options::ProgramOptions &options); std::string _getPassword(const program_options::ProgramOptions &options, std::function askPassword); static std::string _askPasswordForExistingFilesystem(); static std::string _askPasswordForNewFilesystem(); static bool _confirmPassword(const std::string &password); static bool _checkPassword(const std::string &password); void _showVersion(); void _initLogfile(const program_options::ProgramOptions &options); void _sanityChecks(const program_options::ProgramOptions &options); void _checkMountdirDoesntContainBasedir(const program_options::ProgramOptions &options); bool _pathContains(const boost::filesystem::path &parent, const boost::filesystem::path &child); void _checkDirAccessible(const boost::filesystem::path &dir, const std::string &name); std::shared_ptr _checkDirWriteable(const boost::filesystem::path &dir, const std::string &name); void _checkDirReadable(const boost::filesystem::path &dir, std::shared_ptr tempfile, const std::string &name); boost::optional> _createIdleCallback(boost::optional minutes, std::function callback); cpputils::RandomGenerator &_keyGenerator; cpputils::SCryptSettings _scryptSettings; DISALLOW_COPY_AND_ASSIGN(Cli); }; } #endif