2008-01-07 09:09:04 +01:00
|
|
|
/*****************************************************************************
|
|
|
|
* Author: Valient Gough <vgough@pobox.com>
|
|
|
|
*
|
|
|
|
*****************************************************************************
|
2012-10-03 07:12:17 +02:00
|
|
|
* Copyright (c) 2004-2012, Valient Gough
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU Lesser General Public License as published by the
|
|
|
|
* Free Software Foundation, either version 3 of the License, or (at your
|
2013-10-20 00:35:26 +02:00
|
|
|
* option) any later version.
|
2008-01-07 09:09:04 +01:00
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
2012-10-03 07:12:17 +02:00
|
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2008-01-07 09:09:04 +01:00
|
|
|
*/
|
2013-10-20 00:35:26 +02:00
|
|
|
|
2008-01-07 09:09:04 +01:00
|
|
|
#ifndef _FileUtils_incl_
|
|
|
|
#define _FileUtils_incl_
|
|
|
|
|
2013-01-29 04:07:54 +01:00
|
|
|
#include "base/Interface.h"
|
|
|
|
#include "cipher/CipherKey.h"
|
|
|
|
#include "fs/encfs.h"
|
|
|
|
#include "fs/FSConfig.h"
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-03-05 07:29:58 +01:00
|
|
|
namespace encfs {
|
|
|
|
|
2008-01-07 09:09:04 +01:00
|
|
|
// true if the path points to an existing node (of any type)
|
2013-10-20 00:35:26 +02:00
|
|
|
bool fileExists(const char *fileName);
|
2008-01-07 09:09:04 +01:00
|
|
|
// true if path is a directory
|
2013-10-20 00:35:26 +02:00
|
|
|
bool isDirectory(const char *fileName);
|
2008-01-07 09:09:04 +01:00
|
|
|
// true if starts with '/'
|
2013-10-20 00:35:26 +02:00
|
|
|
bool isAbsolutePath(const char *fileName);
|
2008-01-07 09:09:04 +01:00
|
|
|
// pointer to just after the last '/'
|
2013-10-20 00:35:26 +02:00
|
|
|
const char *lastPathElement(const char *name);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
std::string parentDirectory(const std::string &path);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
|
|
|
// ask the user for permission to create the directory. If they say ok, then
|
|
|
|
// do it and return true.
|
2013-10-20 00:35:26 +02:00
|
|
|
bool userAllowMkdir(const char *dirPath, mode_t mode);
|
|
|
|
bool userAllowMkdir(int promptno, const char *dirPath, mode_t mode);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-03-05 07:36:32 +01:00
|
|
|
class CipherV1;
|
2010-08-30 08:32:05 +02:00
|
|
|
class DirNode;
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
struct EncFS_Root {
|
2013-03-05 07:36:32 +01:00
|
|
|
shared_ptr<CipherV1> cipher;
|
2012-04-26 04:18:26 +02:00
|
|
|
CipherKey volumeKey;
|
2012-08-22 06:46:36 +02:00
|
|
|
shared_ptr<DirNode> root;
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2012-04-26 04:18:26 +02:00
|
|
|
EncFS_Root();
|
|
|
|
~EncFS_Root();
|
2008-01-07 09:09:04 +01:00
|
|
|
};
|
|
|
|
|
2012-08-22 06:46:36 +02:00
|
|
|
typedef shared_ptr<EncFS_Root> RootPtr;
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
enum ConfigMode {
|
2012-04-26 04:18:26 +02:00
|
|
|
Config_Prompt,
|
|
|
|
Config_Standard,
|
|
|
|
Config_Paranoia
|
2009-12-07 20:15:23 +01:00
|
|
|
};
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
struct EncFS_Opts {
|
2012-04-26 04:18:26 +02:00
|
|
|
std::string rootDir;
|
|
|
|
bool createIfNotFound; // create filesystem if not found
|
2013-10-20 00:35:26 +02:00
|
|
|
bool idleTracking; // turn on idle monitoring of filesystem
|
|
|
|
bool mountOnDemand; // mounting on-demand
|
|
|
|
bool delayMount; // delay initial mount
|
2012-04-26 04:18:26 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool checkKey; // check crypto key decoding
|
|
|
|
bool forceDecode; // force decode on MAC block failures
|
2012-04-26 04:18:26 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
std::string passwordProgram; // path to password program (or empty)
|
|
|
|
bool useStdin; // read password from stdin rather then prompting
|
|
|
|
bool annotate; // print annotation line prompt to stderr.
|
2012-04-26 04:18:26 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool ownerCreate; // set owner of new files to caller
|
2012-04-26 04:18:26 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool reverseEncryption; // Reverse encryption
|
2012-04-26 04:18:26 +02:00
|
|
|
|
|
|
|
ConfigMode configMode;
|
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
EncFS_Opts() {
|
2012-04-26 04:18:26 +02:00
|
|
|
createIfNotFound = true;
|
|
|
|
idleTracking = false;
|
|
|
|
mountOnDemand = false;
|
2013-10-03 07:10:23 +02:00
|
|
|
delayMount = false;
|
2012-04-26 04:18:26 +02:00
|
|
|
checkKey = true;
|
|
|
|
forceDecode = false;
|
|
|
|
useStdin = false;
|
|
|
|
annotate = false;
|
|
|
|
ownerCreate = false;
|
|
|
|
reverseEncryption = false;
|
|
|
|
configMode = Config_Prompt;
|
|
|
|
}
|
2008-01-07 09:09:04 +01:00
|
|
|
};
|
|
|
|
|
2010-08-30 08:32:05 +02:00
|
|
|
/*
|
|
|
|
Read existing config file. Looks for any supported configuration version.
|
2012-04-26 04:18:26 +02:00
|
|
|
*/
|
2013-10-20 00:35:26 +02:00
|
|
|
ConfigType readConfig(const std::string &rootDir, EncfsConfig &config);
|
2010-08-30 08:32:05 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
Save the configuration. Saves back as the same configuration type as was
|
|
|
|
read from.
|
2012-04-26 04:18:26 +02:00
|
|
|
*/
|
2013-10-20 00:35:26 +02:00
|
|
|
bool saveConfig(const std::string &rootdir, const EncfsConfig &config);
|
2010-08-30 08:32:05 +02:00
|
|
|
|
2008-01-07 09:09:04 +01:00
|
|
|
class EncFS_Context;
|
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
RootPtr initFS(EncFS_Context *ctx, const shared_ptr<EncFS_Opts> &opts);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
RootPtr createConfig(EncFS_Context *ctx, const shared_ptr<EncFS_Opts> &opts);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
void showFSInfo(const EncfsConfig &config);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool readV4Config(const char *configFile, EncfsConfig &config,
|
|
|
|
struct ConfigInfo *);
|
2008-01-07 09:09:04 +01:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool readV5Config(const char *configFile, EncfsConfig &config,
|
|
|
|
struct ConfigInfo *);
|
2012-04-26 04:34:15 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool readV6Config(const char *configFile, EncfsConfig &config,
|
|
|
|
struct ConfigInfo *);
|
2008-04-13 22:35:57 +02:00
|
|
|
|
2013-10-20 00:35:26 +02:00
|
|
|
bool readProtoConfig(const char *configFile, EncfsConfig &config,
|
|
|
|
struct ConfigInfo *);
|
2013-03-05 07:29:58 +01:00
|
|
|
|
|
|
|
} // namespace encfs
|
2008-01-07 09:09:04 +01:00
|
|
|
#endif
|