Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTBylaw.hpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTBylaw.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_OTBYLAW_HPP
134 #define OPENTXS_CORE_SCRIPT_OTBYLAW_HPP
135 
136 #include "OTVariable.hpp"
137 
138 namespace opentxs
139 {
140 
141 class OTClause;
143 
144 typedef std::map<std::string, std::string> mapOfCallbacks;
145 typedef std::map<std::string, OTClause*> mapOfClauses;
146 typedef std::map<std::string, OTVariable*> mapOfVariables;
147 
148 // First is the name of some standard OT hook, like OnActivate, and Second is
149 // name of clause.
150 // It's a multimap because you might have 6 or 7 clauses that all trigger on the
151 // same hook.
152 //
153 typedef std::multimap<std::string, std::string> mapOfHooks;
154 
155 // A section of law, including its own clauses (scripts). A bylaw is kind of
156 // like an OT script "program", so it makes sense to be able to collect them,
157 // and to have them as discrete "packages".
158 //
159 class OTBylaw
160 {
161  OTString m_strName; // Name of this Bylaw.
162  OTString m_strLanguage; // Language that the scripts are written in, for
163  // this bylaw.
164 
165  mapOfVariables m_mapVariables; // constant, persistant, and important
166  // variables (strings and longs)
167  mapOfClauses m_mapClauses; // map of scripts associated with this bylaw.
168 
169  mapOfHooks m_mapHooks; // multimap of server hooks associated with clauses.
170  // string / string
171  mapOfCallbacks m_mapCallbacks; // map of standard callbacks associated with
172  // script clauses. string / string
173 
174  OTScriptable* m_pOwnerAgreement; // This Bylaw is owned by an agreement
175  // (OTScriptable-derived.)
176 public:
177  EXPORT const OTString& GetName() const
178  {
179  return m_strName;
180  }
181  EXPORT const char* GetLanguage() const;
182  EXPORT bool AddVariable(OTVariable& theVariable);
183  EXPORT bool AddVariable(
184  std::string str_Name, std::string str_Value,
186  EXPORT bool AddVariable(
187  std::string str_Name, int32_t nValue,
189  EXPORT bool AddVariable(
190  std::string str_Name, bool bValue,
192  EXPORT bool AddClause(OTClause& theClause);
193  EXPORT bool AddClause(const char* szName, const char* szCode);
194  EXPORT bool AddHook(std::string str_HookName,
195  std::string str_ClauseName); // name of hook such
196  // as cron_process or
197  // hook_activate, and
198  // name of clause,
199  // such as sectionA
200  // (corresponding to
201  // an actual script
202  // in the clauses
203  // map.)
204  EXPORT bool AddCallback(std::string str_CallbackName,
205  std::string str_ClauseName); // name of
206  // callback such
207  // as
208  // callback_party_may_execute_clause,
209  // and name of clause, such as
210  // custom_party_may_execute_clause
211  // (corresponding to an actual script
212  // in the clauses map.)
213  EXPORT OTVariable* GetVariable(std::string str_Name); // not a
214  // reference, so
215  // you can pass
216  // in char *.
217  // Maybe that's
218  // bad? todo:
219  // research
220  // that.
221  EXPORT OTClause* GetClause(std::string str_Name) const;
222  EXPORT OTClause* GetCallback(std::string str_CallbackName);
223  EXPORT bool GetHooks(std::string str_HookName,
224  mapOfClauses& theResults); // Look up all clauses
225  // matching a specific hook.
226  EXPORT int32_t GetVariableCount() const
227  {
228  return static_cast<int32_t>(m_mapVariables.size());
229  }
230  EXPORT int32_t GetClauseCount() const
231  {
232  return static_cast<int32_t>(m_mapClauses.size());
233  }
234  EXPORT int32_t GetCallbackCount() const
235  {
236  return static_cast<int32_t>(m_mapCallbacks.size());
237  }
238  EXPORT int32_t GetHookCount() const
239  {
240  return static_cast<int32_t>(m_mapHooks.size());
241  }
242  EXPORT OTVariable* GetVariableByIndex(int32_t nIndex);
243  EXPORT OTClause* GetClauseByIndex(int32_t nIndex);
244  EXPORT OTClause* GetCallbackByIndex(int32_t nIndex);
245  EXPORT OTClause* GetHookByIndex(int32_t nIndex);
246  EXPORT const std::string GetCallbackNameByIndex(int32_t nIndex);
247  EXPORT const std::string GetHookNameByIndex(int32_t nIndex);
248  EXPORT void RegisterVariablesForExecution(OTScript& theScript);
249  EXPORT bool IsDirty() const; // So you can tell if any of the persistent or
250  // important variables have CHANGED since it
251  // was last set clean.
252  EXPORT bool IsDirtyImportant() const; // So you can tell if ONLY the
253  // IMPORTANT variables have CHANGED
254  // since it was last set clean.
255  EXPORT void SetAsClean(); // Sets the variables as clean, so you can check
256  // later and see if any have been changed (if it's
257  // DIRTY again.)
258  // This pointer isn't owned -- just stored for convenience.
259  //
261  {
262  return m_pOwnerAgreement;
263  }
264  EXPORT void SetOwnerAgreement(OTScriptable& theOwner)
265  {
266  m_pOwnerAgreement = &theOwner;
267  }
268  EXPORT OTBylaw();
269  EXPORT OTBylaw(const char* szName, const char* szLanguage);
270  virtual ~OTBylaw();
271 
272  EXPORT bool Compare(OTBylaw& rhs);
273 
274  EXPORT void Serialize(OTString& strAppend,
275  bool bCalculatingID = false) const;
276 };
277 
278 } // namespace opentxs
279 
280 #endif // OPENTXS_CORE_SCRIPT_OTBYLAW_HPP
EXPORT int32_t GetHookCount() const
Definition: OTBylaw.hpp:238
EXPORT bool AddClause(OTClause &theClause)
Definition: OTBylaw.cpp:854
EXPORT OTScriptable * GetOwnerAgreement()
Definition: OTBylaw.hpp:260
EXPORT OTClause * GetClauseByIndex(int32_t nIndex)
Definition: OTBylaw.cpp:642
virtual ~OTBylaw()
Definition: OTBylaw.cpp:953
std::multimap< std::string, std::string > mapOfHooks
Definition: OTBylaw.hpp:153
EXPORT void RegisterVariablesForExecution(OTScript &theScript)
Definition: OTBylaw.cpp:276
EXPORT OTClause * GetCallback(std::string str_CallbackName)
Definition: OTBylaw.cpp:468
std::map< std::string, OTVariable * > mapOfVariables
Definition: OTBylaw.hpp:146
EXPORT OTClause * GetCallbackByIndex(int32_t nIndex)
EXPORT bool Compare(OTBylaw &rhs)
Definition: OTBylaw.cpp:288
EXPORT bool GetHooks(std::string str_HookName, mapOfClauses &theResults)
Definition: OTBylaw.cpp:686
EXPORT int32_t GetClauseCount() const
Definition: OTBylaw.hpp:230
std::map< std::string, OTClause * > mapOfClauses
Definition: OTBylaw.hpp:145
EXPORT bool IsDirty() const
Definition: OTBylaw.cpp:204
EXPORT int32_t GetCallbackCount() const
Definition: OTBylaw.hpp:234
EXPORT void SetAsClean()
Definition: OTBylaw.cpp:262
EXPORT const std::string GetHookNameByIndex(int32_t nIndex)
Definition: OTBylaw.cpp:663
EXPORT OTClause * GetClause(std::string str_Name) const
Definition: OTBylaw.cpp:623
EXPORT const std::string GetCallbackNameByIndex(int32_t nIndex)
Definition: OTBylaw.cpp:450
EXPORT bool AddVariable(OTVariable &theVariable)
Definition: OTBylaw.cpp:743
EXPORT void SetOwnerAgreement(OTScriptable &theOwner)
Definition: OTBylaw.hpp:264
EXPORT bool IsDirtyImportant() const
Definition: OTBylaw.cpp:235
std::map< std::string, std::string > mapOfCallbacks
Definition: OTBylaw.hpp:142
EXPORT void Serialize(OTString &strAppend, bool bCalculatingID=false) const
Definition: OTBylaw.cpp:146
EXPORT OTVariable * GetVariable(std::string str_Name)
Definition: OTBylaw.cpp:579
EXPORT bool AddCallback(std::string str_CallbackName, std::string str_ClauseName)
Definition: OTBylaw.cpp:512
EXPORT const OTString & GetName() const
Definition: OTBylaw.hpp:177
EXPORT const char * GetLanguage() const
Definition: OTBylaw.cpp:916
EXPORT int32_t GetVariableCount() const
Definition: OTBylaw.hpp:226
EXPORT bool AddHook(std::string str_HookName, std::string str_ClauseName)
Definition: OTBylaw.cpp:556
EXPORT OTVariable * GetVariableByIndex(int32_t nIndex)
Definition: OTBylaw.cpp:602
EXPORT OTClause * GetHookByIndex(int32_t nIndex)
EXPORT OTBylaw()
Definition: OTBylaw.cpp:923