Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTAssetContract.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTAssetContract.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_OTASSETCONTRACT_HPP
134 #define OPENTXS_CORE_OTASSETCONTRACT_HPP
135 
136 #include "OTContract.hpp"
137 
138 namespace opentxs
139 {
140 
141 class OTAccount;
142 class AccountVisitor;
143 class OTIdentifier;
144 class OTPseudonym;
145 class OTString;
146 
148 {
149 public:
150  EXPORT OTAssetContract();
151  EXPORT OTAssetContract(OTString& name, OTString& foldername,
152  OTString& filename, OTString& strID);
153  EXPORT virtual ~OTAssetContract();
154 
155  EXPORT virtual void CreateContents(); // Only used when first generating an
156  // asset
157  // or server contract. Meant for contracts
158  // which never change after that point.
159  // Otherwise does the same thing as
160  // UpdateContents. (But meant for a different
161  // purpose.)
162 
163  EXPORT bool IsShares() const
164  {
165  return m_bIsShares;
166  }
167  // Some asset types keep a list of "simple" accounts (the complete set of
168  // that type.)
169  // This is called when the user creates a new asset account, in order to add
170  // it to that list.
171  // (Currently only operational for "shares", not "currencies", since it's
172  // used exclusively
173  // for the payment of dividends.)
174 
175  // adds the account to the list. (When account is created.)
176  EXPORT bool AddAccountRecord(const OTAccount& theAccount) const;
177 
178  // removes the account from the list. (When account is deleted.)
179  EXPORT bool EraseAccountRecord(const OTIdentifier& theAcctID) const;
180 
181  EXPORT bool VisitAccountRecords(AccountVisitor& visitor) const;
182 
183  EXPORT static std::string formatLongAmount(
184  int64_t lValue, int32_t nFactor = 100, int32_t nPower = 2,
185  const char* szCurrencySymbol = "",
186  const char* szThousandSeparator = ",",
187  const char* szDecimalPoint = ".");
188  EXPORT static bool ParseFormatted(int64_t& lResult,
189  const std::string& str_input,
190  int32_t nFactor = 100, int32_t nPower = 2,
191  const char* szThousandSeparator = ",",
192  const char* szDecimalPoint = ".");
193 
194  EXPORT bool FormatAmount(int64_t amount, std::string& str_output) const;
195 
196  EXPORT bool StringToAmount(int64_t& amount,
197  const std::string& str_input) const;
198 
199  EXPORT const OTString& GetBasketInfo() const
200  {
201  return m_strBasketInfo;
202  }
203 
204  EXPORT const OTString& GetCurrencyName() const
205  {
206  return m_strCurrencyName;
207  } // "dollars" (for example)
208  EXPORT const OTString& GetCurrencyFraction() const
209  {
210  return m_strCurrencyFraction;
211  } // "cents" (for example)
212  EXPORT const OTString& GetCurrencySymbol() const
213  {
214  return m_strCurrencySymbol;
215  } // "$" (for example)
216  EXPORT const OTString& GetCurrencyTLA() const
217  {
218  return m_strCurrencyTLA;
219  } // "USD"" (for example)
220 
221  EXPORT virtual bool SaveContractWallet(OTString& strContents) const;
222  EXPORT virtual bool SaveContractWallet(std::ofstream& ofs) const;
223  EXPORT virtual bool DisplayStatistics(OTString& strContents) const;
224 
225 protected:
226  // return -1 if error, 0 if nothing, and 1 if the node was processed.
227  EXPORT virtual int32_t ProcessXMLNode(irr::io::IrrXMLReader*& xml);
228 
229 protected:
230  // baskets
232 
233  // currencies and shares:
237  OTString m_strIssueType; // A vs B. Voting / non-voting...
238 
239  // shares only:
241 
242  // currencies and shares:
243  OTString m_strCurrencyName; // "dollars", not cents. The name used in
244  // normal conversation.
245  OTString m_strCurrencyType; // "decimal" (Versus? Floating point? Int?)
247 
248  // currencies only:
249  OTString m_strCurrencyTLA; // ISO-4217. E.g., USD, AUG, PSE. Take as hint,
250  // not as contract.
251  OTString m_strCurrencyFactor; // A dollar is 100 cents. Therefore factor ==
252  // 100.
253  OTString m_strCurrencyDecimalPower; // If value is 103, decimal power of 0
254  // displays 103 (actual value.) Whereas
255  // decimal power of 2 displays 1.03 and
256  // 4 displays .0103
258 
259  bool m_bIsCurrency; // default: true. (default.)
260  bool m_bIsShares; // default: false. (defaults to currency, not shares.)
261 };
262 
263 } // namespace opentxs
264 
265 #endif // OPENTXS_CORE_OTASSETCONTRACT_HPP
virtual EXPORT bool DisplayStatistics(OTString &strContents) const
static EXPORT bool ParseFormatted(int64_t &lResult, const std::string &str_input, int32_t nFactor=100, int32_t nPower=2, const char *szThousandSeparator=",", const char *szDecimalPoint=".")
virtual EXPORT int32_t ProcessXMLNode(irr::io::IrrXMLReader *&xml)
static EXPORT std::string formatLongAmount(int64_t lValue, int32_t nFactor=100, int32_t nPower=2, const char *szCurrencySymbol="", const char *szThousandSeparator=",", const char *szDecimalPoint=".")
EXPORT const OTString & GetCurrencyTLA() const
EXPORT bool FormatAmount(int64_t amount, std::string &str_output) const
EXPORT bool StringToAmount(int64_t &amount, const std::string &str_input) const
EXPORT const OTString & GetCurrencySymbol() const
virtual EXPORT void CreateContents()
EXPORT bool AddAccountRecord(const OTAccount &theAccount) const
virtual EXPORT ~OTAssetContract()
EXPORT bool VisitAccountRecords(AccountVisitor &visitor) const
EXPORT bool IsShares() const
EXPORT const OTString & GetBasketInfo() const
EXPORT const OTString & GetCurrencyFraction() const
EXPORT bool EraseAccountRecord(const OTIdentifier &theAcctID) const
virtual EXPORT bool SaveContractWallet(OTString &strContents) const
EXPORT const OTString & GetCurrencyName() const