Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTKeyring.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTKeyring.hpp
4  *
5  */
6 
7 /************************************************************
8  -----BEGIN PGP SIGNED MESSAGE-----
9  Hash: SHA1
10 
11  * OPEN TRANSACTIONS
12  *
13  * Financial Cryptography and Digital Cash
14  * Library, Protocol, API, Server, CLI, GUI
15  *
16  * -- Anonymous Numbered Accounts.
17  * -- Untraceable Digital Cash.
18  * -- Triple-Signed Receipts.
19  * -- Cheques, Vouchers, Transfers, Inboxes.
20  * -- Basket Currencies, Markets, Payment Plans.
21  * -- Signed, XML, Ricardian-style Contracts.
22  * -- Scripted smart contracts.
23  *
24  * Copyright (C) 2010-2013 by "Fellow Traveler" (A pseudonym)
25  *
26  * EMAIL:
28  *
29  * BITCOIN: 1NtTPVVjDsUfDWybS4BwvHpG2pdS9RnYyQ
30  *
31  * KEY FINGERPRINT (PGP Key in license file):
32  * 9DD5 90EB 9292 4B48 0484 7910 0308 00ED F951 BB8E
33  *
34  * OFFICIAL PROJECT WIKI(s):
35  * https://github.com/FellowTraveler/Moneychanger
36  * https://github.com/FellowTraveler/Open-Transactions/wiki
37  *
38  * WEBSITE:
39  * http://www.OpenTransactions.org/
40  *
41  * Components and licensing:
42  * -- Moneychanger..A Java client GUI.....LICENSE:.....GPLv3
43  * -- otlib.........A class library.......LICENSE:...LAGPLv3
44  * -- otapi.........A client API..........LICENSE:...LAGPLv3
45  * -- opentxs/ot....Command-line client...LICENSE:...LAGPLv3
46  * -- otserver......Server Application....LICENSE:....AGPLv3
47  * Github.com/FellowTraveler/Open-Transactions/wiki/Components
48  *
49  * All of the above OT components were designed and written by
50  * Fellow Traveler, with the exception of Moneychanger, which
51  * was contracted out to Vicky C ([email protected]).
52  * The open-source community has since actively contributed.
53  *
54  * -----------------------------------------------------
55  *
56  * LICENSE:
57  * This program is free software: you can redistribute it
58  * and/or modify it under the terms of the GNU Affero
59  * General Public License as published by the Free Software
60  * Foundation, either version 3 of the License, or (at your
61  * option) any later version.
62  *
63  * ADDITIONAL PERMISSION under the GNU Affero GPL version 3
64  * section 7: (This paragraph applies only to the LAGPLv3
65  * components listed above.) If you modify this Program, or
66  * any covered work, by linking or combining it with other
67  * code, such other code is not for that reason alone subject
68  * to any of the requirements of the GNU Affero GPL version 3.
69  * (==> This means if you are only using the OT API, then you
70  * don't have to open-source your code--only your changes to
71  * Open-Transactions itself must be open source. Similar to
72  * LGPLv3, except it applies to software-as-a-service, not
73  * just to distributing binaries.)
74  *
75  * Extra WAIVER for OpenSSL, Lucre, and all other libraries
76  * used by Open Transactions: This program is released under
77  * the AGPL with the additional exemption that compiling,
78  * linking, and/or using OpenSSL is allowed. The same is true
79  * for any other open source libraries included in this
80  * project: complete waiver from the AGPL is hereby granted to
81  * compile, link, and/or use them with Open-Transactions,
82  * according to their own terms, as long as the rest of the
83  * Open-Transactions terms remain respected, with regard to
84  * the Open-Transactions code itself.
85  *
86  * Lucre License:
87  * This code is also "dual-license", meaning that Ben Lau-
88  * rie's license must also be included and respected, since
89  * the code for Lucre is also included with Open Transactions.
90  * See Open-Transactions/src/otlib/lucre/LUCRE_LICENSE.txt
91  * The Laurie requirements are light, but if there is any
92  * problem with his license, simply remove the Lucre code.
93  * Although there are no other blind token algorithms in Open
94  * Transactions (yet. credlib is coming), the other functions
95  * will continue to operate.
96  * See Lucre on Github: https://github.com/benlaurie/lucre
97  * -----------------------------------------------------
98  * You should have received a copy of the GNU Affero General
99  * Public License along with this program. If not, see:
100  * http://www.gnu.org/licenses/
101  *
102  * If you would like to use this software outside of the free
103  * software license, please contact FellowTraveler.
104  * (Unfortunately many will run anonymously and untraceably,
105  * so who could really stop them?)
106  *
107  * DISCLAIMER:
108  * This program is distributed in the hope that it will be
109  * useful, but WITHOUT ANY WARRANTY; without even the implied
110  * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
111  * PURPOSE. See the GNU Affero General Public License for
112  * more details.
113 
114  -----BEGIN PGP SIGNATURE-----
115  Version: GnuPG v1.4.9 (Darwin)
116 
117  iQIcBAEBAgAGBQJRSsfJAAoJEAMIAO35UbuOQT8P/RJbka8etf7wbxdHQNAY+2cC
118  vDf8J3X8VI+pwMqv6wgTVy17venMZJa4I4ikXD/MRyWV1XbTG0mBXk/7AZk7Rexk
119  KTvL/U1kWiez6+8XXLye+k2JNM6v7eej8xMrqEcO0ZArh/DsLoIn1y8p8qjBI7+m
120  aE7lhstDiD0z8mwRRLKFLN2IH5rAFaZZUvj5ERJaoYUKdn4c+RcQVei2YOl4T0FU
121  LWND3YLoH8naqJXkaOKEN4UfJINCwxhe5Ke9wyfLWLUO7NamRkWD2T7CJ0xocnD1
122  sjAzlVGNgaFDRflfIF4QhBx1Ddl6wwhJfw+d08bjqblSq8aXDkmFA7HeunSFKkdn
123  oIEOEgyj+veuOMRJC5pnBJ9vV+7qRdDKQWaCKotynt4sWJDGQ9kWGWm74SsNaduN
124  TPMyr9kNmGsfR69Q2Zq/FLcLX/j8ESxU+HYUB4vaARw2xEOu2xwDDv6jt0j3Vqsg
125  x7rWv4S/Eh18FDNDkVRChiNoOIilLYLL6c38uMf1pnItBuxP3uhgY6COm59kVaRh
126  nyGTYCDYD2TK+fI9o89F1297uDCwEJ62U0Q7iTDp5QuXCoxkPfv8/kX6lS6T3y9G
127  M9mqIoLbIQ1EDntFv7/t6fUTS2+46uCrdZWbQ5RjYXdrzjij02nDmJAm2BngnZvd
128  kamH0Y/n11lCvo1oQxM+
129  =uSzz
130  -----END PGP SIGNATURE-----
131  **************************************************************/
132 
133 #ifndef OPENTXS_CORE_CRYPTO_OTKEYRING_HPP
134 #define OPENTXS_CORE_CRYPTO_OTKEYRING_HPP
135 
136 #include <string>
137 
138 // It's better to turn-on one of these, by using the Makefile,
139 // instead of hardcoding it here, which is entirely unnecessary.
140 //
141 // Nevertheless, I have added this comment anyway, in case that's
142 // what you want to do (for testing or whatever.)
143 //
144 //#define OT_KEYRING_WINDOWS 1
145 //#define OT_KEYRING_MAC 1
146 //#define OT_KEYRING_GNOME 1
147 //#define OT_KEYRING_KWALLET 1
148 //#define OT_KEYRING_FLATFILE 1
149 
150 namespace opentxs
151 {
152 
153 class OTString;
154 class OTPassword;
155 
157 {
158 public:
159  // NOTE: Normally the "username" in our context is related to the
160  // master key. OTCachedKey will call OTKeyring::RetrieveSecret, and
161  // will pass in probably a hash of the encrypted master key as the
162  // "username", and will retrieve the cleartext master key as the
163  // "password" (which it then uses as the password for all private
164  // keys in the wallet.)
165  //
166  // OT *already* caches its master key inside the OTCachedKey object
167  // itself, for X minutes. So then, why have this additional step,
168  // where we store it using whatever is the standard API for
169  // "protected memory" on the user's computer? The answer is, so that
170  // we can cache the password BETWEEN runs of the OT engine, and not
171  // just DURING the CURRENT run. For example, only this sort of
172  // caching makes it possible to set the user free from still having
173  // to enter his password for every run of an OT script.
174  //
175  // I don't even know if I recommend using this OTKeyring, since I
176  // don't necessarily trust the operating system's protected memory,
177  // and since the password is vulnerable during the time it is cached
178  // by the OS, since any other process ALSO running as the same user
179  // is able to ask the OS what the cached value is.
180  //
181  // (So be careful what software you run on your computer...)
182  // In fact, perhaps OT should ONLY run as a certain user, which is
183  // not used for anything else. Have it be setuid. That way, even if
184  // a hacker can trick you into running his trojan as your own user,
185  // he will be unable to query the OS for your master key, since your
186  // user is not what was used to cache the PW in the first place (a
187  // special "OT user" being used instead.) And thus cannot be used to
188  // retrieve it, either.
189  //
190  // INTERFACE:
191  //
192  EXPORT static bool StoreSecret(const OTString& strUser,
193  const OTPassword& thePassword,
194  const std::string& str_display);
195 
196  EXPORT static bool RetrieveSecret(const OTString& strUser,
197  OTPassword& thePassword,
198  const std::string& str_display);
199 
200  EXPORT static bool DeleteSecret(const OTString& strUser,
201  const std::string& str_display);
202 
203 private:
204 #if defined(OT_KEYRING_WINDOWS) && defined(_WIN32)
205  EXPORT static bool Windows_StoreSecret(const OTString& strUser,
206  const OTPassword& thePassword,
207  const std::string& str_display);
208 
209  EXPORT static bool Windows_RetrieveSecret(const OTString& strUser,
210  OTPassword& thePassword,
211  const std::string& str_display);
212 
213  EXPORT static bool Windows_DeleteSecret(const OTString& strUser,
214  const std::string& str_display);
215 //#endif
216 #elif defined(OT_KEYRING_MAC) && defined(__APPLE__)
217  static bool Mac_StoreSecret(const OTString& strUser,
218  const OTPassword& thePassword,
219  const std::string& str_display);
220 
221  static bool Mac_RetrieveSecret(const OTString& strUser,
222  OTPassword& thePassword,
223  const std::string& str_display);
224 
225  static bool Mac_DeleteSecret(const OTString& strUser,
226  const std::string& str_display);
227 //#endif
228 #elif defined(OT_KEYRING_IOS) && defined(__APPLE__)
229  static bool IOS_StoreSecret(const OTString& strUser,
230  const OTPassword& thePassword,
231  const std::string& str_display);
232 
233  static bool IOS_RetrieveSecret(const OTString& strUser,
234  OTPassword& thePassword,
235  const std::string& str_display);
236 
237  static bool IOS_DeleteSecret(const OTString& strUser,
238  const std::string& str_display);
239 //#endif
240 #elif defined(OT_KEYRING_GNOME)
241  static bool Gnome_StoreSecret(const OTString& strUser,
242  const OTPassword& thePassword,
243  const std::string& str_display);
244 
245  static bool Gnome_RetrieveSecret(const OTString& strUser,
246  OTPassword& thePassword,
247  const std::string& str_display); // unused
248 
249  static bool Gnome_DeleteSecret(const OTString& strUser,
250  const std::string& str_display); // unused
251  //#endif
252 #elif defined(OT_KEYRING_KWALLET)
253  static KWallet::Wallet* s_pWallet;
254  static KApplication* s_pApp;
255  static bool KWallet_StoreSecret(const OTString& strUser,
256  const OTPassword& thePassword,
257  const std::string& str_display);
258 
259  static bool KWallet_RetrieveSecret(const OTString& strUser,
260  OTPassword& thePassword,
261  const std::string& str_display);
262 
263  static bool KWallet_DeleteSecret(const OTString& strUser,
264  const std::string& str_display);
265 #elif defined(OT_KEYRING_FLATFILE) // Do not use! Unsafe! For testing only!
266  static bool FlatFile_StoreSecret(const OTString& strUser,
267  const OTPassword& thePassword,
268  const std::string& str_display);
269 
270  static bool FlatFile_RetrieveSecret(const OTString& strUser,
271  OTPassword& thePassword,
272  const std::string& str_display);
273 
274  static bool FlatFile_DeleteSecret(const OTString& strUser,
275  const std::string& str_display);
276 
277 public:
278  EXPORT static void FlatFile_SetPasswordFolder(std::string folder);
279  EXPORT static const char* FlatFile_GetPasswordFolder();
280 
281 private:
282  EXPORT static std::string s_str_passwd_folder; // NOTE: Do not ever use
283  // this. OT_KEYRING_FLATFILE
284  // should NEVER be defined!
285  // No! For testing only.
286 #endif
287 };
288 
289 } // namespace opentxs
290 
291 #endif // OPENTXS_CORE_CRYPTO_OTKEYRING_HPP
static EXPORT bool RetrieveSecret(const OTString &strUser, OTPassword &thePassword, const std::string &str_display)
Definition: OTKeyring.cpp:1365
static EXPORT bool DeleteSecret(const OTString &strUser, const std::string &str_display)
Definition: OTKeyring.cpp:1395
static EXPORT bool StoreSecret(const OTString &strUser, const OTPassword &thePassword, const std::string &str_display)
Definition: OTKeyring.cpp:1335