Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTPartyAccount.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTPartyAccount.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_SCRIPT_OTPARTYACCOUNT_HPP
134 #define OPENTXS_CORE_SCRIPT_OTPARTYACCOUNT_HPP
135 
136 #include "../OTString.hpp"
137 
138 namespace opentxs
139 {
140 
141 class OTAccount;
142 class OTAgent;
143 class OTIdentifier;
144 class OTParty;
145 class OTPseudonym;
146 class OTScript;
147 class OTSmartContract;
148 
149 typedef std::map<std::string, OTPseudonym*> mapOfNyms;
150 
151 // Each party has a list of accounts. Just as the agent, depending on context,
152 // MAY
153 // have an unowned-but-useful pointer to its active Nym, similarly a
154 // partyaccount
155 // MAY have an unowned-but-useful point to its actual Account.
156 //
157 // (Normally, an OTPartyAccount is loaded with the party, as part of an
158 // OTScriptable-
159 // derived object, and it doesn't actually load a copy of the actual Nyms and
160 // Accounts
161 // at that time, it just stores their IDs. But times may also come when the
162 // actual pointer
163 // is passed in for use by the Parties, who are not otherwise expected to do
164 // anything
165 // with it, or to clean it up or rely on it for their normal data storage.)
166 //
167 // Represents an account (to a party.) This is because ACTUALLY loading the REAL
168 // account is a pain in the ass,
169 // and we just want to store its ID, etc. This way, the party can OWN this
170 // information about this list of
171 // accounts, and store it, load it, destroy it, etc, often without involving the
172 // actual account file at all.
173 //
174 // (Even if a this isn't currently doing anything with any of the party's
175 // accounts, the contract still
176 // has to have a LIST of them, so it knows what to do in those cases when it
177 // DOES need to do something.)
178 //
179 // For example, this is where we store the CLOSING TRANSACTION # for that
180 // account (for this agreement.)
181 // That number can't be found in the account itself, but all smart contracts
182 // involving asset accounts must
183 // provide a closing number for each asset account.
184 //
186 {
187  OTParty* m_pForParty; // When being added to a party, this pointer will be
188  // set.
189  // NOTE: each party needs to have a list of partyaccounts, AND each account
190  // on that list needs to have a CLOSING #!!! Ahh...
191  OTAccount* m_pAccount;
192  int64_t m_lClosingTransNo; // Any account that is party to an agreement,
193  // must have a closing transaction # for
194  // finalReceipt.
195  // account name (inside the script language, "gold_acct_A" could be used to
196  // reference this acct.)
197  //
198  OTString m_strName; // Name of the account (for use in scripts.)
199  OTString m_strAcctID; // The Account ID itself.
200  OTString m_strAssetTypeID; // The asset type ID for the account. Stored
201  // because parties agree on this even before the
202  // account ID is selected. Compare() uses this
203  // even when the account ID is blank, and when
204  // acct ID *is* added, its asset type must match
205  // this.
206  OTString m_strAgentName; // The name of the agent who has rights to this
207  // account.
208  // Entity, role, and Nym information are not stored here.
209  // Entity is already known on the party who owns this account (and I should
210  // have a ptr to him.)
211  // Role is already known on the agent who is presumably on the party's list
212  // of agents.
213  // Nym is known on the party (for owner) and on the agent.
214 
215  // "GetOwnerID()" for a partyaccount (if it were to store NymID, EntityID,
216  // and a bool to choose
217  // between them) should be logically the same as
218  // m_pOwnerParty->GetPartyID().
219  //
220 public:
221  EXPORT void RegisterForExecution(OTScript& theScript);
222 
223  OTParty* GetParty() const
224  {
225  return m_pForParty;
226  }
227  void SetParty(OTParty& theOwnerParty); // This happens when the partyaccount
228  // is added to the party. (so I have
229  // a ptr back)
230 
231  EXPORT const OTString& GetName() const
232  {
233  return m_strName;
234  } // account's name as used in a script.
235  const OTString& GetAgentName() const
236  {
237  return m_strAgentName;
238  } // agent's name as used in a script.
239  const OTString& GetAcctID() const
240  {
241  return m_strAcctID;
242  } // account's ID as used internal to OT.
243  const OTString& GetAssetTypeID() const
244  {
245  return m_strAssetTypeID;
246  } // asset type ID for the account.
247 
248  void SetAgentName(const OTString& strAgentName)
249  {
250  m_strAgentName = strAgentName;
251  }
252  void SetAcctID(const OTString& strAccountID)
253  {
254  m_strAcctID = strAccountID;
255  }
256  EXPORT OTAgent* GetAuthorizedAgent();
257  OTAccount* LoadAccount(OTPseudonym& theSignerNym,
258  const OTString& strServerID);
259  bool IsAccount(OTAccount& theAccount);
260  bool IsAccountByID(const OTIdentifier& theAcctID) const;
261  bool VerifyOwnership() const; // I have a ptr to my owner (party), as well
262  // as to the actual account. I will ask him to
263  // verify whether he actually owns it.
264  bool VerifyAgency(); // I can get a ptr to my agent, and I have one to the
265  // actual account. I will ask him to verify whether he
266  // actually has agency over it.
267  int64_t GetClosingTransNo() const
268  {
269  return m_lClosingTransNo;
270  }
271  void SetClosingTransNo(int64_t lTransNo)
272  {
273  m_lClosingTransNo = lTransNo;
274  }
275  bool Compare(const OTPartyAccount& rhs) const;
277  mapOfNyms* pNymMap, const OTString& strServerID,
278  OTPseudonym& theServerNym, OTSmartContract& theSmartContract,
279  const int64_t& lNewTransactionNumber, const OTString& strOrigCronItem,
280  OTString* pstrNote = nullptr, OTString* pstrAttachment = nullptr);
281  OTPartyAccount();
282  OTPartyAccount(std::string str_account_name, const OTString& strAgentName,
283  OTAccount& theAccount, int64_t lClosingTransNo);
284  OTPartyAccount(const OTString& strName, const OTString& strAgentName,
285  const OTString& strAcctID, const OTString& strAssetTypeID,
286  int64_t lClosingTransNo);
287 
288  virtual ~OTPartyAccount();
289 
290  void Serialize(OTString& strAppend, bool bCalculatingID = false,
291  bool bSpecifyAssetID = false) const;
292 
293  // For pointers I don't own, but store for convenience.
294  // This clears them once we're done processing, so I don't
295  // end up stuck with bad pointers on the next go-around.
296  //
298  {
299  m_pAccount = nullptr;
300  }
301 };
302 
303 } // namespace opentxs
304 
305 #endif // OPENTXS_CORE_SCRIPT_OTPARTYACCOUNT_HPP
void SetAgentName(const OTString &strAgentName)
void Serialize(OTString &strAppend, bool bCalculatingID=false, bool bSpecifyAssetID=false) const
EXPORT const OTString & GetName() const
void SetAcctID(const OTString &strAccountID)
std::map< std::string, OTPseudonym * > mapOfNyms
Definition: OTWallet.hpp:161
EXPORT OTAgent * GetAuthorizedAgent()
void SetClosingTransNo(int64_t lTransNo)
bool Compare(const OTPartyAccount &rhs) const
const OTString & GetAgentName() const
OTParty * GetParty() const
const OTString & GetAcctID() const
EXPORT void RegisterForExecution(OTScript &theScript)
bool DropFinalReceiptToInbox(mapOfNyms *pNymMap, const OTString &strServerID, OTPseudonym &theServerNym, OTSmartContract &theSmartContract, const int64_t &lNewTransactionNumber, const OTString &strOrigCronItem, OTString *pstrNote=nullptr, OTString *pstrAttachment=nullptr)
const OTString & GetAssetTypeID() const
bool IsAccountByID(const OTIdentifier &theAcctID) const
int64_t GetClosingTransNo() const
bool IsAccount(OTAccount &theAccount)
void SetParty(OTParty &theOwnerParty)
OTAccount * LoadAccount(OTPseudonym &theSignerNym, const OTString &strServerID)