Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTData.cpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTData.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 "OTData.hpp"
136 #include "crypto/OTASCIIArmor.hpp"
137 #include "crypto/OTPassword.hpp"
138 #include "util/Assert.hpp"
139 #include <utility>
140 #include <cstring>
141 
142 namespace opentxs
143 {
144 
146  : data_(nullptr)
147  , position_(0)
148  , size_(0)
149 {
150 }
151 
152 OTData::OTData(const OTData& source)
153  : data_(nullptr)
154  , position_(0)
155  , size_(0)
156 {
157  Assign(source);
158 }
159 
161  : data_(nullptr)
162  , position_(0)
163  , size_(0)
164 {
165  if (source.Exists()) {
166  source.GetData(*this);
167  }
168 }
169 
170 OTData::OTData(const void* data, uint32_t size)
171  : data_(nullptr)
172  , position_(0)
173  , size_(0)
174 {
175  Assign(data, size);
176 }
177 
179 {
180  Release_Data();
181 }
182 
183 bool OTData::operator==(const OTData& rhs) const
184 {
185  if (size_ != rhs.size_) {
186  return false;
187  }
188 
189  if (size_ == 0 && rhs.size_ == 0) {
190  return true;
191  }
192  // TODO security: replace memcmp with a more secure
193  // version. Still, though, I am managing it internal to
194  // the class.
195  if (std::memcmp(data_, rhs.data_, size_) == 0) {
196  return true;
197  }
198 
199  return false;
200 }
201 
202 bool OTData::operator!=(const OTData& rhs) const
203 {
204  return !operator==(rhs);
205 }
206 
207 // First use reset() to set the internal position to 0.
208 // Then you pass in the buffer where the results go.
209 // You pass in the length of that buffer.
210 // It returns how much was actually read.
211 // If you start at position 0, and read 100 bytes, then
212 // you are now on position 100, and the next OTfread will
213 // proceed from that position. (Unless you reset().)
214 uint32_t OTData::OTfread(uint8_t* data, uint32_t size)
215 {
216  OT_ASSERT(data != nullptr && size > 0);
217 
218  uint32_t sizeToRead = 0;
219 
220  if (data_ != nullptr && position_ < GetSize()) {
221  // If the size is 20, and position is 5 (I've already read the first 5
222  // bytes) then the size remaining to read is 15. That is, GetSize()
223  // minus position_.
224  sizeToRead = GetSize() - position_;
225 
226  if (size < sizeToRead) {
227  sizeToRead = size;
228  }
229  OTPassword::safe_memcpy(data, size,
230  static_cast<uint8_t*>(data_) + position_,
231  static_cast<uint32_t>(sizeToRead));
232  position_ += sizeToRead;
233  }
234 
235  return sizeToRead;
236 }
237 
238 void OTData::zeroMemory() const
239 {
240  if (data_ != nullptr) {
241  OTPassword::zeroMemory(data_, size_);
242  }
243 }
244 
246 {
247  if (data_ != nullptr) {
248  // For security reasons, we clear the memory to 0 when deleting the
249  // object. (Seems smart.)
250  OTPassword::zeroMemory(data_, size_);
251  delete[] static_cast<uint8_t*>(data_);
252  // If data_ was already nullptr, no need to re-Initialize().
253  Initialize();
254  }
255 }
256 
258 {
259  Release_Data();
260 }
261 
263 {
264  swap(rhs);
265  return *this;
266 }
267 
269 {
270  std::swap(data_, rhs.data_);
271  std::swap(position_, rhs.position_);
272  std::swap(size_, rhs.size_);
273 }
274 
275 void OTData::Assign(const OTData& source)
276 {
277  // can't assign to self.
278  if (&source == this) {
279  return;
280  }
281 
282  if (!source.IsEmpty()) {
283  Assign(source.data_, source.size_);
284  }
285  else {
286  // Otherwise if it's empty, then empty this also.
287  Release();
288  }
289 }
290 
291 bool OTData::IsEmpty() const
292 {
293  return size_ < 1;
294 }
295 
296 void OTData::Assign(const void* data, uint32_t size)
297 {
298  // This releases all memory and zeros out all members.
299  Release();
300 
301  if (data != nullptr && size > 0) {
302  data_ = static_cast<void*>(new uint8_t[size]);
303  OT_ASSERT(data_ != nullptr);
304  OTPassword::safe_memcpy(data_, size, data, size);
305  size_ = size;
306  }
307  // TODO: else error condition. Could just ASSERT() this.
308 }
309 
310 bool OTData::Randomize(uint32_t size)
311 {
312  Release(); // This releases all memory and zeros out all members.
313  if (size > 0) {
314  data_ = static_cast<void*>(new uint8_t[size]);
315  OT_ASSERT(data_ != nullptr);
316 
317  if (!OTPassword::randomizeMemory_uint8(static_cast<uint8_t*>(data_),
318  size)) {
319  // randomizeMemory already logs, so I'm not logging again twice
320  // here.
321  delete[] static_cast<uint8_t*>(data_);
322  data_ = nullptr;
323  return false;
324  }
325 
326  size_ = size;
327  return true;
328  }
329  // else error condition. Could just ASSERT() this.
330  return false;
331 }
332 
333 void OTData::Concatenate(const void* data, uint32_t size)
334 {
335  OT_ASSERT(data != nullptr);
336  OT_ASSERT(size > 0);
337 
338  if (size == 0) {
339  return;
340  }
341 
342  if (size_ == 0) {
343  Assign(data, size);
344  return;
345  }
346 
347  void* newData = nullptr;
348  uint32_t newSize = GetSize() + size;
349 
350  if (newSize > 0) {
351  newData = static_cast<void*>(new uint8_t[newSize]);
352  OT_ASSERT(newData != nullptr);
353  OTPassword::zeroMemory(newData, newSize);
354  }
355  // If there's a new memory buffer (for the combined..)
356  if (newData != nullptr) {
357  // if THIS object has data inside of it...
358  if (!IsEmpty()) {
359  // Copy THIS object into the new
360  // buffer, starting at the
361  // beginning.
362  OTPassword::safe_memcpy(newData, newSize, data_, GetSize());
363  }
364 
365  // Next we copy the data being appended...
366  OTPassword::safe_memcpy(static_cast<uint8_t*>(newData) + GetSize(),
367  newSize - GetSize(), data, size);
368  }
369 
370  if (data_ != nullptr) {
371  delete[] static_cast<uint8_t*>(data_);
372  }
373 
374  data_ = newData;
375  size_ = newSize;
376 }
377 
379 {
380  if (rhs.GetSize() > 0) {
381  Concatenate(rhs.data_, rhs.GetSize());
382  }
383  return *this;
384 }
385 
386 void OTData::SetSize(uint32_t size)
387 {
388  Release();
389 
390  if (size > 0) {
391  data_ = static_cast<void*>(new uint8_t[size]);
392  OT_ASSERT(data_ != nullptr);
393  OTPassword::zeroMemory(data_, size);
394  size_ = size;
395  }
396 }
397 
398 } // namespace opentxs
EXPORT void Release_Data()
Definition: OTData.cpp:245
EXPORT void swap(OTData &rhs)
Definition: OTData.cpp:268
EXPORT OTData & operator=(OTData rhs)
Definition: OTData.cpp:262
EXPORT void zeroMemory()
Definition: OTPassword.cpp:281
EXPORT OTData()
Definition: OTData.cpp:145
static EXPORT bool randomizeMemory_uint8(uint8_t *destination, uint32_t size)
Definition: OTPassword.cpp:881
EXPORT bool operator!=(const OTData &rhs) const
Definition: OTData.cpp:202
EXPORT bool Exists() const
Definition: OTString.cpp:1035
virtual EXPORT ~OTData()
Definition: OTData.cpp:178
void Initialize()
Definition: OTData.hpp:192
EXPORT void Assign(const OTData &source)
Definition: OTData.cpp:275
EXPORT bool operator==(const OTData &rhs) const
Definition: OTData.cpp:183
#define OT_ASSERT(x)
Definition: Assert.hpp:150
void SetSize(uint32_t size)
Definition: OTData.cpp:386
EXPORT bool GetData(OTData &theData, bool bLineBreaks=true) const
EXPORT OTData & operator+=(const OTData &rhs)
Definition: OTData.cpp:378
EXPORT uint32_t OTfread(uint8_t *data, uint32_t size)
Definition: OTData.cpp:214
EXPORT bool IsEmpty() const
Definition: OTData.cpp:291
virtual EXPORT void Release()
Definition: OTData.cpp:257
EXPORT bool Randomize(uint32_t size)
Definition: OTData.cpp:310
static EXPORT void * safe_memcpy(void *dest, uint32_t dsize, const void *src, uint32_t ssize, bool zeroSource=false)
Definition: OTPassword.cpp:357
EXPORT void Concatenate(const void *data, uint32_t size)
Definition: OTData.cpp:333
uint32_t GetSize() const
Definition: OTData.hpp:174
EXPORT void zeroMemory() const
Definition: OTData.cpp:238