// Copyright (c) 2014-2016 The Dash Core developers // Distributed under the MIT/X11 software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #ifndef _KEEPASS_H_ #define _KEEPASS_H_ #include "support/allocators/secure.h" #include static const int KEEPASS_CRYPTO_KEY_SIZE = 32; static const int KEEPASS_CRYPTO_BLOCK_SIZE = 16; static const int KEEPASS_HTTP_CONNECT_TIMEOUT = 30; static const unsigned int DEFAULT_KEEPASS_HTTP_PORT = 19455; static const char* KEEPASS_HTTP_HOST = "localhost"; class CKeePassIntegrator { bool bIsActive; unsigned int nPort; SecureString sKeyBase64; SecureString sKey; SecureString sUrl; //SecureString sSubmitUrl; std::string sKeePassId; std::string sKeePassEntryName; class CKeePassRequest { UniValue requestObj; std::string sType; std::string sIV; SecureString sKey; void init(); public: void addStrParameter(std::string sName, std::string sValue); // Regular void addStrParameter(std::string sName, SecureString sValue); // Encrypt std::string getJson(); CKeePassRequest(SecureString sKey, std::string sType) { this->sKey = sKey; this->sType = sType; init(); }; }; class CKeePassEntry { SecureString uuid; SecureString name; SecureString login; SecureString password; public: CKeePassEntry(SecureString uuid, SecureString name, SecureString login, SecureString password) : uuid(uuid), name(name), login(login), password(password) { } SecureString getUuid() { return uuid; } SecureString getName() { return name; } SecureString getLogin() { return login; } SecureString getPassword() { return password; } }; class CKeePassResponse { bool bSuccess; std::string sType; std::string sIV; SecureString sKey; void parseResponse(std::string sResponse); public: UniValue responseObj; CKeePassResponse(SecureString sKey, std::string sResponse) { this->sKey = sKey; parseResponse(sResponse); } bool getSuccess() { return bSuccess; } SecureString getSecureStr(std::string sName); std::string getStr(std::string sName); std::vector getEntries(); SecureString decrypt(std::string sValue); // DecodeBase64 and decrypt arbitrary string value }; static SecureString generateRandomKey(size_t nSize); static std::string constructHTTPPost(const std::string& strMsg, const std::map& mapRequestHeaders); void doHTTPPost(const std::string& sRequest, int& nStatus, std::string& sResponse); void rpcTestAssociation(bool bTriggerUnlock); std::vector rpcGetLogins(); void rpcSetLogin(const SecureString& strWalletPass, const SecureString& sEntryId); public: CKeePassIntegrator(); void init(); static SecureString generateKeePassKey(); void rpcAssociate(std::string& sId, SecureString& sKeyBase64); SecureString retrievePassphrase(); void updatePassphrase(const SecureString& sWalletPassphrase); }; extern CKeePassIntegrator keePassInt; #endif