Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTASCIIArmor.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTASCIIArmor.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_OTASCIIARMOR_HPP
134 #define OPENTXS_CORE_CRYPTO_OTASCIIARMOR_HPP
135 
136 #include "../OTString.hpp"
137 
138 #include <memory>
139 
140 namespace opentxs
141 {
142 
143 class OTASCIIArmor;
144 class OTData;
145 class OTEnvelope;
146 class OTPayload;
147 
148 namespace OTDB
149 {
150 class OTPacker;
151 }
152 
153 typedef std::map<int64_t, OTASCIIArmor*> mapOfArmor;
154 
155 extern const char* OT_BEGIN_ARMORED;
156 extern const char* OT_END_ARMORED;
157 
158 extern const char* OT_BEGIN_ARMORED_escaped;
159 extern const char* OT_END_ARMORED_escaped;
160 
161 extern const char* OT_BEGIN_SIGNED;
162 extern const char* OT_BEGIN_SIGNED_escaped;
163 
164 // The natural state of OTASCIIArmor is in compressed and base64-encoded, string
165 // form.
166 // It is derived from OTString. The Get() method returns a base64-encoded
167 // string.
168 // The Set() method assumes that you are PASSING IN a base64-encoded string.
169 // The constructors assume that you are passing in a base64-encoded string.
170 class OTASCIIArmor : public OTString
171 {
172 public:
173  static OTDB::OTPacker* GetPacker();
174 
175  EXPORT OTASCIIArmor();
176  EXPORT OTASCIIArmor(const char* szValue);
177  EXPORT OTASCIIArmor(const OTData& theValue);
178  EXPORT OTASCIIArmor(const OTPayload& theValue);
179  EXPORT OTASCIIArmor(const OTString& strValue);
180  EXPORT OTASCIIArmor(const OTASCIIArmor& strValue);
181  EXPORT OTASCIIArmor(const OTEnvelope& theEnvelope);
182  EXPORT virtual ~OTASCIIArmor();
183 
184  using OTString::swap;
185 
186  EXPORT OTASCIIArmor& operator=(const char* szValue);
187  EXPORT OTASCIIArmor& operator=(const OTData& theValue);
188  EXPORT OTASCIIArmor& operator=(const OTString& strValue);
189  EXPORT OTASCIIArmor& operator=(const OTASCIIArmor& strValue);
190 
191  EXPORT bool LoadFromFile(const OTString& foldername,
192  const OTString& filename);
193  EXPORT bool LoadFrom_ifstream(std::ifstream& fin);
194  EXPORT bool SaveTo_ofstream(std::ofstream& fout);
195  EXPORT bool LoadFromExactPath(const std::string& filename);
196  EXPORT bool SaveToExactPath(const std::string& filename);
197  // Let's say you don't know if the input string is raw base64, or if it has
198  // bookends
199  // on it like -----BEGIN BLAH BLAH ...
200  // And if it DOES have Bookends, you don't know if they are escaped: -
201  // -----BEGIN ...
202  // Let's say you just want an easy function that will figure that crap out,
203  // and load the
204  // contents up properly into an OTASCIIArmor object. (That's what this
205  // function will do.)
206  //
207  EXPORT static bool LoadFromString(
208  OTASCIIArmor& ascArmor, const OTString& strInput,
209  std::string str_bookend = "-----BEGIN"); // todo hardcoding.
210  // str_bookend is a
211  // default. So you
212  // could make it more
213  // specific like,
214  // -----BEGIN ENCRYPTED
215  // KEY (or whatever.)
216 
217  EXPORT bool LoadFromString(OTString& theStr, bool bEscaped = false,
218  const // This sub-string determines where the
219  // content starts, when loading.
220  std::string str_override =
221  "-----BEGIN"); // "-----BEGIN" is the default
222  // "content start" substr.
223  // Todo: hardcoding.
224 
225  EXPORT bool WriteArmoredString(
226  OTString& strOutput, const // for "-----BEGIN OT LEDGER-----", str_type
227  // would contain ==> "LEDGER" <==
228  std::string str_type, // There's no default, to force you to enter the
229  // right string.
230  bool bEscaped = false) const;
231 
232  EXPORT bool WriteArmoredFile(const OTString& foldername,
233  const OTString& filename,
234  const // for "-----BEGIN OT LEDGER-----",
235  // str_type would contain ==> "LEDGER"
236  // <==
237  std::string str_type, // There's no default, to
238  // force you to enter the
239  // right string.
240  bool bEscaped = false) const;
241 
242  // This function will base64 DECODE the string contents (This class is a
243  // string)
244  // and return them as BINARY in theData
245  // Should be called "Get From Internal String Into Data"
246  //
247  EXPORT bool GetData(OTData& theData, bool bLineBreaks = true) const;
248  EXPORT bool GetAndUnpackData(OTData& theData,
249  bool bLineBreaks = true) const;
250 
251  // This function will base64 ENCODE theData,
252  // and then Set() that as the string contents.
253  // Should be called "Encode Data And Set As Internal String"
254  EXPORT bool SetData(const OTData& theData, bool bLineBreaks = true);
255  EXPORT bool SetAndPackData(const OTData& theData, bool bLineBreaks = true);
256 
257  // This function will base64 DECODE the string contents
258  // and return them as a STRING in theData
259  //
260  EXPORT bool GetString(OTString& theData, bool bLineBreaks = true) const;
261  EXPORT bool GetAndUnpackString(OTString& theData,
262  bool bLineBreaks = true) const;
263 
264  // This function will base64 ENCODE the STRING stored in theData,
265  // and then Set() that as this string contents.
266  //
267  EXPORT bool SetString(const OTString& theData, bool bLineBreaks = true);
268  EXPORT bool SetAndPackString(const OTString& theData,
269  bool bLineBreaks = true);
270 
271  EXPORT bool GetStringMap(std::map<std::string, std::string>& the_map,
272  bool bLineBreaks = true) const;
273  EXPORT bool GetAndUnpackStringMap(
274  std::map<std::string, std::string>& the_map,
275  bool bLineBreaks = true) const;
276 
277  EXPORT bool SetStringMap(const std::map<std::string, std::string>& the_map,
278  bool bLineBreaks = true);
279  EXPORT bool SetAndPackStringMap(
280  const std::map<std::string, std::string>& the_map,
281  bool bLineBreaks = true);
282 
283 private:
284  static std::unique_ptr<OTDB::OTPacker> s_pPacker;
285 };
286 
287 } // namespace opentxs
288 
289 #endif // OPENTXS_CORE_CRYPTO_OTASCIIARMOR_HPP
EXPORT bool LoadFromExactPath(const std::string &filename)
EXPORT bool SetAndPackString(const OTString &theData, bool bLineBreaks=true)
const char * OT_BEGIN_ARMORED_escaped
const char * OT_BEGIN_SIGNED_escaped
EXPORT bool GetAndUnpackStringMap(std::map< std::string, std::string > &the_map, bool bLineBreaks=true) const
virtual EXPORT ~OTASCIIArmor()
const char * OT_END_ARMORED
EXPORT bool GetStringMap(std::map< std::string, std::string > &the_map, bool bLineBreaks=true) const
const char * OT_END_ARMORED_escaped
EXPORT bool WriteArmoredString(OTString &strOutput, const std::string str_type, bool bEscaped=false) const
EXPORT bool SetString(const OTString &theData, bool bLineBreaks=true)
static EXPORT bool LoadFromString(OTASCIIArmor &ascArmor, const OTString &strInput, std::string str_bookend="-----BEGIN")
EXPORT bool LoadFromFile(const OTString &foldername, const OTString &filename)
EXPORT bool SaveToExactPath(const std::string &filename)
EXPORT bool SetAndPackData(const OTData &theData, bool bLineBreaks=true)
EXPORT OTASCIIArmor & operator=(const char *szValue)
EXPORT bool SaveTo_ofstream(std::ofstream &fout)
EXPORT bool GetAndUnpackData(OTData &theData, bool bLineBreaks=true) const
const char * OT_BEGIN_SIGNED
EXPORT bool LoadFrom_ifstream(std::ifstream &fin)
static OTDB::OTPacker * GetPacker()
EXPORT bool GetData(OTData &theData, bool bLineBreaks=true) const
EXPORT bool WriteArmoredFile(const OTString &foldername, const OTString &filename, const std::string str_type, bool bEscaped=false) const
std::map< int64_t, OTASCIIArmor * > mapOfArmor
Definition: Mint.hpp:146
EXPORT bool SetData(const OTData &theData, bool bLineBreaks=true)
EXPORT bool GetString(OTString &theData, bool bLineBreaks=true) const
EXPORT bool SetStringMap(const std::map< std::string, std::string > &the_map, bool bLineBreaks=true)
EXPORT bool GetAndUnpackString(OTString &theData, bool bLineBreaks=true) const
const char * OT_BEGIN_ARMORED
EXPORT bool SetAndPackStringMap(const std::map< std::string, std::string > &the_map, bool bLineBreaks=true)
void swap(OTString &rhs)
Definition: OTString.cpp:1018