Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTPayload.cpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTPayload.cpp
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 #include "stdafx.hpp"
134 
135 #include "OTPayload.hpp"
136 
137 #include "util/OTDataCheck.hpp"
138 #include "crypto/OTEnvelope.hpp"
139 #include "OTLog.hpp"
140 #include "OTMessage.hpp"
141 
142 namespace opentxs
143 {
144 
146  : OTData()
147 {
148 }
149 
150 OTPayload::OTPayload(const void* pNewData, uint32_t nNewSize)
151  : OTData(pNewData, nNewSize)
152 {
153 }
154 
156  : OTData(rhs)
157 {
158 }
159 
161  : OTData(theSource)
162 {
163 }
164 
166 {
167 }
168 
169 uint32_t OTPayload::ReadBytesFrom(OTData& theData, uint32_t lSize)
170 {
171  OT_ASSERT(theData.GetSize() >= lSize);
172 
173  // The size requested to read MUST be less or equal to size of theData
174  if (theData.GetSize() < lSize) abort();
175 
176  OTPayload& refPayload = (OTPayload&)theData; // todo fix this cast.
177 
178  // Copy from theData to this, up until lSize
179  Assign(refPayload.GetPayloadPointer(), lSize);
180 
181  // Create a temp var, starting from theData+lSize, copying to the end of
182  // theData
183  OTData TEMPdata((uint8_t*)refPayload.GetPayloadPointer() + lSize,
184  theData.GetSize() - lSize);
185 
186  // theData is assigned to TEMPdata (thus removing from it the bytes that we
187  // just read into this.)
188  theData.Assign(TEMPdata);
189 
190  return lSize;
191 }
192 
193 // Envelope copied into payload to prepare for sending.
194 bool OTPayload::SetEnvelope(const OTEnvelope& theEnvelope)
195 {
196  OTASCIIArmor theArmor;
197 
198  if (theEnvelope.GetAsciiArmoredData(theArmor)) {
199  uint32_t lSize = theArmor.GetLength() + 1; //+1 for the null terminater
200 
201  if (theArmor.GetLength()) {
202  SetPayloadSize(lSize + 1); // +1 for the checksum byte.
203 
204  // Copy it in.
205  memcpy((void*)GetPointer(), theArmor.Get(), lSize);
206 
207  // Add the checksum, success.
208  AppendChecksum((OT_BYTE*)GetPointer(), lSize);
209  return true;
210  }
211  }
212  return false;
213 }
214 
216 {
217  uint32_t lSize =
218  theMessage.m_strRawFile.GetLength() + 1; //+1 for the null terminater
219 
220  if (theMessage.m_strRawFile.GetLength()) {
221  SetPayloadSize(lSize + 1); // +1 for the checksum byte.
222  memcpy((void*)GetPointer(), theMessage.m_strRawFile.Get(), lSize);
223 
224  // Add the checksum
225  AppendChecksum((OT_BYTE*)GetPointer(), lSize);
226  return true;
227  }
228  return false;
229 }
230 
231 // Envelope retrieved from payload.
232 bool OTPayload::GetEnvelope(OTEnvelope& theEnvelope) const
233 {
234  // validate checksum
235  uint32_t lSize = GetSize();
236  uint32_t lIndex = lSize - 2; // the index to where the nullptr terminator
237  // SHOULD be if they
238  // sent us a base64-encoded string, containing an encrypted message. (which
239  // we expect...)
240 
241  // (lSize-1 would be the location of the checksum at the end.)
242  if (0 == lSize) return false;
243 
244  if (IsChecksumValid((OT_BYTE*)GetPointer(), (uint32_t)lSize)) {
245  // We add the null-terminator ourselves at this point, for security
246  // reasons,
247  // since we will process the data, soon after this function, as a
248  // string.
249  ((OT_BYTE*)GetPointer())[lIndex] = 0;
250 
251  theEnvelope.m_dataContents.Release();
252 
253  OTASCIIArmor theArmor;
254  // Why is this safe, where I cast the Payload data pointer as
255  // a char * and tell the data object to set itself from that?
256  // Because (1) I just validated the checksum, and
257  // (2) There place where the nullptr should be, I set to 0, by hand,
258  // just above 2 lines. So when this set operation occurs, the
259  // farthest it will go is to that 0.
260  theArmor.Set((const char*)GetPointer());
261 
262  // Todo NOTE: If I ever want to process bookends here instead of
263  // assuming they aren't there,
264  // IT'S VERY EASY!! All I have to do is call theArmor.LoadFromString
265  // instead of theArmor.Set.
266 
267  // Now the ascii-armored string that was sent across is decoded back to
268  // binary into the
269  // Envelope object.
270  theEnvelope.SetAsciiArmoredData(theArmor);
271  return true;
272  }
273  else {
274  otErr << "Invalid Checksum in OTPayload::GetEnvelope\n";
275  return false;
276  }
277 }
278 
279 // Message retrieved from Payload
281 {
282  // validate checksum
283  uint32_t lSize = GetSize();
284  uint32_t lIndex = lSize - 2; // the index to where the nullptr terminator
285  // SHOULD be if they
286  // sent us a string like they were supposed to. (A contract.)
287  // (nSize-1 would be the location of the checksum at the end.)
288  if (0 == lSize) return false;
289 
290  if (IsChecksumValid((OT_BYTE*)GetPointer(), (uint32_t)lSize)) {
291  // We add the null-terminator ourselves at this point, for security
292  // reasons,
293  // since we will process the data, after this point, as a string.
294  ((OT_BYTE*)GetPointer())[lIndex] = 0;
295 
296  theMessage.Release();
297 
298  // Why is this safe, where I cast the Payload data pointer as
299  // a char * and tell the string to set itself from that?
300  // Because (1) I just validated the checksum, and
301  // (2) There place where the nullptr should be, I set to 0, by hand,
302  // just above 2 lines. So when this set operation occurs, the
303  // farthest it will go is to that 0.
304  theMessage.m_strRawFile.Set((const char*)GetPointer());
305  return true;
306  }
307  else {
308  otErr << "Invalid Checksum in OTPayload::GetMessage\n";
309  return false;
310  }
311 }
312 
313 void OTPayload::SetPayloadSize(uint32_t lNewSize)
314 {
315  SetSize(lNewSize);
316 }
317 
318 const void* OTPayload::GetPayloadPointer() const
319 {
320  return GetPointer();
321 }
322 
323 } // namespace opentxs
EXPORT bool GetEnvelope(OTEnvelope &theEnvelope) const
Definition: OTPayload.cpp:232
EXPORT bool SetMessagePayload(const OTMessage &theMessage)
Definition: OTPayload.cpp:215
EXPORT uint32_t GetLength() const
Definition: OTString.cpp:1040
EXPORT bool SetAsciiArmoredData(const OTASCIIArmor &theArmoredText, bool bLineBreaks=true)
Definition: OTEnvelope.cpp:178
EXPORT uint32_t ReadBytesFrom(OTData &theData, uint32_t lSize)
Definition: OTPayload.cpp:169
EXPORT void Set(const char *data, uint32_t enforcedMaxLength=0)
Definition: OTString.cpp:1055
EXPORT void Assign(const OTData &source)
Definition: OTData.cpp:275
EXPORT bool GetAsciiArmoredData(OTASCIIArmor &theArmoredText, bool bLineBreaks=true) const
Definition: OTEnvelope.cpp:162
EXPORT OT_BOOL IsChecksumValid(OT_BYTE *buffer, uint32_t size)
#define OT_ASSERT(x)
Definition: Assert.hpp:150
void SetSize(uint32_t size)
Definition: OTData.cpp:386
EXPORT void SetPayloadSize(uint32_t lNewSize)
Definition: OTPayload.cpp:313
EXPORT bool GetMessagePayload(OTMessage &theMessage) const
Definition: OTPayload.cpp:280
EXPORT const char * Get() const
Definition: OTString.cpp:1045
EXPORT const void * GetPayloadPointer() const
Definition: OTPayload.cpp:318
OTLOG_IMPORT OTLogStream otErr
const void * GetPointer() const
Definition: OTData.hpp:162
virtual EXPORT void Release()
Definition: OTContract.cpp:277
void AppendChecksum(OT_BYTE *buffer, uint32_t &size)
EXPORT bool SetEnvelope(const OTEnvelope &theEnvelope)
Definition: OTPayload.cpp:194
virtual EXPORT void Release()
Definition: OTData.cpp:257
uint32_t GetSize() const
Definition: OTData.hpp:174
uint8_t OT_BYTE
virtual EXPORT ~OTPayload()
Definition: OTPayload.cpp:165