Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTMessage.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTMessage.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_OTMESSAGE_HPP
134 #define OPENTXS_CORE_OTMESSAGE_HPP
135 
136 #include "crypto/OTASCIIArmor.hpp"
137 #include "OTContract.hpp"
138 #include "OTNumList.hpp"
139 
140 namespace opentxs
141 {
142 
143 class OTPasswordData;
144 class OTPseudonym;
145 
146 class OTMessage : public OTContract
147 {
148 protected:
149  virtual bool SaveContractWallet(std::ofstream& ofs) const;
150  // virtual bool SaveContractWallet(FILE* fl);
151  virtual int32_t ProcessXMLNode(irr::io::IrrXMLReader*& xml);
152 
153  virtual void UpdateContents();
154 
156 
157 public:
158  EXPORT OTMessage();
159  EXPORT virtual ~OTMessage();
160 
161  virtual bool VerifyContractID() const;
162 
163  EXPORT virtual bool SignContract(const OTPseudonym& theNym,
164  const OTPasswordData* pPWData = nullptr);
165  EXPORT virtual bool VerifySignature(
166  const OTPseudonym& theNym,
167  const OTPasswordData* pPWData = nullptr) const;
168 
169  EXPORT bool HarvestTransactionNumbers(
170  OTPseudonym& theNym,
171  bool bHarvestingForRetry, // false until positively asserted.
172  bool bReplyWasSuccess, // false until positively asserted.
173  bool bReplyWasFailure, // false until positively asserted.
174  bool bTransactionWasSuccess, // false until positively asserted.
175  bool bTransactionWasFailure) const; // false until positively asserted.
176 
177  // So the message can get the list of numbers from the Nym, before sending,
178  // that should be listed as acknowledged that the server reply has already
179  // been
180  // seen for those request numbers.
181  // IMPORTANT NOTE: The Server ID is used to lookup the numbers from the Nym.
182  // Therefore,
183  // make sure that OTMessage::m_strServerID is set BEFORE calling this
184  // function. (It will
185  // ASSERT if you don't...)
186  //
187  EXPORT void SetAcknowledgments(OTPseudonym& theNym);
188 
189  OTString m_strCommand; // perhaps @register is the string for "reply to
190  // register" a-ha
191  OTString m_strServerID; // This is sent with every message for security
192  // reasons.
193  OTString m_strNymID; // The hash of the user's public key... or x509 cert.
194  OTString m_strNymboxHash; // Sometimes in a server reply as FYI, sometimes
195  // in user message for validation purposes.
196  OTString m_strInboxHash; // Sometimes in a server reply as FYI, sometimes in
197  // user message for validation purposes.
198  OTString m_strOutboxHash; // Sometimes in a server reply as FYI, sometimes
199  // in user message for validation purposes.
200  OTString m_strNymID2; // If the user requests public key of another user.
201  // ALSO used for MARKET ID sometimes.
202  OTString m_strNymPublicKey; // The user's public key... or x509 cert.
203  OTString m_strAssetID; // The hash of the contract for whatever digital
204  // asset is referenced.
205  OTString m_strAcctID; // The unique ID of an asset account.
207  OTString m_strRequestNum; // Every user has a request number. This prevents
208  // messages from
209  // being intercepted and repeated by attackers.
210 
211  OTASCIIArmor m_ascInReferenceTo; // If the server responds to a user
212  // command, he sends
213  // it back to the user here in ascii armored format.
214  OTASCIIArmor m_ascPayload; // If the reply needs to include a payload (such
215  // as a new account
216  // or a message envelope or request from another user etc) then
217  // it can be put here in ascii-armored format.
218  OTASCIIArmor m_ascPayload2; // Sometimes one payload just isn't enough.
219 
220  // This list of request numbers is stored for optimization, so client/server
221  // can communicate about
222  // which messages have been received, and can avoid certain downloads, such
223  // as replyNotice Box Receipts.
224  //
225  OTNumList m_AcknowledgedReplies; // Client request: list of server replies
226  // client has already seen.
227  // Server reply: list of client-acknowledged replies (so client knows that
228  // server knows.)
229 
230  int64_t m_lNewRequestNum; // If you are SENDING a message, you set
231  // m_strRequestNum. (For all msgs.)
232  // Server Reply for all messages copies that same number into
233  // m_strRequestNum;
234  // But if this is a SERVER REPLY to the "getRequestNumber" MESSAGE, the
235  // "request number" expected in that reply is stored HERE in
236  // m_lNewRequestNum;
237  int64_t m_lDepth; // For Market-related messages... (Plus for usage
238  // credits.) Also used by getBoxReceipt
239  int64_t m_lTransactionNum; // For Market-related messages... Also used by
240  // getBoxReceipt
241 
242  bool m_bSuccess; // When the server replies to the client, this may be true
243  // or false
244  bool m_bBool; // Some commands need to send a bool. This variable is for
245  // those.
246  int64_t m_lTime; // Timestamp when the message was signed.
247 };
248 
249 } // namespace opentxs
250 
251 #endif // OPENTXS_CORE_OTMESSAGE_HPP
int64_t m_lNewRequestNum
Definition: OTMessage.hpp:230
OTASCIIArmor m_ascPayload2
Definition: OTMessage.hpp:218
virtual bool SaveContractWallet(std::ofstream &ofs) const
Definition: OTMessage.cpp:3953
virtual EXPORT bool SignContract(const OTPseudonym &theNym, const OTPasswordData *pPWData=nullptr)
Definition: OTMessage.cpp:3873
OTString m_strAcctID
Definition: OTMessage.hpp:205
virtual EXPORT bool VerifySignature(const OTPseudonym &theNym, const OTPasswordData *pPWData=nullptr) const
Definition: OTMessage.cpp:3898
OTString m_strInboxHash
Definition: OTMessage.hpp:196
EXPORT void SetAcknowledgments(OTPseudonym &theNym)
Definition: OTMessage.cpp:262
int64_t m_lTransactionNum
Definition: OTMessage.hpp:239
OTString m_strAssetID
Definition: OTMessage.hpp:203
virtual EXPORT ~OTMessage()
Definition: OTMessage.cpp:3947
OTNumList m_AcknowledgedReplies
Definition: OTMessage.hpp:225
OTString m_strNymID2
Definition: OTMessage.hpp:200
OTString m_strOutboxHash
Definition: OTMessage.hpp:198
OTASCIIArmor m_ascInReferenceTo
Definition: OTMessage.hpp:211
virtual void UpdateContents()
Definition: OTMessage.cpp:296
OTString m_strServerID
Definition: OTMessage.hpp:191
OTString m_strNymboxHash
Definition: OTMessage.hpp:194
OTString m_strRequestNum
Definition: OTMessage.hpp:207
OTASCIIArmor m_ascPayload
Definition: OTMessage.hpp:214
EXPORT bool HarvestTransactionNumbers(OTPseudonym &theNym, bool bHarvestingForRetry, bool bReplyWasSuccess, bool bReplyWasFailure, bool bTransactionWasSuccess, bool bTransactionWasFailure) const
Definition: OTMessage.cpp:158
OTString m_strCommand
Definition: OTMessage.hpp:189
OTString m_strNymPublicKey
Definition: OTMessage.hpp:202
virtual bool VerifyContractID() const
Definition: OTMessage.cpp:3928
virtual int32_t ProcessXMLNode(irr::io::IrrXMLReader *&xml)
Definition: OTMessage.cpp:1676