mirror of
https://github.com/RetroShare/RetroShare.git
synced 2025-01-16 18:07:11 -05:00
337 lines
13 KiB
C++
337 lines
13 KiB
C++
/*******************************************************************************
|
|
* libretroshare/src/retroshare: rsinit.h *
|
|
* *
|
|
* libretroshare: retroshare core library *
|
|
* *
|
|
* Copyright 2004-2006 by Robert Fernie <retroshare@lunamutt.com> *
|
|
* *
|
|
* 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 option) any later version. *
|
|
* *
|
|
* This program is distributed in the hope that it will be useful, *
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
|
|
* MERCHANTABILITY or 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 <https://www.gnu.org/licenses/>. *
|
|
* *
|
|
*******************************************************************************/
|
|
#ifndef RETROSHARE_INIT_INTERFACE_H
|
|
#define RETROSHARE_INIT_INTERFACE_H
|
|
|
|
// Initialize ok, result >= 0
|
|
#define RS_INIT_OK 0 // Initialize ok
|
|
#define RS_INIT_HAVE_ACCOUNT 1 // Initialize ok, have account
|
|
// Initialize failed, result < 0
|
|
#define RS_INIT_AUTH_FAILED -1 // AuthGPG::InitAuth failed
|
|
#define RS_INIT_BASE_DIR_ERROR -2 // AuthGPG::InitAuth failed
|
|
#define RS_INIT_NO_KEYRING -3 // Keyring is empty. Need to import it.
|
|
|
|
|
|
/****
|
|
* #define RS_USE_PGPSSL 1
|
|
***/
|
|
|
|
#define RS_USE_PGPSSL 1
|
|
|
|
#include <stdint.h>
|
|
#include <list>
|
|
#include <map>
|
|
#include <vector>
|
|
#include <retroshare/rstypes.h>
|
|
|
|
struct RsLoginHelper;
|
|
|
|
/**
|
|
* Pointer to global instance of RsLoginHelper
|
|
* @jsonapi{development}
|
|
*/
|
|
extern RsLoginHelper* rsLoginHelper;
|
|
|
|
|
|
/*!
|
|
* Initialisation Class (not publicly disclosed to RsIFace)
|
|
*/
|
|
class RsInit
|
|
{
|
|
public:
|
|
enum LoadCertificateStatus : uint8_t
|
|
{
|
|
OK, /// Everything go as expected, no error occurred
|
|
ERR_ALREADY_RUNNING, /// Another istance is running already
|
|
ERR_CANT_ACQUIRE_LOCK, /// Another istance is already running?
|
|
ERR_UNKOWN /// Unkown error, maybe password is wrong?
|
|
};
|
|
|
|
/* reorganised RsInit system */
|
|
|
|
/*!
|
|
* PreLogin
|
|
* Call before init retroshare, initialises rsinitconfig's public attributes
|
|
*/
|
|
static void InitRsConfig();
|
|
|
|
/*!
|
|
* Should be called to load up ssl cert and private key, and intialises gpg
|
|
* this must be called before accessing rsserver (e.g. ::startupretroshare)
|
|
* @param argc passed from executable
|
|
* @param argv commandline arguments passed to executable
|
|
* @param strictCheck set to true if you want rs to continue executing if
|
|
* invalid argument passed and vice versa
|
|
* @return RS_INIT_...
|
|
*/
|
|
static int InitRetroShare(int argc, char **argv, bool strictCheck=true);
|
|
|
|
static bool isPortable();
|
|
static bool isWindowsXP();
|
|
static bool collectEntropy(uint32_t bytes) ;
|
|
|
|
/*
|
|
* Setup Hidden Location;
|
|
*/
|
|
static void SetHiddenLocation(const std::string& hiddenaddress, uint16_t port, bool useBob);
|
|
|
|
static bool LoadPassword(const std::string& passwd) ;
|
|
|
|
/*
|
|
* Final Certificate load. This can be called if:
|
|
* a) InitRetroshare() returns RS_INIT_HAVE_ACCOUNT -> autoLoad/password Set.
|
|
* b) or LoadPassword()
|
|
*
|
|
* This uses the preferredId from RsAccounts.
|
|
* This wrapper also locks the profile before finalising the login
|
|
*/
|
|
static LoadCertificateStatus LockAndLoadCertificates(
|
|
bool autoLoginNT, std::string& lockFilePath );
|
|
|
|
// Post Login Options
|
|
static bool getStartMinimised();
|
|
|
|
static int getSslPwdLen();
|
|
static bool getAutoLogin();
|
|
static void setAutoLogin(bool autoLogin);
|
|
static bool RsClearAutoLogin() ;
|
|
|
|
private:
|
|
/** @brief Lock profile directory
|
|
* param[in] accountDir account directory to lock
|
|
* param[out] lockFilePath path of the created lock-file
|
|
*/
|
|
static LoadCertificateStatus LockConfigDirectory(
|
|
const std::string& accountDir, std::string& lockFilePath);
|
|
|
|
/// @brief Unlock profile directory
|
|
static void UnlockConfigDirectory();
|
|
|
|
static int LoadCertificates(bool autoLoginNT);
|
|
};
|
|
|
|
|
|
|
|
/* Seperate static Class for dealing with Accounts */
|
|
|
|
class RsAccountsDetail;
|
|
|
|
class RsAccounts
|
|
{
|
|
public:
|
|
/// Should be called once before everything else.
|
|
static bool init(const std::string &opt_base_dir, int& error_code);
|
|
|
|
/**
|
|
* @brief ConfigDirectory (usually ~/.retroshare) you can call this method
|
|
* even before initialisation (you can't with some other methods)
|
|
* @see RsAccountsDetail::PathBaseDirectory()
|
|
*/
|
|
static std::string ConfigDirectory();
|
|
|
|
/**
|
|
* @brief Get current account id. Beware that an account may be selected
|
|
* without actually logging in.
|
|
* @jsonapi{development,unauthenticated}
|
|
* @param[out] id storage for current account id
|
|
* @return false if account hasn't been selected yet, true otherwise
|
|
*/
|
|
static bool getCurrentAccountId(RsPeerId &id);
|
|
|
|
/**
|
|
* @brief DataDirectory
|
|
* you can call this method even before initialisation (you can't with some other methods)
|
|
* @param check if set to true and directory does not exist, return empty string
|
|
* @return path where global platform independent files are stored, like bdboot.txt or webinterface files
|
|
*/
|
|
static std::string systemDataDirectory(bool check = true);
|
|
static std::string PGPDirectory();
|
|
|
|
/**
|
|
* @brief Get available PGP identities id list
|
|
* @jsonapi{development,unauthenticated}
|
|
* @param[out] pgpIds storage for PGP id list
|
|
* @return true on success, false otherwise
|
|
*/
|
|
static int GetPGPLogins(std::list<RsPgpId> &pgpIds);
|
|
static int GetPGPLoginDetails(const RsPgpId& id, std::string &name, std::string &email);
|
|
static bool GeneratePGPCertificate(const std::string&, const std::string& email, const std::string& passwd, RsPgpId &pgpId, const int keynumbits, std::string &errString);
|
|
|
|
/**
|
|
* @brief Export full encrypted PGP identity to file
|
|
* @jsonapi{development}
|
|
* @param[in] filePath path of certificate file
|
|
* @param[in] pgpId PGP id to export
|
|
* @return true on success, false otherwise
|
|
*/
|
|
static bool ExportIdentity( const std::string& filePath,
|
|
const RsPgpId& pgpId );
|
|
|
|
/**
|
|
* @brief Import full encrypted PGP identity from file
|
|
* @jsonapi{development,unauthenticated}
|
|
* @param[in] filePath path of certificate file
|
|
* @param[out] pgpId storage for the PGP fingerprint of the imported key
|
|
* @param[out] errorMsg storage for eventual human readable error message
|
|
* @return true on success, false otherwise
|
|
*/
|
|
static bool ImportIdentity(
|
|
const std::string& filePath, RsPgpId& pgpId, std::string& errorMsg );
|
|
|
|
/**
|
|
* @brief Import full encrypted PGP identity from string
|
|
* @jsonapi{development,unauthenticated}
|
|
* @param[in] data certificate string
|
|
* @param[out] pgpId storage for the PGP fingerprint of the imported key
|
|
* @param[out] errorMsg storage for eventual human readable error message
|
|
* @return true on success, false otherwise
|
|
*/
|
|
static bool importIdentityFromString(
|
|
const std::string& data, RsPgpId& pgpId,
|
|
std::string& errorMsg );
|
|
|
|
/**
|
|
* @brief Export full encrypted PGP identity to string
|
|
* @jsonapi{development}
|
|
* @param[out] data storage for certificate string
|
|
* @param[in] pgpId PGP id to export
|
|
* @param[in] includeSignatures true to include signatures
|
|
* @param[out] errorMsg storage for eventual human readable error message
|
|
* @return true on success, false otherwise
|
|
*/
|
|
static bool exportIdentityToString(
|
|
std::string& data, const RsPgpId& pgpId, std::string& errorMsg,
|
|
bool includeSignatures = true );
|
|
|
|
static void GetUnsupportedKeys(std::map<std::string,std::vector<std::string> > &unsupported_keys);
|
|
static bool CopyGnuPGKeyrings() ;
|
|
|
|
// Rs Accounts
|
|
static bool SelectAccount(const RsPeerId& id);
|
|
static bool GetPreferredAccountId(RsPeerId &id);
|
|
static bool GetAccountIds(std::list<RsPeerId> &ids);
|
|
|
|
static bool GetAccountDetails(const RsPeerId &id, RsPgpId &gpgId, std::string &gpgName, std::string &gpgEmail, std::string &location);
|
|
|
|
static bool createNewAccount(
|
|
const RsPgpId& pgp_id, const std::string& org,
|
|
const std::string& loc, const std::string& country,
|
|
bool ishiddenloc, bool is_auto_tor, const std::string& passwd,
|
|
RsPeerId &sslId, std::string &errString );
|
|
|
|
static void storeSelectedAccount() ;
|
|
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
// All methods bellow can only be called ones SelectAccount() as been called. //
|
|
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
static bool getCurrentAccountOptions(bool& is_hidden,bool& is_tor_auto,bool& is_first_time) ;
|
|
|
|
static bool checkCreateAccountDirectory(); // Generate the hierarchy of directories below ~/.retroshare/[SSL dir]/
|
|
static bool isHiddenNode() ; // true if the running node is a hidden node. Used to choose which services to start.
|
|
static bool isTorAuto() ; // true if the running node is a hidden node using automated Tor management
|
|
|
|
static std::string AccountDirectory(); // linux: ~/.retroshare/[SSL dir]/
|
|
static std::string AccountKeysDirectory(); // linux: ~/.retroshare/[SSL dir]/keys/
|
|
static std::string AccountPathCertFile(); // linux: ~/.retroshare/[SSL dir]/keys/user_cert.pem
|
|
static std::string AccountPathKeyFile(); // linux: ~/.retroshare/[SSL dir]/keys/user_pk.pem
|
|
static std::string AccountLocationName();
|
|
|
|
static bool lockPreferredAccount() ; // are these methods any useful??
|
|
static void unlockPreferredAccount() ;
|
|
|
|
private:
|
|
static RsAccountsDetail* rsAccountsDetails;
|
|
};
|
|
|
|
/**
|
|
* Pointer to global instance of RsAccounts needed to expose JSON API, as all
|
|
* the members of this class are static you should call them directly without
|
|
* using this pointer in the other parts of the code
|
|
* @jsonapi{development}
|
|
*/
|
|
extern RsAccounts* rsAccounts;
|
|
|
|
|
|
/**
|
|
* This helper class have been implemented because there was not reasonable way
|
|
* to login in the API that could be exposed via JSON API
|
|
*/
|
|
struct RsLoginHelper
|
|
{
|
|
/**
|
|
* @brief Normal way to attempt login
|
|
* @jsonapi{development,manualwrapper}
|
|
* @param[in] account Id of the account to which attempt login
|
|
* @param[in] password Password for the given account
|
|
* @return RsInit::OK if login attempt success, error code otherwhise
|
|
*/
|
|
RsInit::LoadCertificateStatus attemptLogin(
|
|
const RsPeerId& account, const std::string& password );
|
|
|
|
struct Location : RsSerializable
|
|
{
|
|
RsPeerId mLocationId;
|
|
RsPgpId mPgpId;
|
|
std::string mLocationName;
|
|
std::string mPpgName;
|
|
|
|
/// @see RsSerializable::serial_process
|
|
void serial_process( RsGenericSerializer::SerializeJob j,
|
|
RsGenericSerializer::SerializeContext& ctx );
|
|
};
|
|
|
|
/**
|
|
* @brief Get locations and associated information
|
|
* @jsonapi{development,unauthenticated}
|
|
* @param[out] locations storage for the retrived locations
|
|
*/
|
|
void getLocations(std::vector<RsLoginHelper::Location>& locations);
|
|
|
|
/**
|
|
* @brief Creates a new RetroShare location, and log in once is created
|
|
* @jsonapi{development,manualwrapper}
|
|
* @param[inout] location provide input information to generate the location
|
|
* and storage to output the data of the generated location
|
|
* @param[in] password to protect and unlock the associated PGP key
|
|
* @param[out] errorMessage if some error occurred human readable error
|
|
* message
|
|
* @param[in] makeHidden pass true to create an hidden location. UNTESTED!
|
|
* @param[in] makeAutoTor pass true to create an automatically configured
|
|
* Tor hidden location. UNTESTED!
|
|
* @return true if success, false otherwise
|
|
*/
|
|
bool createLocation( RsLoginHelper::Location& location,
|
|
const std::string& password, std::string& errorMessage,
|
|
bool makeHidden = false, bool makeAutoTor = false );
|
|
|
|
/**
|
|
* @brief Check if RetroShare is already logged in, this usually return true
|
|
* after a successfull attemptLogin() and before closeSession()
|
|
* @jsonapi{development,unauthenticated}
|
|
* @return true if already logged in, false otherwise
|
|
*/
|
|
bool isLoggedIn();
|
|
};
|
|
|
|
#endif
|