Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTVariable.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTVariable.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_OTVARIABLE_HPP
134 #define OPENTXS_CORE_SCRIPT_OTVARIABLE_HPP
135 
136 #include "../OTString.hpp"
137 
138 namespace opentxs
139 {
140 
141 class OTBylaw;
142 class OTScript;
143 class OTVariable;
144 
146 {
147 public:
149  Var_String, // std::string
150  Var_Integer, // Integer. (For int64_t int32_t: use strings.)
151  Var_Bool, // Boolean. (True / False)
152  Var_Error_Type // should never happen.
153  };
154 
156  Var_Constant, // Constant -- you cannot change this value.
157  Var_Persistent, // Persistent -- changing value doesn't require notice
158  // to parties.
159  Var_Important, // Important -- changing value requires notice to
160  // parties.
161  Var_Error_Access // should never happen.
162  };
163 
164 private:
165  OTString m_strName; // Name of this variable.
166  std::string m_str_Value; // If a string, the value is stored here.
167  int32_t m_nValue; // If an integer, the value is stored here.
168  bool m_bValue; // If a bool, the value is stored here.
169  std::string m_str_ValueBackup; // If a string, the value backup is stored
170  // here. (So we can see if it has changed
171  // since execution)
172  int32_t m_nValueBackup; // If an integer, the value backup is stored here.
173  // (So we can see if it has changed since execution)
174  bool m_bValueBackup; // If a bool, the value backup is stored here. (So we
175  // can check for dirtiness later...)
176  OTBylaw* m_pBylaw; // the Bylaw that this variable belongs to.
177  OTVariable_Type m_Type; // Currently bool, int32_t, or string.
178  OTVariable_Access m_Access; // Determines how the variable is used inside
179  // the script.
180  OTScript* m_pScript; // If the variable is set onto a script, this pointer
181  // gets set. When the variable destructs, it will
182  // remove itself from the script.
183 
184 public:
185  EXPORT void RegisterForExecution(OTScript& theScript); // We keep an
186  // internal script
187  // pointer here, so
188  // if we destruct, we
189  // can remove
190  // ourselves from the
191  // script.
192  EXPORT void UnregisterScript(); // If the script destructs before the
193  // variable does, it unregisters itself
194  // here, so the variable isn't stuck with a
195  // bad pointer.
196  bool IsDirty() const; // So you can tell if the variable has CHANGED since
197  // it was last set clean.
198  void SetAsClean(); // Sets the variable as clean, so you can check it later
199  // and see if it's been changed (if it's DIRTY again.)
200  bool IsConstant() const
201  {
202  return (Var_Constant == m_Access);
203  }
204  bool IsPersistent() const
205  {
206  return ((Var_Persistent == m_Access) || (Var_Important == m_Access));
207  } // important vars are persistent, too.
208  bool IsImportant() const
209  {
210  return (Var_Important == m_Access);
211  }
212  void SetBylaw(OTBylaw& theBylaw)
213  {
214  m_pBylaw = &theBylaw;
215  }
216  bool SetValue(const int32_t& nValue);
217  bool SetValue(bool bValue);
218  bool SetValue(const std::string& str_Value);
219 
220  EXPORT const OTString& GetName() const
221  {
222  return m_strName;
223  } // variable's name as used in a script.
225  {
226  return m_Type;
227  }
229  {
230  return m_Access;
231  }
232 
233  bool IsInteger() const
234  {
235  return (Var_Integer == m_Type);
236  }
237  bool IsBool() const
238  {
239  return (Var_Bool == m_Type);
240  }
241  bool IsString() const
242  {
243  return (Var_String == m_Type);
244  }
245 
246  int32_t CopyValueInteger() const
247  {
248  return m_nValue;
249  }
250  bool CopyValueBool() const
251  {
252  return m_bValue;
253  }
254  std::string CopyValueString() const
255  {
256  return m_str_Value;
257  }
258 
259  int32_t& GetValueInteger()
260  {
261  return m_nValue;
262  }
263  bool& GetValueBool()
264  {
265  return m_bValue;
266  }
267  std::string& GetValueString()
268  {
269  return m_str_Value;
270  }
271 
272  bool Compare(OTVariable& rhs);
273 
274  EXPORT OTVariable();
275  EXPORT OTVariable(std::string str_Name, int32_t nValue,
276  OTVariable_Access theAccess = Var_Persistent);
277  EXPORT OTVariable(std::string str_Name, bool bValue,
278  OTVariable_Access theAccess = Var_Persistent);
279  EXPORT OTVariable(std::string str_Name, std::string str_Value,
280  OTVariable_Access theAccess = Var_Persistent);
281  EXPORT virtual ~OTVariable();
282 
283  void Serialize(OTString& strAppend, bool bCalculatingID = false) const;
284 };
285 
286 } // namespace opentxs
287 
288 #endif // OPENTXS_CORE_SCRIPT_OTVARIABLE_HPP
bool IsString() const
Definition: OTVariable.hpp:241
std::string CopyValueString() const
Definition: OTVariable.hpp:254
OTVariable_Type GetType() const
Definition: OTVariable.hpp:224
EXPORT void RegisterForExecution(OTScript &theScript)
Definition: OTVariable.cpp:424
bool IsDirty() const
Definition: OTVariable.cpp:353
bool IsImportant() const
Definition: OTVariable.hpp:208
void SetBylaw(OTBylaw &theBylaw)
Definition: OTVariable.hpp:212
bool CopyValueBool() const
Definition: OTVariable.hpp:250
bool IsInteger() const
Definition: OTVariable.hpp:233
EXPORT void UnregisterScript()
Definition: OTVariable.cpp:416
EXPORT const OTString & GetName() const
Definition: OTVariable.hpp:220
bool SetValue(const int32_t &nValue)
Definition: OTVariable.cpp:307
void Serialize(OTString &strAppend, bool bCalculatingID=false) const
Definition: OTVariable.cpp:144
bool IsBool() const
Definition: OTVariable.hpp:237
OTVariable_Access GetAccess() const
Definition: OTVariable.hpp:228
virtual EXPORT ~OTVariable()
Definition: OTVariable.cpp:295
bool IsConstant() const
Definition: OTVariable.hpp:200
std::string & GetValueString()
Definition: OTVariable.hpp:267
int32_t & GetValueInteger()
Definition: OTVariable.hpp:259
bool IsPersistent() const
Definition: OTVariable.hpp:204
bool Compare(OTVariable &rhs)
Definition: OTVariable.cpp:438
int32_t CopyValueInteger() const
Definition: OTVariable.hpp:246