Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTCheque.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTCheque.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_OTCHEQUE_HPP
134 #define OPENTXS_CORE_OTCHEQUE_HPP
135 
136 #include "OTTrackable.hpp"
137 
138 namespace opentxs
139 {
140 
141 class OTCheque : public OTTrackable
142 {
143 private: // Private prevents erroneous use by other classes.
144  typedef OTTrackable ot_super;
145 
146 protected:
147  virtual int32_t ProcessXMLNode(irr::io::IrrXMLReader*& xml);
148 
149  int64_t m_lAmount;
151  OTIdentifier m_RECIPIENT_USER_ID; // Optional. If present, must match
152  // depositor's user ID.
154  OTIdentifier m_REMITTER_USER_ID; // In the case of vouchers (cashier's
155  // cheques) we store the Remitter's ID.
158 
159 public:
160  inline void SetAsVoucher(const OTIdentifier& remitterUserID,
161  const OTIdentifier& remitterAcctID)
162  {
163  m_REMITTER_USER_ID = remitterUserID;
164  m_REMITTER_ACCT_ID = remitterAcctID;
165  m_bHasRemitter = true;
166  m_strContractType = "VOUCHER";
167  }
168  inline const OTString& GetMemo() const
169  {
170  return m_strMemo;
171  }
172  inline const int64_t& GetAmount() const
173  {
174  return m_lAmount;
175  }
176  inline const OTIdentifier& GetRecipientUserID() const
177  {
178  return m_RECIPIENT_USER_ID;
179  }
180  inline bool HasRecipient() const
181  {
182  return m_bHasRecipient;
183  }
184  inline const OTIdentifier& GetRemitterUserID() const
185  {
186  return m_REMITTER_USER_ID;
187  }
188  inline const OTIdentifier& GetRemitterAcctID() const
189  {
190  return m_REMITTER_ACCT_ID;
191  }
192  inline bool HasRemitter() const
193  {
194  return m_bHasRemitter;
195  }
196 
197  // A cheque HAS NO "Recipient Asset Acct ID", since the recipient's account
198  // (where he deposits
199  // the cheque) is not known UNTIL the time of the deposit. It's certain not
200  // known at the time
201  // that the cheque is written...
202 
203  // Calling this function is like writing a check...
204  EXPORT bool IssueCheque(
205  const int64_t& lAmount, const int64_t& lTransactionNum,
206  const time64_t& VALID_FROM,
207  const time64_t& VALID_TO, // The expiration date (valid from/to dates.)
208  const OTIdentifier& SENDER_ACCT_ID, // The asset account the cheque is
209  // drawn on.
210  const OTIdentifier& SENDER_USER_ID, // This ID must match the user ID on
211  // the asset account,
212  // AND must verify the cheque signature with that user's key.
213  const OTString& strMemo, // Optional memo field.
214  const OTIdentifier* pRECIPIENT_USER_ID = nullptr); // Recipient
215  // optional. (Might
216  // be a blank
217  // cheque.)
218 
219  EXPORT void CancelCheque(); // You still need to re-sign the cheque after
220  // doing this.
221 
222  // From OTTrackable (parent class of this)
223  /*
224  // A cheque can be written offline, provided you have a transaction
225  // number handy to write it with. (Necessary to prevent double-spending.)
226  inline int64_t GetTransactionNum() const { return
227  m_lTransactionNum; }
228  inline const OTIdentifier& GetSenderAcctID() { return
229  m_SENDER_ACCT_ID; }
230  inline const OTIdentifier& GetSenderUserID() { return
231  m_SENDER_USER_ID; }
232  */
233 
234  // From OTInstrument (parent class of OTTrackable, parent class of this)
235  /*
236  OTInstrument(const OTIdentifier& SERVER_ID, const OTIdentifier& ASSET_ID)
237  : OTContract()
238 
239  inline const OTIdentifier& GetAssetID() const { return m_AssetTypeID; }
240  inline const OTIdentifier& GetServerID() const { return m_ServerID; }
241 
242  inline time64_t GetValidFrom() const { return m_VALID_FROM; }
243  inline time64_t GetValidTo() const { return m_VALID_TO; }
244 
245  bool VerifyCurrentDate(); // Verify the current date against the VALID FROM
246  / TO dates.
247  */
248  EXPORT OTCheque();
249  EXPORT OTCheque(const OTIdentifier& SERVER_ID,
250  const OTIdentifier& ASSET_ID);
251  EXPORT virtual ~OTCheque();
252 
253  void InitCheque();
254  virtual void Release();
255  void Release_Cheque();
256  virtual void UpdateContents(); // Before transmission or serialization, this
257  // is where the token saves its contents
258 
259  // virtual bool SaveContractWallet(FILE* fl);
260  virtual bool SaveContractWallet(std::ofstream& ofs) const;
261 };
262 
263 } // namespace opentxs
264 
265 #endif // OPENTXS_CORE_OTCHEQUE_HPP
virtual int32_t ProcessXMLNode(irr::io::IrrXMLReader *&xml)
Definition: OTCheque.cpp:197
virtual void UpdateContents()
Definition: OTCheque.cpp:148
OTString m_strMemo
Definition: OTCheque.hpp:150
void Release_Cheque()
Definition: OTCheque.cpp:395
virtual bool SaveContractWallet(std::ofstream &ofs) const
Definition: OTCheque.cpp:421
const int64_t & GetAmount() const
Definition: OTCheque.hpp:172
OTIdentifier m_REMITTER_ACCT_ID
Definition: OTCheque.hpp:156
const OTIdentifier & GetRemitterAcctID() const
Definition: OTCheque.hpp:188
bool HasRecipient() const
Definition: OTCheque.hpp:180
int64_t time64_t
Definition: Common.hpp:209
const OTString & GetMemo() const
Definition: OTCheque.hpp:168
EXPORT void CancelCheque()
Definition: OTCheque.cpp:295
OTIdentifier m_REMITTER_USER_ID
Definition: OTCheque.hpp:154
OTString m_strContractType
Definition: OTContract.hpp:178
bool HasRemitter() const
Definition: OTCheque.hpp:192
const OTIdentifier & GetRemitterUserID() const
Definition: OTCheque.hpp:184
void SetAsVoucher(const OTIdentifier &remitterUserID, const OTIdentifier &remitterAcctID)
Definition: OTCheque.hpp:160
EXPORT bool IssueCheque(const int64_t &lAmount, const int64_t &lTransactionNum, const time64_t &VALID_FROM, const time64_t &VALID_TO, const OTIdentifier &SENDER_ACCT_ID, const OTIdentifier &SENDER_USER_ID, const OTString &strMemo, const OTIdentifier *pRECIPIENT_USER_ID=nullptr)
Definition: OTCheque.cpp:322
virtual void Release()
Definition: OTCheque.cpp:411
OTIdentifier m_RECIPIENT_USER_ID
Definition: OTCheque.hpp:151
EXPORT OTCheque()
Definition: OTCheque.cpp:373
const OTIdentifier & GetRecipientUserID() const
Definition: OTCheque.hpp:176
virtual EXPORT ~OTCheque()
Definition: OTCheque.cpp:416