Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTKeypair.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTKeypair.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_OTKEYPAIR_HPP
134 #define OPENTXS_CORE_CRYPTO_OTKEYPAIR_HPP
135 
136 #include <list>
137 #include <cstdint>
138 
139 // A nym contains a list of master credentials, via OTCredential.
140 // The whole purpose of a Nym is to be an identity, which can have
141 // master credentials.
142 //
143 // Each credential is like a master key for the Nym's identity,
144 // which can issue its own subkeys.
145 //
146 // Each subkey has 3 key pairs: encryption, signing, and authentication.
147 // Not all subcredentials are a subkey. For example, you might have a
148 // subcredential that uses Google Authenticator, and thus doesn't contain
149 // any keys, because it uses alternate methods for its own authentication.
150 //
151 // Each OTCredential contains a "master" subkey, and a list of subcredentials
152 // (some of them subkeys) signed by that master.
153 //
154 // The same class (subcredential/subkey) is used because there are master
155 // credentials and subcredentials, so we're using inheritance for
156 // "subcredential"
157 // and "subkey" to encapsulate the credentials, so we don't have to repeat code
158 // across both.
159 // We're using a "has-a" model here, since the OTCredential "has a" master
160 // subkey, and also "has a" list of subcredentials, some of which are subkeys.
161 //
162 // Each subcredential must be signed by the subkey that is the master key.
163 // Each subkey has 3 key pairs: encryption, signing, and authentication.
164 //
165 // Each key pair has 2 OTAsymmetricKeys (public and private.)
166 //
167 // I'm thinking that the Nym should also have a key pair (for whatever is
168 // its current key pair, copied from its credentials.)
169 //
170 // the master should never be able to do any actions except for sign subkeys.
171 // the subkeys, meanwhile should only be able to do actions, and not issue
172 // any new keys.
173 
174 namespace opentxs
175 {
176 
177 class OTASCIIArmor;
178 class OTAsymmetricKey;
179 class OTContract;
180 class OTIdentifier;
181 class OTPassword;
182 class OTPasswordData;
183 class OTSignature;
184 class OTSignatureMetadata;
185 class OTString;
186 
187 typedef std::list<OTAsymmetricKey*> listOfAsymmetricKeys;
188 
189 // Encapsulates public/private key (though often there may only be
190 // a public key present, unless the nym belongs to you.)
191 //
193 {
194  friend class OTLowLevelKeyData;
195 
196  OTAsymmetricKey* m_pkeyPublic; // This nym's public key
197  OTAsymmetricKey* m_pkeyPrivate; // This nym's private key
198 
199 public:
200  EXPORT bool MakeNewKeypair(int32_t nBits = 1024);
201  EXPORT bool ReEncrypt(const OTPassword& theExportPassword, bool bImporting,
202  OTString& strOutput); // Used when importing/exporting
203  // a Nym to/from the wallet.
204  EXPORT bool HasPublicKey();
205  EXPORT bool HasPrivateKey();
206  EXPORT const OTAsymmetricKey& GetPublicKey() const;
207  EXPORT const OTAsymmetricKey& GetPrivateKey() const;
208  EXPORT bool CalculateID(OTIdentifier& theOutput) const;
209  EXPORT bool SaveCertToString(
210  OTString& strOutput, const OTString* pstrReason = nullptr,
211  const OTPassword* pImportPassword = nullptr) const;
212  EXPORT bool SavePrivateKeyToString(
213  OTString& strOutput, const OTString* pstrReason = nullptr,
214  const OTPassword* pImportPassword = nullptr) const;
215  EXPORT bool SaveCertAndPrivateKeyToString(
216  OTString& strOutput, const OTString* pstrReason = nullptr,
217  const OTPassword* pImportPassword = nullptr);
218  // Load from local storage.
219  EXPORT bool LoadPrivateKey(const OTString& strFoldername,
220  const OTString& strFilename,
221  const OTString* pstrReason = nullptr,
222  const OTPassword* pImportPassword = nullptr);
223  EXPORT bool LoadPublicKey(const OTString& strFoldername,
224  const OTString& strFilename);
225  // LoadPrivateKeyFromCertString
226  //
227  // "escaped" means pre-pended with "- " as in: - -----BEGIN
228  // CERTIFICATE....
229  //
230  EXPORT bool LoadPrivateKeyFromCertString(
231  const OTString& strCert, bool bEscaped = true,
232  const OTString* pstrReason = nullptr,
233  const OTPassword* pImportPassword = nullptr);
234  // Load Public Key from Cert (file or string)
235  //
236  EXPORT bool LoadPublicKeyFromCertString(
237  const OTString& strCert, bool bEscaped = true,
238  const OTString* pstrReason = nullptr,
239  const OTPassword* pImportPassword = nullptr); // DOES handle bookends,
240  // AND escapes.
241  EXPORT bool LoadPublicKeyFromCertFile(
242  const OTString& strFoldername, const OTString& strFilename,
243  const OTString* pstrReason = nullptr,
244  const OTPassword* pImportPassword = nullptr); // DOES handle bookends.
246  const OTString& strInput, const OTString* pstrReason = nullptr,
247  const OTPassword* pImportPassword = nullptr);
248  // LOAD BOTH KEYS FROM CERT FILE
249  //
250  EXPORT bool LoadBothKeysFromCertFile(
251  const OTString& strFoldername, const OTString& strFilename,
252  const OTString* pstrReason = nullptr,
253  const OTPassword* pImportPassword = nullptr);
254 
256  OTString* pstrOutputCert = nullptr,
257  const OTString* pstrReason = nullptr,
258  const OTPassword* pImportPassword = nullptr);
259  // PUBLIC KEY
260 
261  // * Get the public key in ASCII-armored format --
262  // OTASCIIArmor
263  // * Get the public key in ASCII-armored format WITH bookends -- OTString
264  // - ------- BEGIN PUBLIC KEY --------
265  // Notice the "- " before the rest of the bookend starts.
266  EXPORT bool GetPublicKey(OTASCIIArmor& strKey) const;
267  EXPORT bool GetPublicKey(OTString& strKey, bool bEscaped = true) const;
268  // (Below) Decodes a public key from ASCII armor into an actual key pointer
269  // and sets that as the m_pKey on this object.
270  EXPORT bool SetPublicKey(const OTASCIIArmor& strKey);
271  EXPORT bool SetPublicKey(const OTString& strKey, bool bEscaped = false);
272  // (Above) Decodes a public key from bookended key string into an actual key
273  // pointer, and sets that as the m_pPublicKey on this object.
274  // This is the version that will handle the bookends ( -----BEGIN PUBLIC
275  // KEY-----)
276 
277  // PRIVATE KEY
278  // Get the private key in ASCII-armored format with bookends
279  // - ------- BEGIN ENCRYPTED PRIVATE KEY --------
280  // Notice the "- " before the rest of the bookend starts.
281  EXPORT bool GetPrivateKey(OTString& strKey, bool bEscaped = true) const;
282  EXPORT bool GetPrivateKey(OTASCIIArmor& strKey) const; // Get the private
283  // key in
284  // ASCII-armored
285  // format
286  // Decodes a private key from ASCII armor into an actual key pointer
287  // and sets that as the m_pPrivateKey on this object.
288  // This is the version that will handle the bookends ( -----BEGIN ENCRYPTED
289  // PRIVATE KEY-----)
290  EXPORT bool SetPrivateKey(const OTString& strKey, bool bEscaped = false);
291  EXPORT bool SetPrivateKey(const OTASCIIArmor& strKey); // Decodes a private
292  // key from ASCII
293  // armor into an
294  // actual key pointer
295  // and sets that as
296  // the m_pKey on this
297  // object.
298  // Only works if a private key is present.
299  //
300  EXPORT bool SignContract(OTContract& theContract,
301  const OTPasswordData* pPWData = nullptr);
302  EXPORT void SetMetadata(const OTSignatureMetadata& theMetadata);
303  EXPORT int32_t GetPublicKeyBySignature(
304  listOfAsymmetricKeys& listOutput, // inclusive means, return keys when
305  // theSignature has no metadata.
306  const OTSignature& theSignature, bool bInclusive = false) const;
307  EXPORT OTKeypair();
308  EXPORT ~OTKeypair();
309 };
310 
311 } // namespace opentxs
312 
313 #endif // OPENTXS_CORE_CRYPTO_OTKEYPAIR_HPP
EXPORT bool LoadCertAndPrivateKeyFromString(const OTString &strInput, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:294
EXPORT bool ReEncrypt(const OTPassword &theExportPassword, bool bImporting, OTString &strOutput)
Definition: OTKeypair.cpp:692
std::list< OTAsymmetricKey * > listOfAsymmetricKeys
EXPORT const OTAsymmetricKey & GetPublicKey() const
Definition: OTKeypair.cpp:229
EXPORT int32_t GetPublicKeyBySignature(listOfAsymmetricKeys &listOutput, const OTSignature &theSignature, bool bInclusive=false) const
Definition: OTKeypair.cpp:650
EXPORT bool SavePrivateKeyToString(OTString &strOutput, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr) const
Definition: OTKeypair.cpp:261
EXPORT bool SaveAndReloadBothKeysFromTempFile(OTString *pstrOutputCert=nullptr, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:333
EXPORT bool LoadBothKeysFromCertFile(const OTString &strFoldername, const OTString &strFilename, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:456
EXPORT bool HasPublicKey()
Definition: OTKeypair.cpp:213
EXPORT void SetMetadata(const OTSignatureMetadata &theMetadata)
Definition: OTKeypair.cpp:200
EXPORT bool SetPublicKey(const OTASCIIArmor &strKey)
Definition: OTKeypair.cpp:526
EXPORT bool CalculateID(OTIdentifier &theOutput) const
Definition: OTKeypair.cpp:643
EXPORT bool LoadPublicKeyFromCertString(const OTString &strCert, bool bEscaped=true, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:409
EXPORT const OTAsymmetricKey & GetPrivateKey() const
Definition: OTKeypair.cpp:236
EXPORT bool LoadPrivateKeyFromCertString(const OTString &strCert, bool bEscaped=true, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:396
EXPORT bool SetPrivateKey(const OTString &strKey, bool bEscaped=false)
Definition: OTKeypair.cpp:588
EXPORT bool SaveCertToString(OTString &strOutput, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr) const
Definition: OTKeypair.cpp:243
EXPORT bool HasPrivateKey()
Definition: OTKeypair.cpp:221
EXPORT bool SaveCertAndPrivateKeyToString(OTString &strOutput, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:277
EXPORT bool LoadPublicKey(const OTString &strFoldername, const OTString &strFilename)
Definition: OTKeypair.cpp:384
EXPORT bool LoadPrivateKey(const OTString &strFoldername, const OTString &strFilename, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:373
EXPORT bool MakeNewKeypair(int32_t nBits=1024)
Definition: OTKeypair.cpp:430
EXPORT bool SignContract(OTContract &theContract, const OTPasswordData *pPWData=nullptr)
Definition: OTKeypair.cpp:494
EXPORT bool LoadPublicKeyFromCertFile(const OTString &strFoldername, const OTString &strFilename, const OTString *pstrReason=nullptr, const OTPassword *pImportPassword=nullptr)
Definition: OTKeypair.cpp:419