Open-Transactions  0.93.0-ge03d287
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
OTDataFolder.cpp
Go to the documentation of this file.
1 /************************************************************
2  *
3  * OTDataFolder.cpp
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 #include "stdafx.hpp"
134 
135 #include "util/OTDataFolder.hpp"
136 #include "util/OTPaths.hpp"
137 #include "OTLog.hpp"
138 
139 #ifdef _WIN32
140 #include <direct.h>
141 #include <shlobj.h>
142 #endif
143 
144 #ifndef _WIN32
145 #include <libgen.h>
146 #include <unistd.h>
147 #endif
148 
149 #ifdef __APPLE__
150 #include "TargetConditionals.h"
151 #endif
152 
153 #ifdef TARGET_OS_MAC
154 #include <mach-o/dyld.h>
155 #include <limits.h>
156 #endif
157 
158 #define CONFIG_FILE_EXT ".cfg"
159 #define DATA_FOLDER_EXT "_data"
160 #define OT_CONFIG_ISRELATIVE "_is_relative"
161 
162 namespace opentxs
163 {
164 
165 OTDataFolder* OTDataFolder::pDataFolder;
166 
167 bool OTDataFolder::Init(const OTString& strThreadContext)
168 {
169  if (nullptr != pDataFolder)
170  return true; // we already have a data dir setup.
171 
172  if (!strThreadContext.Exists()) {
173  otErr << __FUNCTION__ << ": Null: "
174  << "strThreadContext"
175  << " passed in!\n";
176  OT_FAIL;
177  }
178  if (3 > strThreadContext.GetLength()) {
179  otErr << __FUNCTION__ << ": Too Short: "
180  << "strThreadContext"
181  << " !\n";
182  OT_FAIL;
183  }
184 
185  pDataFolder = new OTDataFolder; // make the new instance
186 
187  pDataFolder->m_bInitialized = false;
188 
189  // setup the config instance.
191  pSettings->Reset();
192  if (!pSettings->Load()) return false;
193 
194  // setup the RelativeKey
195  OTString l_strRelativeKey("");
196  l_strRelativeKey.Format("%s%s", strThreadContext.Get(),
198 
199  bool l_IsRelative(false), l_Exist(false);
200  OTString l_strFolderName(""), l_strDataConifgFilename("");
201 
202  // check the config for an existing configuration.
203  if (!pSettings->Check_bool("data_path", l_strRelativeKey, l_IsRelative,
204  l_Exist)) {
205  return false;
206  } // is data folder relative
207 
208  if (l_Exist) {
209  if (!pSettings->Check_str("data_path", strThreadContext,
210  l_strFolderName, l_Exist)) {
211  return false;
212  } // what is the data folder
213 
214  if (l_Exist) {
215  if (!pSettings->Check_str("data_config", strThreadContext,
216  l_strDataConifgFilename, l_Exist)) {
217  return false;
218  } // what is config file name
219 
220  if (l_Exist) {
221  if (l_IsRelative) // data folder path
222  {
223  if (!OTPaths::AppendFolder(pDataFolder->m_strDataFolderPath,
225  l_strFolderName)) {
226  return false;
227  }
228  }
229  else {
230  pDataFolder->m_strDataFolderPath = l_strFolderName;
231  }
232 
233  // data config file path.
234  if (!OTPaths::AppendFile(pDataFolder->m_strDataConifgFilePath,
236  l_strDataConifgFilename)) {
237  return false;
238  }
239 
240  pDataFolder->m_bInitialized = true;
241  return true;
242  }
243  }
244  }
245 
246  // if we get here we do not have a valid config, lets set one.
247 
248  // setup the default conifg file-name;
249  l_strFolderName.Format("%s%s", strThreadContext.Get(), DATA_FOLDER_EXT);
250  l_strDataConifgFilename.Format("%s%s", strThreadContext.Get(),
252 
253  if (!pSettings->Set_bool("data_path", l_strRelativeKey, true, l_Exist)) {
254  return false;
255  }
256  if (!pSettings->Set_str("data_path", strThreadContext, l_strFolderName,
257  l_Exist)) {
258  return false;
259  }
260  if (!pSettings->Set_str("data_config", strThreadContext,
261  l_strDataConifgFilename, l_Exist)) {
262  return false;
263  }
264 
265  if (!OTPaths::AppendFolder(pDataFolder->m_strDataFolderPath,
266  OTPaths::AppDataFolder(), l_strFolderName)) {
267  return false;
268  }
269  if (!OTPaths::AppendFile(pDataFolder->m_strDataConifgFilePath,
271  l_strDataConifgFilename)) {
272  return false;
273  }
274 
275  // save config
276  if (!pSettings->Save()) return false;
277  pSettings->Reset();
278 
279  if (nullptr != pSettings) delete pSettings;
280  pSettings = nullptr;
281 
282  // have set the default dir, now returning true;
283 
284  pDataFolder->m_bInitialized = true;
285  return true;
286 }
287 
289 {
290  if (nullptr == pDataFolder)
291  return false; // we already have a data dir setup.
292 
293  return pDataFolder->m_bInitialized;
294 }
295 
297 {
298  if (nullptr != pDataFolder) {
299  delete pDataFolder;
300  pDataFolder = nullptr;
301  return true;
302  }
303  else {
304  pDataFolder = nullptr;
305  return false;
306  }
307 }
308 
310 {
312  OT_FAIL;
313  }
314 
315  OTString strDataFolder = "";
316  if (OTDataFolder::Get(strDataFolder)) {
317  return strDataFolder;
318  }
319  else {
320  strDataFolder = "";
321  return strDataFolder;
322  }
323 }
324 
325 bool OTDataFolder::Get(OTString& strDataFolder)
326 {
327  if (nullptr != pDataFolder) {
328  if (true == pDataFolder->m_bInitialized) {
329  if (pDataFolder->m_strDataFolderPath.Exists()) {
330  strDataFolder = pDataFolder->m_strDataFolderPath;
331  return true;
332  }
333  }
334  }
335 
336  return false;
337 }
338 
340 {
341  if (nullptr != pDataFolder) {
342  if (true == pDataFolder->m_bInitialized) {
343  if (pDataFolder->m_strDataConifgFilePath.Exists()) {
344  strConfigFilePath = pDataFolder->m_strDataConifgFilePath;
345  return true;
346  }
347  }
348  }
349 
350  return false;
351 }
352 
353 } // namespace opentxs
#define DATA_FOLDER_EXT
static EXPORT bool Cleanup()
EXPORT bool Check_str(const OTString &strSection, const OTString &strKey, OTString &out_strResult, bool &out_bKeyExist) const
Definition: OTSettings.cpp:309
static EXPORT bool GetConfigFilePath(OTString &strConfigFilePath)
EXPORT bool Set_bool(const OTString &strSection, const OTString &strKey, const bool &bValue, bool &out_bNewOrUpdate, const OTString &strComment="")
Definition: OTSettings.cpp:607
EXPORT uint32_t GetLength() const
Definition: OTString.cpp:1040
static EXPORT bool IsInitialized()
#define CONFIG_FILE_EXT
EXPORT bool Exists() const
Definition: OTString.cpp:1035
static EXPORT bool Init(const OTString &strThreadContext)
static EXPORT const OTString & AppDataFolder()
Definition: OTPaths.cpp:254
EXPORT void Format(const char *fmt,...)
Definition: OTString.cpp:1319
static EXPORT bool AppendFolder(OTString &out_strPath, const OTString &strBasePath, const OTString &strFolderName)
Definition: OTPaths.cpp:1212
EXPORT bool Set_str(const OTString &strSection, const OTString &strKey, const OTString &strValue, bool &out_bNewOrUpdate, const OTString &strComment="")
Definition: OTSettings.cpp:449
EXPORT bool Reset()
Definition: OTSettings.cpp:297
#define OT_FAIL
Definition: Assert.hpp:139
EXPORT bool Check_bool(const OTString &strSection, const OTString &strKey, bool &out_bResult, bool &out_bKeyExist) const
Definition: OTSettings.cpp:400
EXPORT const char * Get() const
Definition: OTString.cpp:1045
OTLOG_IMPORT OTLogStream otErr
#define OT_CONFIG_ISRELATIVE
static EXPORT bool AppendFile(OTString &out_strPath, const OTString &strBasePath, const OTString &strFileName)
Definition: OTPaths.cpp:1245
static EXPORT OTString Get()
static EXPORT const OTString & GlobalConfigFile()
Definition: OTPaths.cpp:286