blob: bf6e33bc30f3623a7494a6e3459b74ec40e5d97c [file] [log] [blame]
Dees_Troy51a0e822012-09-05 15:24:24 -04001/*
Ethan Yonkerfe916112016-03-14 14:54:37 -05002 Copyright 2012 to 2016 bigbiff/Dees_Troy TeamWin
Dees Troy3be70a82013-10-22 14:25:12 +00003 This file is part of TWRP/TeamWin Recovery Project.
4
5 TWRP is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
9
10 TWRP is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with TWRP. If not, see <http://www.gnu.org/licenses/>.
17*/
Dees_Troy51a0e822012-09-05 15:24:24 -040018
Dees_Troy51a0e822012-09-05 15:24:24 -040019#include <pthread.h>
Dees_Troy51a0e822012-09-05 15:24:24 -040020#include <time.h>
Dees_Troy51a0e822012-09-05 15:24:24 -040021#include <string>
Dees_Troy51a0e822012-09-05 15:24:24 -040022#include <sstream>
Ethan Yonker3fdcda42016-11-30 12:29:37 -060023#include <fstream>
Ethan Yonkerfe916112016-03-14 14:54:37 -050024#include <cctype>
25#include <cutils/properties.h>
Ethan Yonker34ae4832016-08-24 15:32:18 -050026#include <unistd.h>
Dees_Troy51a0e822012-09-05 15:24:24 -040027
28#include "variables.h"
29#include "data.hpp"
30#include "partitions.hpp"
Dees_Troy01a9b7a2012-10-01 09:01:03 -040031#include "twrp-functions.hpp"
Ricardo Gomezc9ecd442013-07-05 16:13:52 -070032#ifndef TW_NO_SCREEN_TIMEOUT
Dees_Troy2f9117a2013-02-17 19:52:09 -060033#include "gui/blanktimer.hpp"
Ricardo Gomezc9ecd442013-07-05 16:13:52 -070034#endif
Ethan Yonker00028b42014-04-09 14:29:02 -050035#include "find_file.hpp"
Ethan Yonker4b94cfd2014-12-11 10:00:45 -060036#include "set_metadata.h"
Ethan Yonker74db1572015-10-28 12:44:49 -050037#include "gui/gui.hpp"
Ethan Yonkerfe916112016-03-14 14:54:37 -050038#include "infomanager.hpp"
Dees_Troy51a0e822012-09-05 15:24:24 -040039
Matt Mowere9260742015-02-22 20:20:18 -060040#define DEVID_MAX 64
41#define HWID_MAX 32
Anatoly Smaznov10c11f62013-02-12 13:33:40 +070042
Dees_Troy51a0e822012-09-05 15:24:24 -040043extern "C"
44{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +020045 #include "twcommon.h"
Dees_Troy7d15c252012-09-05 20:47:21 -040046 #include "gui/pages.h"
Dees_Troy7d15c252012-09-05 20:47:21 -040047 void gui_notifyVarChange(const char *name, const char* value);
Dees_Troy51a0e822012-09-05 15:24:24 -040048}
Ethan Yonkerfbb43532015-12-28 21:54:50 +010049#include "minuitwrp/minui.h"
Dees_Troy51a0e822012-09-05 15:24:24 -040050
Ethan Yonkerfe916112016-03-14 14:54:37 -050051#define FILE_VERSION 0x00010010 // Do not set to 0
Dees_Troy51a0e822012-09-05 15:24:24 -040052
53using namespace std;
54
Ricardo Gomezc9ecd442013-07-05 16:13:52 -070055string DataManager::mBackingFile;
56int DataManager::mInitialized = 0;
Ethan Yonkerfe916112016-03-14 14:54:37 -050057InfoManager DataManager::mPersist; // Data that that is not constant and will be saved to the settings file
58InfoManager DataManager::mData; // Data that is not constant and will not be saved to settings file
59InfoManager DataManager::mConst; // Data that is constant and will not be saved to settings file
Jenkins1710bf22014-10-02 20:22:21 -040060
Ethan Yonker6277c792014-09-15 14:54:30 -050061extern bool datamedia;
Dees_Troy51a0e822012-09-05 15:24:24 -040062
Ethan Yonkerc798c9c2015-10-09 11:15:26 -050063#ifndef PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP
Vojtech Bocekfda239b2015-01-07 22:55:13 +010064pthread_mutex_t DataManager::m_valuesLock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER;
Ethan Yonkerc798c9c2015-10-09 11:15:26 -050065#else
66pthread_mutex_t DataManager::m_valuesLock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP;
67#endif
Vojtech Bocekfda239b2015-01-07 22:55:13 +010068
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040069// Device ID functions
70void DataManager::sanitize_device_id(char* device_id) {
Matt Mowere9260742015-02-22 20:20:18 -060071 const char* whitelist ="-._";
72 char str[DEVID_MAX];
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040073 char* c = str;
74
Matt Mowere9260742015-02-22 20:20:18 -060075 snprintf(str, DEVID_MAX, "%s", device_id);
76 memset(device_id, 0, strlen(device_id));
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040077 while (*c) {
Matt Mowere9260742015-02-22 20:20:18 -060078 if (isalnum(*c) || strchr(whitelist, *c))
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040079 strncat(device_id, c, 1);
80 c++;
81 }
82 return;
83}
84
Vojtech Bocekfafb0c52013-07-25 22:53:02 +020085#define CMDLINE_SERIALNO "androidboot.serialno="
86#define CMDLINE_SERIALNO_LEN (strlen(CMDLINE_SERIALNO))
87#define CPUINFO_SERIALNO "Serial"
88#define CPUINFO_SERIALNO_LEN (strlen(CPUINFO_SERIALNO))
89#define CPUINFO_HARDWARE "Hardware"
90#define CPUINFO_HARDWARE_LEN (strlen(CPUINFO_HARDWARE))
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040091
92void DataManager::get_device_id(void) {
93 FILE *fp;
94 char line[2048];
Matt Mowere9260742015-02-22 20:20:18 -060095 char hardware_id[HWID_MAX] = { 0 };
96 char device_id[DEVID_MAX] = { 0 };
Dees_Troyfdf5fcc2012-09-11 10:27:01 -040097 char* token;
98
Anatoly Smaznov10c11f62013-02-12 13:33:40 +070099#ifdef TW_USE_MODEL_HARDWARE_ID_FOR_DEVICE_ID
Matt Mowere9260742015-02-22 20:20:18 -0600100 // Use (product_model)_(hardware_id) as device id
Anatoly Smaznov10c11f62013-02-12 13:33:40 +0700101 char model_id[PROPERTY_VALUE_MAX];
102 property_get("ro.product.model", model_id, "error");
Matt Mowere9260742015-02-22 20:20:18 -0600103 if (strcmp(model_id, "error") != 0) {
Dees_Troy2673cec2013-04-02 20:22:16 +0000104 LOGINFO("=> product model: '%s'\n", model_id);
Anatoly Smaznov10c11f62013-02-12 13:33:40 +0700105 // Replace spaces with underscores
Matt Mower23d8aae2017-01-06 14:30:33 -0600106 for (size_t i = 0; i < strlen(model_id); i++) {
Matt Mowere9260742015-02-22 20:20:18 -0600107 if (model_id[i] == ' ')
108 model_id[i] = '_';
Anatoly Smaznov10c11f62013-02-12 13:33:40 +0700109 }
Matt Mowere9260742015-02-22 20:20:18 -0600110 snprintf(device_id, DEVID_MAX, "%s", model_id);
111
112 if (strlen(device_id) < DEVID_MAX) {
113 fp = fopen("proc_cpuinfo.txt", "rt");
114 if (fp != NULL) {
115 while (fgets(line, sizeof(line), fp) != NULL) {
116 if (memcmp(line, CPUINFO_HARDWARE,
117 CPUINFO_HARDWARE_LEN) == 0) {
118 // skip past "Hardware", spaces, and colon
119 token = line + CPUINFO_HARDWARE_LEN;
120 while (*token && (!isgraph(*token) || *token == ':'))
121 token++;
122
123 if (*token && *token != '\n'
124 && strcmp("UNKNOWN\n", token)) {
125 snprintf(hardware_id, HWID_MAX, "%s", token);
126 if (hardware_id[strlen(hardware_id)-1] == '\n')
127 hardware_id[strlen(hardware_id)-1] = 0;
128 LOGINFO("=> hardware id from cpuinfo: '%s'\n",
129 hardware_id);
130 }
131 break;
132 }
133 }
134 fclose(fp);
135 }
Anatoly Smaznov10c11f62013-02-12 13:33:40 +0700136 }
Matt Mowere9260742015-02-22 20:20:18 -0600137
138 if (hardware_id[0] != 0)
139 snprintf(device_id, DEVID_MAX, "%s_%s", model_id, hardware_id);
140
141 sanitize_device_id(device_id);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500142 mConst.SetValue("device_id", device_id);
Dees_Troy2673cec2013-04-02 20:22:16 +0000143 LOGINFO("=> using device id: '%s'\n", device_id);
Anatoly Smaznov10c11f62013-02-12 13:33:40 +0700144 return;
145 }
146#endif
147
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400148#ifndef TW_FORCE_CPUINFO_FOR_DEVICE_ID
lambdadroidfc0b16d2017-08-04 17:16:53 +0200149#ifdef TW_USE_SERIALNO_PROPERTY_FOR_DEVICE_ID
150 // Check serial number system property
151 if (property_get("ro.serialno", line, "")) {
152 snprintf(device_id, DEVID_MAX, "%s", line);
153 sanitize_device_id(device_id);
154 mConst.SetValue("device_id", device_id);
155 return;
156 }
157#endif
158
Matt Mowere9260742015-02-22 20:20:18 -0600159 // Check the cmdline to see if the serial number was supplied
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400160 fp = fopen("/proc/cmdline", "rt");
Matt Mowere9260742015-02-22 20:20:18 -0600161 if (fp != NULL) {
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200162 fgets(line, sizeof(line), fp);
Matt Mowere9260742015-02-22 20:20:18 -0600163 fclose(fp); // cmdline is only one line long
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400164
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200165 token = strtok(line, " ");
Matt Mowere9260742015-02-22 20:20:18 -0600166 while (token) {
167 if (memcmp(token, CMDLINE_SERIALNO, CMDLINE_SERIALNO_LEN) == 0) {
168 token += CMDLINE_SERIALNO_LEN;
169 snprintf(device_id, DEVID_MAX, "%s", token);
170 sanitize_device_id(device_id); // also removes newlines
Ethan Yonkerfe916112016-03-14 14:54:37 -0500171 mConst.SetValue("device_id", device_id);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200172 return;
173 }
174 token = strtok(NULL, " ");
175 }
176 }
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400177#endif
Matt Mowere9260742015-02-22 20:20:18 -0600178 // Check cpuinfo for serial number; if found, use as device_id
179 // If serial number is not found, fallback to hardware_id for the device_id
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400180 fp = fopen("/proc/cpuinfo", "rt");
Matt Mowere9260742015-02-22 20:20:18 -0600181 if (fp != NULL) {
182 while (fgets(line, sizeof(line), fp) != NULL) {
183 if (memcmp(line, CPUINFO_SERIALNO, CPUINFO_SERIALNO_LEN) == 0) {
184 // skip past "Serial", spaces, and colon
185 token = line + CPUINFO_SERIALNO_LEN;
186 while (*token && (!isgraph(*token) || *token == ':'))
187 token++;
188
189 if (*token && *token != '\n') {
190 snprintf(device_id, DEVID_MAX, "%s", token);
191 sanitize_device_id(device_id); // also removes newlines
Dees_Troy2673cec2013-04-02 20:22:16 +0000192 LOGINFO("=> serial from cpuinfo: '%s'\n", device_id);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500193 mConst.SetValue("device_id", device_id);
Matt Mowere9260742015-02-22 20:20:18 -0600194 fclose(fp);
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400195 return;
196 }
Matt Mowere9260742015-02-22 20:20:18 -0600197 } else if (memcmp(line, CPUINFO_HARDWARE,
198 CPUINFO_HARDWARE_LEN) == 0) {
199 // skip past "Hardware", spaces, and colon
200 token = line + CPUINFO_HARDWARE_LEN;
201 while (*token && (!isgraph(*token) || *token == ':'))
202 token++;
203
204 if (*token && *token != '\n') {
205 snprintf(hardware_id, HWID_MAX, "%s", token);
206 if (hardware_id[strlen(hardware_id)-1] == '\n')
207 hardware_id[strlen(hardware_id)-1] = 0;
Dees_Troy2673cec2013-04-02 20:22:16 +0000208 LOGINFO("=> hardware id from cpuinfo: '%s'\n", hardware_id);
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400209 }
210 }
211 }
212 fclose(fp);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200213 }
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400214
215 if (hardware_id[0] != 0) {
Dees_Troy2673cec2013-04-02 20:22:16 +0000216 LOGINFO("\nusing hardware id for device id: '%s'\n", hardware_id);
Matt Mowere9260742015-02-22 20:20:18 -0600217 snprintf(device_id, DEVID_MAX, "%s", hardware_id);
218 sanitize_device_id(device_id);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500219 mConst.SetValue("device_id", device_id);
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400220 return;
221 }
222
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200223 strcpy(device_id, "serialno");
Ethan Yonker74db1572015-10-28 12:44:49 -0500224 LOGINFO("=> device id not found, using '%s'\n", device_id);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500225 mConst.SetValue("device_id", device_id);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200226 return;
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400227}
228
Dees_Troy51a0e822012-09-05 15:24:24 -0400229int DataManager::ResetDefaults()
230{
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100231 pthread_mutex_lock(&m_valuesLock);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500232 mPersist.Clear();
233 mData.Clear();
234 mConst.Clear();
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100235 pthread_mutex_unlock(&m_valuesLock);
236
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200237 SetDefaultValues();
238 return 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400239}
240
Ethan Yonkerfe916112016-03-14 14:54:37 -0500241int DataManager::LoadValues(const string& filename)
Dees_Troy51a0e822012-09-05 15:24:24 -0400242{
nkk7198fc3992017-12-16 16:26:42 +0200243 string dev_id;
Dees_Troy51a0e822012-09-05 15:24:24 -0400244
245 if (!mInitialized)
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200246 SetDefaultValues();
Dees_Troy51a0e822012-09-05 15:24:24 -0400247
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200248 GetValue("device_id", dev_id);
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400249 // Save off the backing file for set operations
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200250 mBackingFile = filename;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500251 mPersist.SetFile(filename);
252 mPersist.SetFileVersion(FILE_VERSION);
Dees_Troy51a0e822012-09-05 15:24:24 -0400253
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200254 // Read in the file, if possible
Ethan Yonkerfe916112016-03-14 14:54:37 -0500255 pthread_mutex_lock(&m_valuesLock);
256 mPersist.LoadValues();
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100257
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700258#ifndef TW_NO_SCREEN_TIMEOUT
Ethan Yonkerfe916112016-03-14 14:54:37 -0500259 blankTimer.setTime(mPersist.GetIntValue("tw_screen_timeout_secs"));
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700260#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500261
262 pthread_mutex_unlock(&m_valuesLock);
Dees_Troya13d74f2013-03-24 08:54:55 -0500263 string current = GetCurrentStoragePath();
Ethan Yonkereeed3c52014-04-16 11:49:02 -0500264 TWPartition* Part = PartitionManager.Find_Partition_By_Path(current);
Matt Mowera8a89d12016-12-30 18:10:37 -0600265 if (!Part)
Vojtech Bocek93cb1ef2014-05-12 15:41:52 +0200266 Part = PartitionManager.Get_Default_Storage_Partition();
267 if (Part && current != Part->Storage_Path && Part->Mount(false)) {
Ethan Yonkereeed3c52014-04-16 11:49:02 -0500268 LOGINFO("LoadValues setting storage path to '%s'\n", Part->Storage_Path.c_str());
269 SetValue("tw_storage_path", Part->Storage_Path);
Dees_Troya13d74f2013-03-24 08:54:55 -0500270 } else {
271 SetBackupFolder();
272 }
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200273 return 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400274}
275
nkk7198fc3992017-12-16 16:26:42 +0200276int DataManager::LoadPersistValues(void)
277{
278 static bool loaded = false;
279 string dev_id;
280
281 // Only run this function once, and make sure normal settings file has not yet been read
282 if (loaded || !mBackingFile.empty() || !TWFunc::Path_Exists(PERSIST_SETTINGS_FILE))
283 return -1;
284
285 LOGINFO("Attempt to load settings from /persist settings file...\n");
286
287 if (!mInitialized)
288 SetDefaultValues();
289
290 GetValue("device_id", dev_id);
291 mPersist.SetFile(PERSIST_SETTINGS_FILE);
292 mPersist.SetFileVersion(FILE_VERSION);
293
294 // Read in the file, if possible
295 pthread_mutex_lock(&m_valuesLock);
296 mPersist.LoadValues();
297
298#ifndef TW_NO_SCREEN_TIMEOUT
299 blankTimer.setTime(mPersist.GetIntValue("tw_screen_timeout_secs"));
300#endif
301
302 update_tz_environment_variables();
303 TWFunc::Set_Brightness(GetStrValue("tw_brightness"));
304
305 pthread_mutex_unlock(&m_valuesLock);
306
307 /* Don't set storage nor backup paths this early */
308
309 loaded = true;
310
311 return 0;
312}
313
Dees_Troy51a0e822012-09-05 15:24:24 -0400314int DataManager::Flush()
315{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200316 return SaveValues();
Dees_Troy51a0e822012-09-05 15:24:24 -0400317}
318
319int DataManager::SaveValues()
320{
Ethan Yonker83e82572014-04-04 10:59:28 -0500321#ifndef TW_OEM_BUILD
nkk7198fc3992017-12-16 16:26:42 +0200322 if (PartitionManager.Mount_By_Path("/persist", false)) {
323 mPersist.SetFile(PERSIST_SETTINGS_FILE);
324 mPersist.SetFileVersion(FILE_VERSION);
325 pthread_mutex_lock(&m_valuesLock);
326 mPersist.SaveValues();
327 pthread_mutex_unlock(&m_valuesLock);
328 LOGINFO("Saved settings file values to %s\n", PERSIST_SETTINGS_FILE);
329 }
330
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200331 if (mBackingFile.empty())
332 return -1;
Dees_Troy51a0e822012-09-05 15:24:24 -0400333
334 string mount_path = GetSettingsStoragePath();
Dees_Troy5bf43922012-09-07 16:07:55 -0400335 PartitionManager.Mount_By_Path(mount_path.c_str(), 1);
Dees_Troy51a0e822012-09-05 15:24:24 -0400336
Ethan Yonkerfe916112016-03-14 14:54:37 -0500337 mPersist.SetFile(mBackingFile);
338 mPersist.SetFileVersion(FILE_VERSION);
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100339 pthread_mutex_lock(&m_valuesLock);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500340 mPersist.SaveValues();
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100341 pthread_mutex_unlock(&m_valuesLock);
342
Ethan Yonker4b94cfd2014-12-11 10:00:45 -0600343 tw_set_default_metadata(mBackingFile.c_str());
nkk7198fc3992017-12-16 16:26:42 +0200344 LOGINFO("Saved settings file values to '%s'\n", mBackingFile.c_str());
Ethan Yonker83e82572014-04-04 10:59:28 -0500345#endif // ifdef TW_OEM_BUILD
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200346 return 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400347}
348
Ethan Yonkerfe916112016-03-14 14:54:37 -0500349int DataManager::GetValue(const string& varName, string& value)
Dees_Troy51a0e822012-09-05 15:24:24 -0400350{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200351 string localStr = varName;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500352 int ret = 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400353
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200354 if (!mInitialized)
355 SetDefaultValues();
Dees_Troy51a0e822012-09-05 15:24:24 -0400356
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200357 // Strip off leading and trailing '%' if provided
358 if (localStr.length() > 2 && localStr[0] == '%' && localStr[localStr.length()-1] == '%')
359 {
360 localStr.erase(0, 1);
361 localStr.erase(localStr.length() - 1, 1);
362 }
Dees_Troy51a0e822012-09-05 15:24:24 -0400363
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200364 // Handle magic values
365 if (GetMagicValue(localStr, value) == 0)
366 return 0;
Xuefera163f152015-03-26 22:45:04 +0800367
368 // Handle property
369 if (localStr.length() > 9 && localStr.substr(0, 9) == "property.") {
370 char property_value[PROPERTY_VALUE_MAX];
371 property_get(localStr.substr(9).c_str(), property_value, "");
372 value = property_value;
373 return 0;
374 }
375
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100376 pthread_mutex_lock(&m_valuesLock);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500377 ret = mConst.GetValue(localStr, value);
378 if (ret == 0)
379 goto exit;
Dees_Troy51a0e822012-09-05 15:24:24 -0400380
Ethan Yonkerfe916112016-03-14 14:54:37 -0500381 ret = mPersist.GetValue(localStr, value);
382 if (ret == 0)
383 goto exit;
384
385 ret = mData.GetValue(localStr, value);
386exit:
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100387 pthread_mutex_unlock(&m_valuesLock);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500388 return ret;
Dees_Troy51a0e822012-09-05 15:24:24 -0400389}
390
Ethan Yonkerfe916112016-03-14 14:54:37 -0500391int DataManager::GetValue(const string& varName, int& value)
Dees_Troy51a0e822012-09-05 15:24:24 -0400392{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200393 string data;
Dees_Troy51a0e822012-09-05 15:24:24 -0400394
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200395 if (GetValue(varName,data) != 0)
396 return -1;
Dees_Troy51a0e822012-09-05 15:24:24 -0400397
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200398 value = atoi(data.c_str());
399 return 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400400}
401
Ethan Yonkerfe916112016-03-14 14:54:37 -0500402int DataManager::GetValue(const string& varName, float& value)
Dees_Troy2673cec2013-04-02 20:22:16 +0000403{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200404 string data;
Dees_Troy2673cec2013-04-02 20:22:16 +0000405
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200406 if (GetValue(varName,data) != 0)
407 return -1;
Dees_Troy2673cec2013-04-02 20:22:16 +0000408
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200409 value = atof(data.c_str());
410 return 0;
Dees_Troy2673cec2013-04-02 20:22:16 +0000411}
412
nkk7198fc3992017-12-16 16:26:42 +0200413int DataManager::GetValue(const string& varName, unsigned long long& value)
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500414{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200415 string data;
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500416
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200417 if (GetValue(varName,data) != 0)
418 return -1;
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500419
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200420 value = strtoull(data.c_str(), NULL, 10);
421 return 0;
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500422}
423
Dees_Troy51a0e822012-09-05 15:24:24 -0400424// This function will return an empty string if the value doesn't exist
Ethan Yonkerfe916112016-03-14 14:54:37 -0500425string DataManager::GetStrValue(const string& varName)
Dees_Troy51a0e822012-09-05 15:24:24 -0400426{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200427 string retVal;
Dees_Troy51a0e822012-09-05 15:24:24 -0400428
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200429 GetValue(varName, retVal);
430 return retVal;
Dees_Troy51a0e822012-09-05 15:24:24 -0400431}
432
433// This function will return 0 if the value doesn't exist
Ethan Yonkerfe916112016-03-14 14:54:37 -0500434int DataManager::GetIntValue(const string& varName)
Dees_Troy51a0e822012-09-05 15:24:24 -0400435{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200436 string retVal;
Dees_Troy51a0e822012-09-05 15:24:24 -0400437
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200438 GetValue(varName, retVal);
439 return atoi(retVal.c_str());
Dees_Troy51a0e822012-09-05 15:24:24 -0400440}
441
Ethan Yonkerfe916112016-03-14 14:54:37 -0500442int DataManager::SetValue(const string& varName, const string& value, const int persist /* = 0 */)
Dees_Troy51a0e822012-09-05 15:24:24 -0400443{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200444 if (!mInitialized)
445 SetDefaultValues();
Dees_Troy51a0e822012-09-05 15:24:24 -0400446
Xuefera163f152015-03-26 22:45:04 +0800447 // Handle property
448 if (varName.length() > 9 && varName.substr(0, 9) == "property.") {
449 int ret = property_set(varName.substr(9).c_str(), value.c_str());
450 if (ret)
451 LOGERR("Error setting property '%s' to '%s'\n", varName.substr(9).c_str(), value.c_str());
452 return ret;
453 }
454
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200455 // Don't allow empty values or numerical starting values
456 if (varName.empty() || (varName[0] >= '0' && varName[0] <= '9'))
457 return -1;
Dees_Troy51a0e822012-09-05 15:24:24 -0400458
Ethan Yonkerfe916112016-03-14 14:54:37 -0500459 string test;
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100460 pthread_mutex_lock(&m_valuesLock);
Ethan Yonkerfe916112016-03-14 14:54:37 -0500461 int constChk = mConst.GetValue(varName, test);
462 if (constChk == 0) {
463 pthread_mutex_unlock(&m_valuesLock);
464 return -1;
465 }
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100466
Ethan Yonkerfe916112016-03-14 14:54:37 -0500467 if (persist) {
468 mPersist.SetValue(varName, value);
469 } else {
470 int persistChk = mPersist.GetValue(varName, test);
471 if (persistChk == 0) {
472 mPersist.SetValue(varName, value);
473 } else {
474 mData.SetValue(varName, value);
475 }
476 }
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700477
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100478 pthread_mutex_unlock(&m_valuesLock);
479
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700480#ifndef TW_NO_SCREEN_TIMEOUT
bigbiff bigbifff8e2f372013-02-27 20:50:43 -0500481 if (varName == "tw_screen_timeout_secs") {
Dees_Troy2f9117a2013-02-17 19:52:09 -0600482 blankTimer.setTime(atoi(value.c_str()));
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700483 } else
484#endif
485 if (varName == "tw_storage_path") {
Dees_Troya13d74f2013-03-24 08:54:55 -0500486 SetBackupFolder();
bigbiff bigbifff8e2f372013-02-27 20:50:43 -0500487 }
Dees_Troya13d74f2013-03-24 08:54:55 -0500488 gui_notifyVarChange(varName.c_str(), value.c_str());
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200489 return 0;
Dees_Troy51a0e822012-09-05 15:24:24 -0400490}
491
Ethan Yonkerfe916112016-03-14 14:54:37 -0500492int DataManager::SetValue(const string& varName, const int value, const int persist /* = 0 */)
Dees_Troy51a0e822012-09-05 15:24:24 -0400493{
494 ostringstream valStr;
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200495 valStr << value;
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200496 return SetValue(varName, valStr.str(), persist);
Dees_Troy51a0e822012-09-05 15:24:24 -0400497}
498
Ethan Yonkerfe916112016-03-14 14:54:37 -0500499int DataManager::SetValue(const string& varName, const float value, const int persist /* = 0 */)
Dees_Troy51a0e822012-09-05 15:24:24 -0400500{
501 ostringstream valStr;
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200502 valStr << value;
503 return SetValue(varName, valStr.str(), persist);;
Dees_Troy51a0e822012-09-05 15:24:24 -0400504}
505
Ethan Yonkerfe916112016-03-14 14:54:37 -0500506int DataManager::SetValue(const string& varName, const unsigned long long& value, const int persist /* = 0 */)
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500507{
508 ostringstream valStr;
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200509 valStr << value;
510 return SetValue(varName, valStr.str(), persist);
bigbiff bigbiff2c57d782013-02-19 10:09:21 -0500511}
512
Chaosmasterab164372020-02-03 15:38:02 +0100513// For legacy code that doesn't set a scope
Ethan Yonkerfe916112016-03-14 14:54:37 -0500514int DataManager::SetProgress(const float Fraction) {
Chaosmasterab164372020-02-03 15:38:02 +0100515 if (SetValue("ui_portion_size", 0) != 0)
516 return -1;
517 if (SetValue("ui_portion_start", 0) != 0)
518 return -1;
519 ShowProgress(1, 0);
520 int res = _SetProgress(Fraction);
521 if (SetValue("ui_portion_size", 0) != 0)
522 return -1;
523 if (SetValue("ui_portion_start", 0) != 0)
524 return -1;
525 return res;
Dees_Troy2673cec2013-04-02 20:22:16 +0000526}
527
Chaosmasterab164372020-02-03 15:38:02 +0100528int DataManager::_SetProgress(float Fraction) {
529 float Portion_Start, Portion_Size;
530 GetValue("ui_portion_size", Portion_Size);
531 GetValue("ui_portion_start", Portion_Start);
532 //LOGINFO("SetProgress(%.2lf): Portion_Size: %.2lf Portion_Start: %.2lf\n", Fraction, Portion_Size, Portion_Start);
533 if (Fraction < 0.0)
534 Fraction = 0;
535 if (Fraction > 1.0)
536 Fraction = 1;
537 if (SetValue("ui_progress", (float) ((Portion_Start + (Portion_Size * Fraction)) * 100.0)) != 0)
538 return -1;
539 return (SetValue("ui_progress_portion", 0) != 0);
540}
541
542int DataManager::ShowProgress(float Portion, const float Seconds)
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200543{
Chaosmasterab164372020-02-03 15:38:02 +0100544 float Portion_Start, Portion_Size;
545 GetValue("ui_portion_size", Portion_Size);
546 GetValue("ui_portion_start", Portion_Start);
547 Portion_Start += Portion_Size;
548 if(Portion + Portion_Start > 1.0)
549 Portion = 1.0 - Portion_Start;
550 //LOGINFO("ShowProgress(%.2lf, %.2lf): Portion_Start: %.2lf\n", Portion, Seconds, Portion_Start);
551 if (SetValue("ui_portion_start", Portion_Start) != 0)
Dees_Troy2673cec2013-04-02 20:22:16 +0000552 return -1;
Chaosmasterab164372020-02-03 15:38:02 +0100553 if (SetValue("ui_portion_size", Portion) != 0)
Dees_Troy2673cec2013-04-02 20:22:16 +0000554 return -1;
Chaosmasterab164372020-02-03 15:38:02 +0100555 if (SetValue("ui_progress", (float)(Portion_Start * 100.0)) != 0)
556 return -1;
557 if(Seconds) {
558 if (SetValue("ui_progress_portion", (float)((Portion * 100.0) + Portion_Start)) != 0)
559 return -1;
560 if (SetValue("ui_progress_frames", Seconds * 48) != 0)
561 return -1;
562 }
Dees_Troy2673cec2013-04-02 20:22:16 +0000563 return 0;
564}
565
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200566void DataManager::update_tz_environment_variables(void)
567{
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100568 setenv("TZ", GetStrValue(TW_TIME_ZONE_VAR).c_str(), 1);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200569 tzset();
Dees_Troy8170a922012-09-18 15:40:25 -0400570}
571
Dees_Troy16b74352012-11-14 22:27:31 +0000572void DataManager::SetBackupFolder()
573{
574 string str = GetCurrentStoragePath();
Dees_Troya13d74f2013-03-24 08:54:55 -0500575 TWPartition* partition = PartitionManager.Find_Partition_By_Path(str);
Dees_Troy16b74352012-11-14 22:27:31 +0000576 str += "/TWRP/BACKUPS/";
577
578 string dev_id;
579 GetValue("device_id", dev_id);
580
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200581 str += dev_id;
Dees_Troy2673cec2013-04-02 20:22:16 +0000582 LOGINFO("Backup folder set to '%s'\n", str.c_str());
Dees_Troy16b74352012-11-14 22:27:31 +0000583 SetValue(TW_BACKUPS_FOLDER_VAR, str, 0);
Dees_Troya13d74f2013-03-24 08:54:55 -0500584 if (partition != NULL) {
585 SetValue("tw_storage_display_name", partition->Storage_Name);
586 char free_space[255];
587 sprintf(free_space, "%llu", partition->Free / 1024 / 1024);
588 SetValue("tw_storage_free_size", free_space);
589 string zip_path, zip_root, storage_path;
590 GetValue(TW_ZIP_LOCATION_VAR, zip_path);
Ethan Yonkereadfd2e2016-02-18 22:04:18 -0600591 if (partition->Has_Data_Media && !partition->Symlink_Mount_Point.empty())
Dees_Troya13d74f2013-03-24 08:54:55 -0500592 storage_path = partition->Symlink_Mount_Point;
593 else
594 storage_path = partition->Storage_Path;
595 if (zip_path.size() < storage_path.size()) {
596 SetValue(TW_ZIP_LOCATION_VAR, storage_path);
597 } else {
Dees Troyc2e9bc72013-09-10 00:16:24 +0000598 zip_root = TWFunc::Get_Root_Path(zip_path);
Dees_Troy18727952013-06-20 15:24:48 -0500599 if (zip_root != storage_path) {
600 LOGINFO("DataManager::SetBackupFolder zip path was %s changing to %s, %s\n", zip_path.c_str(), storage_path.c_str(), zip_root.c_str());
Dees_Troya13d74f2013-03-24 08:54:55 -0500601 SetValue(TW_ZIP_LOCATION_VAR, storage_path);
Dees_Troy18727952013-06-20 15:24:48 -0500602 }
Dees_Troya13d74f2013-03-24 08:54:55 -0500603 }
604 } else {
Ethan Yonker74db1572015-10-28 12:44:49 -0500605 if (PartitionManager.Fstab_Processed() != 0) {
606 LOGINFO("Storage partition '%s' not found\n", str.c_str());
607 gui_err("unable_locate_storage=Unable to locate storage device.");
608 }
Dees_Troya13d74f2013-03-24 08:54:55 -0500609 }
Dees_Troy16b74352012-11-14 22:27:31 +0000610}
611
Dees_Troy51a0e822012-09-05 15:24:24 -0400612void DataManager::SetDefaultValues()
613{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200614 string str, path;
Dees_Troy51a0e822012-09-05 15:24:24 -0400615
Ethan Yonkerfe916112016-03-14 14:54:37 -0500616 mConst.SetConst();
617
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200618 get_device_id();
Dees_Troy51a0e822012-09-05 15:24:24 -0400619
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100620 pthread_mutex_lock(&m_valuesLock);
621
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200622 mInitialized = 1;
Dees_Troy51a0e822012-09-05 15:24:24 -0400623
Ethan Yonkerfe916112016-03-14 14:54:37 -0500624 mConst.SetValue("true", "1");
625 mConst.SetValue("false", "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400626
Ethan Yonkerfe916112016-03-14 14:54:37 -0500627 mConst.SetValue(TW_VERSION_VAR, TW_VERSION_STR);
bigbiff bigbiff3ed778a2019-03-12 19:28:31 -0400628
629#ifndef TW_NO_HAPTICS
Ethan Yonkerfe916112016-03-14 14:54:37 -0500630 mPersist.SetValue("tw_button_vibrate", "80");
631 mPersist.SetValue("tw_keyboard_vibrate", "40");
632 mPersist.SetValue("tw_action_vibrate", "160");
bigbiff bigbiff3ed778a2019-03-12 19:28:31 -0400633 mConst.SetValue("tw_disable_haptics", "0");
634#else
635 LOGINFO("TW_NO_HAPTICS := true\n");
636 mConst.SetValue("tw_disable_haptics", "1");
637#endif
Dees_Troy51a0e822012-09-05 15:24:24 -0400638
Vojtech Bocek93cb1ef2014-05-12 15:41:52 +0200639 TWPartition *store = PartitionManager.Get_Default_Storage_Partition();
Matt Mowera8a89d12016-12-30 18:10:37 -0600640 if (store)
Ethan Yonkerfe916112016-03-14 14:54:37 -0500641 mPersist.SetValue("tw_storage_path", store->Storage_Path);
Vojtech Bocek93cb1ef2014-05-12 15:41:52 +0200642 else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500643 mPersist.SetValue("tw_storage_path", "/");
Vojtech Bocek93cb1ef2014-05-12 15:41:52 +0200644
Dees_Troyf4499812013-01-23 19:07:38 +0000645#ifdef TW_FORCE_CPUINFO_FOR_DEVICE_ID
646 printf("TW_FORCE_CPUINFO_FOR_DEVICE_ID := true\n");
647#endif
648
Dees_Troy51a0e822012-09-05 15:24:24 -0400649#ifdef BOARD_HAS_NO_REAL_SDCARD
Dees_Troyf4499812013-01-23 19:07:38 +0000650 printf("BOARD_HAS_NO_REAL_SDCARD := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500651 mConst.SetValue(TW_ALLOW_PARTITION_SDCARD, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400652#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500653 mConst.SetValue(TW_ALLOW_PARTITION_SDCARD, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400654#endif
655
656#ifdef TW_INCLUDE_DUMLOCK
Dees_Troyf4499812013-01-23 19:07:38 +0000657 printf("TW_INCLUDE_DUMLOCK := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500658 mConst.SetValue(TW_SHOW_DUMLOCK, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400659#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500660 mConst.SetValue(TW_SHOW_DUMLOCK, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400661#endif
662
Dees_Troy51a0e822012-09-05 15:24:24 -0400663 str = GetCurrentStoragePath();
Ethan Yonkerfe916112016-03-14 14:54:37 -0500664 mPersist.SetValue(TW_ZIP_LOCATION_VAR, str);
Dees_Troy51a0e822012-09-05 15:24:24 -0400665 str += "/TWRP/BACKUPS/";
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400666
667 string dev_id;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500668 mConst.GetValue("device_id", dev_id);
Dees_Troyfdf5fcc2012-09-11 10:27:01 -0400669
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200670 str += dev_id;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500671 mData.SetValue(TW_BACKUPS_FOLDER_VAR, str);
Dees_Troy51a0e822012-09-05 15:24:24 -0400672
Ethan Yonkerfe916112016-03-14 14:54:37 -0500673 mConst.SetValue(TW_REBOOT_SYSTEM, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400674#ifdef TW_NO_REBOOT_RECOVERY
Talustus33ebf932013-02-02 14:11:14 +0100675 printf("TW_NO_REBOOT_RECOVERY := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500676 mConst.SetValue(TW_REBOOT_RECOVERY, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400677#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500678 mConst.SetValue(TW_REBOOT_RECOVERY, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400679#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500680 mConst.SetValue(TW_REBOOT_POWEROFF, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400681#ifdef TW_NO_REBOOT_BOOTLOADER
Talustus33ebf932013-02-02 14:11:14 +0100682 printf("TW_NO_REBOOT_BOOTLOADER := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500683 mConst.SetValue(TW_REBOOT_BOOTLOADER, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400684#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500685 mConst.SetValue(TW_REBOOT_BOOTLOADER, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400686#endif
687#ifdef RECOVERY_SDCARD_ON_DATA
Dees_Troyf4499812013-01-23 19:07:38 +0000688 printf("RECOVERY_SDCARD_ON_DATA := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500689 mConst.SetValue(TW_HAS_DATA_MEDIA, "1");
Ethan Yonker6277c792014-09-15 14:54:30 -0500690 datamedia = true;
Dees_Troy51a0e822012-09-05 15:24:24 -0400691#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500692 mData.SetValue(TW_HAS_DATA_MEDIA, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400693#endif
694#ifdef TW_NO_BATT_PERCENT
Dees_Troyf4499812013-01-23 19:07:38 +0000695 printf("TW_NO_BATT_PERCENT := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500696 mConst.SetValue(TW_NO_BATTERY_PERCENT, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400697#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500698 mConst.SetValue(TW_NO_BATTERY_PERCENT, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400699#endif
Jenkins1710bf22014-10-02 20:22:21 -0400700#ifdef TW_NO_CPU_TEMP
701 printf("TW_NO_CPU_TEMP := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500702 mConst.SetValue("tw_no_cpu_temp", "1");
Jenkins1710bf22014-10-02 20:22:21 -0400703#else
704 string cpu_temp_file;
705#ifdef TW_CUSTOM_CPU_TEMP_PATH
706 cpu_temp_file = EXPAND(TW_CUSTOM_CPU_TEMP_PATH);
707#else
708 cpu_temp_file = "/sys/class/thermal/thermal_zone0/temp";
709#endif
710 if (TWFunc::Path_Exists(cpu_temp_file)) {
Ethan Yonkerfe916112016-03-14 14:54:37 -0500711 mConst.SetValue("tw_no_cpu_temp", "0");
Jenkins1710bf22014-10-02 20:22:21 -0400712 } else {
713 LOGINFO("CPU temperature file '%s' not found, disabling CPU temp.\n", cpu_temp_file.c_str());
Ethan Yonkerfe916112016-03-14 14:54:37 -0500714 mConst.SetValue("tw_no_cpu_temp", "1");
Jenkins1710bf22014-10-02 20:22:21 -0400715 }
716#endif
Dees_Troy51a0e822012-09-05 15:24:24 -0400717#ifdef TW_CUSTOM_POWER_BUTTON
Dees_Troyf4499812013-01-23 19:07:38 +0000718 printf("TW_POWER_BUTTON := %s\n", EXPAND(TW_CUSTOM_POWER_BUTTON));
Ethan Yonkerfe916112016-03-14 14:54:37 -0500719 mConst.SetValue(TW_POWER_BUTTON, EXPAND(TW_CUSTOM_POWER_BUTTON));
Dees_Troy51a0e822012-09-05 15:24:24 -0400720#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500721 mConst.SetValue(TW_POWER_BUTTON, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400722#endif
723#ifdef TW_ALWAYS_RMRF
Dees_Troyf4499812013-01-23 19:07:38 +0000724 printf("TW_ALWAYS_RMRF := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500725 mConst.SetValue(TW_RM_RF_VAR, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400726#endif
727#ifdef TW_NEVER_UNMOUNT_SYSTEM
Dees_Troyf4499812013-01-23 19:07:38 +0000728 printf("TW_NEVER_UNMOUNT_SYSTEM := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500729 mConst.SetValue(TW_DONT_UNMOUNT_SYSTEM, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400730#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500731 mConst.SetValue(TW_DONT_UNMOUNT_SYSTEM, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400732#endif
733#ifdef TW_NO_USB_STORAGE
Dees_Troy6a042c82013-01-23 18:50:52 +0000734 printf("TW_NO_USB_STORAGE := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500735 mConst.SetValue(TW_HAS_USB_STORAGE, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400736#else
Dees_Troy6a042c82013-01-23 18:50:52 +0000737 char lun_file[255];
738 string Lun_File_str = CUSTOM_LUN_FILE;
739 size_t found = Lun_File_str.find("%");
740 if (found != string::npos) {
741 sprintf(lun_file, CUSTOM_LUN_FILE, 0);
742 Lun_File_str = lun_file;
743 }
744 if (!TWFunc::Path_Exists(Lun_File_str)) {
Dees_Troy2673cec2013-04-02 20:22:16 +0000745 LOGINFO("Lun file '%s' does not exist, USB storage mode disabled\n", Lun_File_str.c_str());
Ethan Yonkerfe916112016-03-14 14:54:37 -0500746 mConst.SetValue(TW_HAS_USB_STORAGE, "0");
Dees_Troy6a042c82013-01-23 18:50:52 +0000747 } else {
Dees_Troy2673cec2013-04-02 20:22:16 +0000748 LOGINFO("Lun file '%s'\n", Lun_File_str.c_str());
Ethan Yonkerfe916112016-03-14 14:54:37 -0500749 mData.SetValue(TW_HAS_USB_STORAGE, "1");
Dees_Troy6a042c82013-01-23 18:50:52 +0000750 }
Dees_Troy51a0e822012-09-05 15:24:24 -0400751#endif
752#ifdef TW_INCLUDE_INJECTTWRP
Dees_Troyf4499812013-01-23 19:07:38 +0000753 printf("TW_INCLUDE_INJECTTWRP := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500754 mConst.SetValue(TW_HAS_INJECTTWRP, "1");
755 mPersist(TW_INJECT_AFTER_ZIP, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400756#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500757 mConst.SetValue(TW_HAS_INJECTTWRP, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400758#endif
Dees_Troy51a0e822012-09-05 15:24:24 -0400759#ifdef TW_HAS_DOWNLOAD_MODE
Dees_Troyf4499812013-01-23 19:07:38 +0000760 printf("TW_HAS_DOWNLOAD_MODE := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500761 mConst.SetValue(TW_DOWNLOAD_MODE, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400762#endif
mauronofrioe9a49ef2018-10-03 13:38:16 +0200763#ifdef TW_HAS_EDL_MODE
764 printf("TW_HAS_EDL_MODE := true\n");
765 mConst.SetValue(TW_EDL_MODE, "1");
766#endif
Dees_Troy51a0e822012-09-05 15:24:24 -0400767#ifdef TW_INCLUDE_CRYPTO
Ethan Yonkerfe916112016-03-14 14:54:37 -0500768 mConst.SetValue(TW_HAS_CRYPTO, "1");
Dees_Troyf4499812013-01-23 19:07:38 +0000769 printf("TW_INCLUDE_CRYPTO := true\n");
Dees_Troy51a0e822012-09-05 15:24:24 -0400770#endif
771#ifdef TW_SDEXT_NO_EXT4
Dees_Troyf4499812013-01-23 19:07:38 +0000772 printf("TW_SDEXT_NO_EXT4 := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500773 mConst.SetValue(TW_SDEXT_DISABLE_EXT4, "1");
Dees_Troy51a0e822012-09-05 15:24:24 -0400774#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500775 mConst.SetValue(TW_SDEXT_DISABLE_EXT4, "0");
Dees_Troy51a0e822012-09-05 15:24:24 -0400776#endif
777
Dees_Troya13d74f2013-03-24 08:54:55 -0500778#ifdef TW_HAS_NO_BOOT_PARTITION
Ethan Yonkerfe916112016-03-14 14:54:37 -0500779 mPersist.SetValue("tw_backup_list", "/system;/data;");
Dees_Troya13d74f2013-03-24 08:54:55 -0500780#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500781 mPersist.SetValue("tw_backup_list", "/system;/data;/boot;");
Dees_Troya13d74f2013-03-24 08:54:55 -0500782#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500783 mConst.SetValue(TW_MIN_SYSTEM_VAR, TW_MIN_SYSTEM_SIZE);
784 mData.SetValue(TW_BACKUP_NAME, "(Auto Generate)");
bigbiff bigbiff7ce7f0c2013-01-25 09:54:04 -0500785
Matt Mower8dc25b72016-04-25 23:06:53 -0500786 mPersist.SetValue(TW_INSTALL_REBOOT_VAR, "0");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500787 mPersist.SetValue(TW_SIGNED_ZIP_VERIFY_VAR, "0");
Matt Mowerbfccfb82016-04-25 23:22:31 -0500788 mPersist.SetValue(TW_DISABLE_FREE_SPACE_VAR, "0");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400789 mPersist.SetValue(TW_FORCE_DIGEST_CHECK_VAR, "0");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500790 mPersist.SetValue(TW_USE_COMPRESSION_VAR, "0");
791 mPersist.SetValue(TW_TIME_ZONE_VAR, "CST6CDT,M3.2.0,M11.1.0");
792 mPersist.SetValue(TW_GUI_SORT_ORDER, "1");
793 mPersist.SetValue(TW_RM_RF_VAR, "0");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400794 mPersist.SetValue(TW_SKIP_DIGEST_CHECK_VAR, "0");
795 mPersist.SetValue(TW_SKIP_DIGEST_GENERATE_VAR, "0");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500796 mPersist.SetValue(TW_SDEXT_SIZE, "0");
797 mPersist.SetValue(TW_SWAP_SIZE, "0");
798 mPersist.SetValue(TW_SDPART_FILE_SYSTEM, "ext3");
799 mPersist.SetValue(TW_TIME_ZONE_GUISEL, "CST6;CDT,M3.2.0,M11.1.0");
800 mPersist.SetValue(TW_TIME_ZONE_GUIOFFSET, "0");
801 mPersist.SetValue(TW_TIME_ZONE_GUIDST, "1");
802 mData.SetValue(TW_ACTION_BUSY, "0");
803 mData.SetValue("tw_wipe_cache", "0");
804 mData.SetValue("tw_wipe_dalvik", "0");
805 mData.SetValue(TW_ZIP_INDEX, "0");
806 mData.SetValue(TW_ZIP_QUEUE_COUNT, "0");
807 mData.SetValue(TW_FILENAME, "/sdcard");
808 mData.SetValue(TW_SIMULATE_ACTIONS, "0");
809 mData.SetValue(TW_SIMULATE_FAIL, "0");
810 mData.SetValue(TW_IS_ENCRYPTED, "0");
811 mData.SetValue(TW_IS_DECRYPTED, "0");
812 mData.SetValue(TW_CRYPTO_PASSWORD, "0");
813 mData.SetValue("tw_terminal_state", "0");
814 mData.SetValue("tw_background_thread_running", "0");
815 mData.SetValue(TW_RESTORE_FILE_DATE, "0");
816 mPersist.SetValue("tw_military_time", "0");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400817
818#ifdef TW_INCLUDE_CRYPTO
bigbiff bigbiff9ee4a852018-09-19 19:13:19 -0400819 mPersist.SetValue(TW_USE_SHA2, "1");
820 mPersist.SetValue(TW_NO_SHA2, "0");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400821#else
bigbiff bigbiff9ee4a852018-09-19 19:13:19 -0400822 mPersist.SetValue(TW_NO_SHA2, "1");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400823#endif
Chaosmasterff4f9582020-01-26 15:38:11 +0100824 mPersist.SetValue(TW_UNMOUNT_SYSTEM, "1");
bigbiff bigbiff56cf5642016-08-19 17:43:45 -0400825
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700826#ifdef TW_NO_SCREEN_TIMEOUT
Ethan Yonkerfe916112016-03-14 14:54:37 -0500827 mConst.SetValue("tw_screen_timeout_secs", "0");
828 mConst.SetValue("tw_no_screen_timeout", "1");
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700829#else
Ethan Yonkerfe916112016-03-14 14:54:37 -0500830 mPersist.SetValue("tw_screen_timeout_secs", "60");
831 mPersist.SetValue("tw_no_screen_timeout", "0");
Ricardo Gomezc9ecd442013-07-05 16:13:52 -0700832#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500833 mData.SetValue("tw_gui_done", "0");
834 mData.SetValue("tw_encrypt_backup", "0");
Matt Mower9a2a2052016-05-31 21:31:22 -0500835 mData.SetValue("tw_sleep_total", "5");
836 mData.SetValue("tw_sleep", "5");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500837
838 // Brightness handling
Ethan Yonker00028b42014-04-09 14:29:02 -0500839 string findbright;
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900840#ifdef TW_BRIGHTNESS_PATH
841 findbright = EXPAND(TW_BRIGHTNESS_PATH);
842 LOGINFO("TW_BRIGHTNESS_PATH := %s\n", findbright.c_str());
843 if (!TWFunc::Path_Exists(findbright)) {
844 LOGINFO("Specified brightness file '%s' not found.\n", findbright.c_str());
845 findbright = "";
Ethan Yonker00028b42014-04-09 14:29:02 -0500846 }
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900847#endif
Ethan Yonker00028b42014-04-09 14:29:02 -0500848 if (findbright.empty()) {
849 // Attempt to locate the brightness file
850 findbright = Find_File::Find("brightness", "/sys/class/backlight");
Ethan Yonker9c102b52014-04-15 11:06:18 -0500851 if (findbright.empty()) findbright = Find_File::Find("brightness", "/sys/class/leds/lcd-backlight");
Ethan Yonker00028b42014-04-09 14:29:02 -0500852 }
853 if (findbright.empty()) {
854 LOGINFO("Unable to locate brightness file\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500855 mConst.SetValue("tw_has_brightnesss_file", "0");
Ethan Yonker00028b42014-04-09 14:29:02 -0500856 } else {
857 LOGINFO("Found brightness file at '%s'\n", findbright.c_str());
Ethan Yonkerfe916112016-03-14 14:54:37 -0500858 mConst.SetValue("tw_has_brightnesss_file", "1");
859 mConst.SetValue("tw_brightness_file", findbright);
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900860 string maxBrightness;
861#ifdef TW_MAX_BRIGHTNESS
Vojtech Bocek85932342013-04-01 22:11:33 +0200862 ostringstream maxVal;
863 maxVal << TW_MAX_BRIGHTNESS;
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900864 maxBrightness = maxVal.str();
865#else
866 // Attempt to locate the max_brightness file
867 string maxbrightpath = findbright.insert(findbright.rfind('/') + 1, "max_");
868 if (TWFunc::Path_Exists(maxbrightpath)) {
Ethan Yonker72a85202016-01-22 11:45:06 -0600869 ifstream maxVal(maxbrightpath.c_str());
Matt Mowera8a89d12016-12-30 18:10:37 -0600870 if (maxVal >> maxBrightness) {
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900871 LOGINFO("Got max brightness %s from '%s'\n", maxBrightness.c_str(), maxbrightpath.c_str());
872 } else {
873 // Something went wrong, set that to indicate error
874 maxBrightness = "-1";
875 }
876 }
Ethan Yonker72a85202016-01-22 11:45:06 -0600877 if (atoi(maxBrightness.c_str()) <= 0)
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900878 {
879 // Fallback into default
880 ostringstream maxVal;
881 maxVal << 255;
882 maxBrightness = maxVal.str();
883 }
884#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500885 mConst.SetValue("tw_brightness_max", maxBrightness);
886 mPersist.SetValue("tw_brightness", maxBrightness);
887 mPersist.SetValue("tw_brightness_pct", "100");
xNUTxe85f02d2014-07-18 01:30:58 +0200888#ifdef TW_SECONDARY_BRIGHTNESS_PATH
889 string secondfindbright = EXPAND(TW_SECONDARY_BRIGHTNESS_PATH);
890 if (secondfindbright != "" && TWFunc::Path_Exists(secondfindbright)) {
891 LOGINFO("Will use a second brightness file at '%s'\n", secondfindbright.c_str());
Ethan Yonkerfe916112016-03-14 14:54:37 -0500892 mConst.SetValue("tw_secondary_brightness_file", secondfindbright);
xNUTxe85f02d2014-07-18 01:30:58 +0200893 } else {
894 LOGINFO("Specified secondary brightness file '%s' not found.\n", secondfindbright.c_str());
895 }
896#endif
Greg Wallace36ade452015-11-08 13:54:25 -0500897#ifdef TW_DEFAULT_BRIGHTNESS
898 int defValInt = TW_DEFAULT_BRIGHTNESS;
Ethan Yonker72a85202016-01-22 11:45:06 -0600899 int maxValInt = atoi(maxBrightness.c_str());
Greg Wallace36ade452015-11-08 13:54:25 -0500900 // Deliberately int so the % is always a whole number
901 int defPctInt = ( ( (double)defValInt / maxValInt ) * 100 );
902 ostringstream defPct;
903 defPct << defPctInt;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500904 mPersist.SetValue("tw_brightness_pct", defPct.str());
Greg Wallace36ade452015-11-08 13:54:25 -0500905
906 ostringstream defVal;
907 defVal << TW_DEFAULT_BRIGHTNESS;
Ethan Yonkerfe916112016-03-14 14:54:37 -0500908 mPersist.SetValue("tw_brightness", defVal.str());
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900909 TWFunc::Set_Brightness(defVal.str());
Greg Wallace36ade452015-11-08 13:54:25 -0500910#else
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +0900911 TWFunc::Set_Brightness(maxBrightness);
Greg Wallace36ade452015-11-08 13:54:25 -0500912#endif
Dees_Troy2f9117a2013-02-17 19:52:09 -0600913 }
Ethan Yonkerfe916112016-03-14 14:54:37 -0500914
Dees_Troy83bd4832013-05-04 12:39:56 +0000915#ifndef TW_EXCLUDE_ENCRYPTED_BACKUPS
Ethan Yonkerfe916112016-03-14 14:54:37 -0500916 mConst.SetValue("tw_include_encrypted_backup", "1");
Dees_Troy83bd4832013-05-04 12:39:56 +0000917#else
918 LOGINFO("TW_EXCLUDE_ENCRYPTED_BACKUPS := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500919 mConst.SetValue("tw_include_encrypted_backup", "0");
Dees_Troy83bd4832013-05-04 12:39:56 +0000920#endif
bigbiff bigbiffc7eee6f2014-09-02 18:59:01 -0400921#ifdef TW_HAS_MTP
Ethan Yonkerfe916112016-03-14 14:54:37 -0500922 mConst.SetValue("tw_has_mtp", "1");
923 mPersist.SetValue("tw_mtp_enabled", "1");
924 mPersist.SetValue("tw_mtp_debug", "0");
bigbiff bigbiffc7eee6f2014-09-02 18:59:01 -0400925#else
926 LOGINFO("TW_EXCLUDE_MTP := true\n");
Ethan Yonkerfe916112016-03-14 14:54:37 -0500927 mConst.SetValue("tw_has_mtp", "0");
928 mConst.SetValue("tw_mtp_enabled", "0");
bigbiff bigbiffc7eee6f2014-09-02 18:59:01 -0400929#endif
Ethan Yonkerfe916112016-03-14 14:54:37 -0500930 mPersist.SetValue("tw_mount_system_ro", "2");
931 mPersist.SetValue("tw_never_show_system_ro_page", "0");
932 mPersist.SetValue("tw_language", EXPAND(TW_DEFAULT_LANGUAGE));
Ethan Yonker74db1572015-10-28 12:44:49 -0500933 LOGINFO("LANG: %s\n", EXPAND(TW_DEFAULT_LANGUAGE));
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100934
Ethan Yonkerfe916112016-03-14 14:54:37 -0500935 mData.SetValue("tw_has_adopted_storage", "0");
Ethan Yonker66a19492015-12-10 10:19:45 -0600936
Ethan Yonker1b190162016-12-05 15:25:19 -0600937#ifdef AB_OTA_UPDATER
938 LOGINFO("AB_OTA_UPDATER := true\n");
939 mConst.SetValue("tw_has_boot_slots", "1");
940#else
941 mConst.SetValue("tw_has_boot_slots", "0");
942#endif
nkk71b4c35912017-10-11 23:39:10 +0300943
Ethan Yonker75aa6152017-09-08 12:17:03 -0500944#ifdef TW_NO_LEGACY_PROPS
945 LOGINFO("TW_NO_LEGACY_PROPS := true\n");
Ethan Yonker75aa6152017-09-08 12:17:03 -0500946#endif
nkk71b4c35912017-10-11 23:39:10 +0300947
Ethan Yonkerb4bff5e2016-12-16 07:47:58 -0600948#ifdef TW_OEM_BUILD
949 LOGINFO("TW_OEM_BUILD := true\n");
950 mConst.SetValue("tw_oem_build", "1");
Ethan Yonker76bbd3a2019-05-10 10:50:04 -0500951 mConst.SetValue("tw_app_installed_in_system", "0");
Ethan Yonkerb4bff5e2016-12-16 07:47:58 -0600952#else
953 mConst.SetValue("tw_oem_build", "0");
954 mPersist.SetValue("tw_app_prompt", "1");
955 mPersist.SetValue("tw_app_install_system", "1");
956 mData.SetValue("tw_app_install_status", "0"); // 0 = no status, 1 = not installed, 2 = already installed
Ethan Yonker76bbd3a2019-05-10 10:50:04 -0500957 mData.SetValue("tw_app_installed_in_system", "0");
Ethan Yonkerb4bff5e2016-12-16 07:47:58 -0600958#endif
959
Ethan Yonker53796e72019-01-11 22:49:52 -0600960 mData.SetValue("tw_enable_adb_backup", "0");
961
962 if (TWFunc::Path_Exists("/sbin/magiskboot"))
963 mConst.SetValue("tw_has_repack_tools", "1");
964 else
965 mConst.SetValue("tw_has_repack_tools", "0");
jason972000adae3362017-12-08 09:08:45 -0600966
Vojtech Bocekfda239b2015-01-07 22:55:13 +0100967 pthread_mutex_unlock(&m_valuesLock);
Dees_Troy51a0e822012-09-05 15:24:24 -0400968}
969
970// Magic Values
Ethan Yonkerfe916112016-03-14 14:54:37 -0500971int DataManager::GetMagicValue(const string& varName, string& value)
Dees_Troy51a0e822012-09-05 15:24:24 -0400972{
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200973 // Handle special dynamic cases
974 if (varName == "tw_time")
975 {
976 char tmp[32];
Dees_Troy51a0e822012-09-05 15:24:24 -0400977
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200978 struct tm *current;
979 time_t now;
980 int tw_military_time;
981 now = time(0);
982 current = localtime(&now);
Matt Mowerfb1c4ff2014-04-16 13:43:36 -0500983 GetValue(TW_MILITARY_TIME, tw_military_time);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200984 if (current->tm_hour >= 12)
985 {
986 if (tw_military_time == 1)
987 sprintf(tmp, "%d:%02d", current->tm_hour, current->tm_min);
988 else
989 sprintf(tmp, "%d:%02d PM", current->tm_hour == 12 ? 12 : current->tm_hour - 12, current->tm_min);
bigbiff bigbiff4efe9c32013-02-20 18:58:11 -0500990 }
bigbiff bigbiff4efe9c32013-02-20 18:58:11 -0500991 else
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200992 {
Matt Mowerfb1c4ff2014-04-16 13:43:36 -0500993 if (tw_military_time == 1)
Vojtech Bocekfafb0c52013-07-25 22:53:02 +0200994 sprintf(tmp, "%d:%02d", current->tm_hour, current->tm_min);
995 else
996 sprintf(tmp, "%d:%02d AM", current->tm_hour == 0 ? 12 : current->tm_hour, current->tm_min);
997 }
998 value = tmp;
999 return 0;
bigbiff bigbiff4efe9c32013-02-20 18:58:11 -05001000 }
Jenkins1710bf22014-10-02 20:22:21 -04001001 else if (varName == "tw_cpu_temp")
1002 {
Matt Mowera8a89d12016-12-30 18:10:37 -06001003 int tw_no_cpu_temp;
1004 GetValue("tw_no_cpu_temp", tw_no_cpu_temp);
1005 if (tw_no_cpu_temp == 1) return -1;
Agontuka29361a2015-04-22 14:42:59 +06001006
Matt Mowera8a89d12016-12-30 18:10:37 -06001007 string cpu_temp_file;
1008 static unsigned long convert_temp = 0;
1009 static time_t cpuSecCheck = 0;
Matt Mowera8a89d12016-12-30 18:10:37 -06001010 struct timeval curTime;
1011 string results;
Jenkins1710bf22014-10-02 20:22:21 -04001012
Matt Mowera8a89d12016-12-30 18:10:37 -06001013 gettimeofday(&curTime, NULL);
1014 if (curTime.tv_sec > cpuSecCheck)
1015 {
Jenkins1710bf22014-10-02 20:22:21 -04001016#ifdef TW_CUSTOM_CPU_TEMP_PATH
Matt Mowera8a89d12016-12-30 18:10:37 -06001017 cpu_temp_file = EXPAND(TW_CUSTOM_CPU_TEMP_PATH);
1018 if (TWFunc::read_file(cpu_temp_file, results) != 0)
1019 return -1;
Jenkins1710bf22014-10-02 20:22:21 -04001020#else
Matt Mowera8a89d12016-12-30 18:10:37 -06001021 cpu_temp_file = "/sys/class/thermal/thermal_zone0/temp";
1022 if (TWFunc::read_file(cpu_temp_file, results) != 0)
1023 return -1;
Jenkins1710bf22014-10-02 20:22:21 -04001024#endif
Matt Mowera8a89d12016-12-30 18:10:37 -06001025 convert_temp = strtoul(results.c_str(), NULL, 0) / 1000;
1026 if (convert_temp <= 0)
1027 convert_temp = strtoul(results.c_str(), NULL, 0);
1028 if (convert_temp >= 150)
1029 convert_temp = strtoul(results.c_str(), NULL, 0) / 10;
1030 cpuSecCheck = curTime.tv_sec + 5;
1031 }
1032 value = TWFunc::to_string(convert_temp);
1033 return 0;
Jenkins1710bf22014-10-02 20:22:21 -04001034 }
Vojtech Bocekfafb0c52013-07-25 22:53:02 +02001035 else if (varName == "tw_battery")
1036 {
1037 char tmp[16];
Dees_Troy38bd7602012-09-14 13:33:53 -04001038 static char charging = ' ';
1039 static int lastVal = -1;
1040 static time_t nextSecCheck = 0;
Dees_Troy38bd7602012-09-14 13:33:53 -04001041 struct timeval curTime;
1042 gettimeofday(&curTime, NULL);
1043 if (curTime.tv_sec > nextSecCheck)
1044 {
1045 char cap_s[4];
Dees_Troyf33b4902013-03-01 00:51:39 +00001046#ifdef TW_CUSTOM_BATTERY_PATH
1047 string capacity_file = EXPAND(TW_CUSTOM_BATTERY_PATH);
1048 capacity_file += "/capacity";
1049 FILE * cap = fopen(capacity_file.c_str(),"rt");
1050#else
Dees_Troy38bd7602012-09-14 13:33:53 -04001051 FILE * cap = fopen("/sys/class/power_supply/battery/capacity","rt");
Dees_Troyf33b4902013-03-01 00:51:39 +00001052#endif
Matt Mowera8a89d12016-12-30 18:10:37 -06001053 if (cap) {
Dees_Troy38bd7602012-09-14 13:33:53 -04001054 fgets(cap_s, 4, cap);
1055 fclose(cap);
1056 lastVal = atoi(cap_s);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +02001057 if (lastVal > 100) lastVal = 101;
1058 if (lastVal < 0) lastVal = 0;
Dees_Troy38bd7602012-09-14 13:33:53 -04001059 }
Dees_Troyf33b4902013-03-01 00:51:39 +00001060#ifdef TW_CUSTOM_BATTERY_PATH
1061 string status_file = EXPAND(TW_CUSTOM_BATTERY_PATH);
1062 status_file += "/status";
1063 cap = fopen(status_file.c_str(),"rt");
1064#else
Dees_Troy38bd7602012-09-14 13:33:53 -04001065 cap = fopen("/sys/class/power_supply/battery/status","rt");
Dees_Troyf33b4902013-03-01 00:51:39 +00001066#endif
Dees_Troy38bd7602012-09-14 13:33:53 -04001067 if (cap) {
1068 fgets(cap_s, 2, cap);
1069 fclose(cap);
1070 if (cap_s[0] == 'C')
1071 charging = '+';
1072 else
1073 charging = ' ';
1074 }
1075 nextSecCheck = curTime.tv_sec + 60;
1076 }
1077
1078 sprintf(tmp, "%i%%%c", lastVal, charging);
Vojtech Bocekfafb0c52013-07-25 22:53:02 +02001079 value = tmp;
1080 return 0;
1081 }
1082 return -1;
Dees_Troy51a0e822012-09-05 15:24:24 -04001083}
1084
Vojtech Bocekfafb0c52013-07-25 22:53:02 +02001085void DataManager::Output_Version(void)
1086{
Ethan Yonker89583ef2015-08-26 09:01:59 -05001087#ifndef TW_OEM_BUILD
Dees_Troy1c1ac442013-01-17 21:42:14 +00001088 string Path;
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001089 char version[255];
1090
bigbiff349ea552020-06-19 16:07:38 -04001091 std::string logDir = TWFunc::get_log_dir();
1092 if (logDir.empty()) {
bigbiff bigbiffe4bdb152019-03-23 18:33:17 -04001093 LOGINFO("Unable to find cache directory\n");
1094 return;
1095 }
1096
bigbiff349ea552020-06-19 16:07:38 -04001097 std::string recoveryLogDir = logDir + "recovery/";
bigbiff bigbiff19874f12019-01-08 20:06:57 -05001098
bigbiff349ea552020-06-19 16:07:38 -04001099 if (logDir == CACHE_LOGS_DIR) {
1100 if (!PartitionManager.Mount_By_Path(CACHE_LOGS_DIR, false)) {
bigbiff bigbiff19874f12019-01-08 20:06:57 -05001101 LOGINFO("Unable to mount '%s' to write version number.\n", Path.c_str());
Dees_Troy1c1ac442013-01-17 21:42:14 +00001102 return;
1103 }
Mohd Faraz3754fab2020-06-06 20:50:57 +05301104
bigbiff349ea552020-06-19 16:07:38 -04001105 if (!TWFunc::Path_Exists(recoveryLogDir)) {
1106 LOGINFO("Recreating %s folder.\n", recoveryLogDir.c_str());
1107 if (!TWFunc::Create_Dir_Recursive(recoveryLogDir.c_str(), S_IRWXU | S_IRWXG | S_IWGRP | S_IXGRP, 0, 0)) {
1108 LOGERR("DataManager::Output_Version -- Unable to make %s: %s\n", recoveryLogDir.c_str(), strerror(errno));
Mohd Faraz3754fab2020-06-06 20:50:57 +05301109 return;
1110 }
1111 }
Dees_Troy1c1ac442013-01-17 21:42:14 +00001112 }
bigbiffa2bd7b72020-05-07 21:45:34 -04001113
bigbiff349ea552020-06-19 16:07:38 -04001114 std::string verPath = recoveryLogDir + ".version";
bigbiff bigbiff19874f12019-01-08 20:06:57 -05001115 if (TWFunc::Path_Exists(verPath)) {
1116 unlink(verPath.c_str());
1117 }
1118 FILE *fp = fopen(verPath.c_str(), "w");
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001119 if (fp == NULL) {
bigbiff bigbiff19874f12019-01-08 20:06:57 -05001120 gui_msg(Msg(msg::kError, "error_opening_strerr=Error opening: '{1}' ({2})")(verPath)(strerror(errno)));
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001121 return;
1122 }
1123 strcpy(version, TW_VERSION_STR);
1124 fwrite(version, sizeof(version[0]), strlen(version) / sizeof(version[0]), fp);
1125 fclose(fp);
bigbiff349ea552020-06-19 16:07:38 -04001126 TWFunc::copy_file("/etc/recovery.fstab", recoveryLogDir + "recovery.fstab", 0644);
Dees_Troyd93bda52013-07-03 19:55:19 +00001127 PartitionManager.Output_Storage_Fstab();
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001128 sync();
bigbiff bigbiff19874f12019-01-08 20:06:57 -05001129 LOGINFO("Version number saved to '%s'\n", verPath.c_str());
Ethan Yonker89583ef2015-08-26 09:01:59 -05001130#endif
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001131}
1132
Dees_Troy51a0e822012-09-05 15:24:24 -04001133void DataManager::ReadSettingsFile(void)
1134{
Ethan Yonker83e82572014-04-04 10:59:28 -05001135#ifndef TW_OEM_BUILD
Dees_Troy51a0e822012-09-05 15:24:24 -04001136 // Load up the values for TWRP - Sleep to let the card be ready
1137 char mkdir_path[255], settings_file[255];
Matt Mower23d8aae2017-01-06 14:30:33 -06001138 int is_enc, has_data_media;
Dees_Troy51a0e822012-09-05 15:24:24 -04001139
1140 GetValue(TW_IS_ENCRYPTED, is_enc);
1141 GetValue(TW_HAS_DATA_MEDIA, has_data_media);
Dees_Troy51a0e822012-09-05 15:24:24 -04001142
1143 memset(mkdir_path, 0, sizeof(mkdir_path));
1144 memset(settings_file, 0, sizeof(settings_file));
Vojtech Bocekfda239b2015-01-07 22:55:13 +01001145 sprintf(mkdir_path, "%s/TWRP", GetSettingsStoragePath().c_str());
Dees_Troy51a0e822012-09-05 15:24:24 -04001146 sprintf(settings_file, "%s/.twrps", mkdir_path);
1147
Dees_Troy5bf43922012-09-07 16:07:55 -04001148 if (!PartitionManager.Mount_Settings_Storage(false))
Dees_Troy51a0e822012-09-05 15:24:24 -04001149 {
1150 usleep(500000);
Dees_Troy5bf43922012-09-07 16:07:55 -04001151 if (!PartitionManager.Mount_Settings_Storage(false))
Ethan Yonker74db1572015-10-28 12:44:49 -05001152 gui_msg(Msg(msg::kError, "unable_to_mount=Unable to mount {1}")(settings_file));
Dees_Troy51a0e822012-09-05 15:24:24 -04001153 }
1154
1155 mkdir(mkdir_path, 0777);
1156
Dees_Troy2673cec2013-04-02 20:22:16 +00001157 LOGINFO("Attempt to load settings from settings file...\n");
Dees_Troy51a0e822012-09-05 15:24:24 -04001158 LoadValues(settings_file);
Dees_Troy01a9b7a2012-10-01 09:01:03 -04001159 Output_Version();
Ethan Yonker83e82572014-04-04 10:59:28 -05001160#endif // ifdef TW_OEM_BUILD
Ethan Yonker7af51ce2014-04-04 13:33:30 -05001161 PartitionManager.Mount_All_Storage();
Dees_Troy8170a922012-09-18 15:40:25 -04001162 update_tz_environment_variables();
Tatsuyuki Ishi548a1752015-12-28 10:08:58 +09001163 TWFunc::Set_Brightness(GetStrValue("tw_brightness"));
Dees_Troy51a0e822012-09-05 15:24:24 -04001164}
1165
1166string DataManager::GetCurrentStoragePath(void)
1167{
Dees_Troya13d74f2013-03-24 08:54:55 -05001168 return GetStrValue("tw_storage_path");
Dees_Troy51a0e822012-09-05 15:24:24 -04001169}
1170
Dees_Troy51a0e822012-09-05 15:24:24 -04001171string DataManager::GetSettingsStoragePath(void)
1172{
Dees_Troya13d74f2013-03-24 08:54:55 -05001173 return GetStrValue("tw_settings_path");
Dees_Troy51a0e822012-09-05 15:24:24 -04001174}
1175
Ethan Yonkerfe916112016-03-14 14:54:37 -05001176void DataManager::Vibrate(const string& varName)
Samer Diab (S.a.M.e.R_d)71e9b042014-01-07 20:18:47 +00001177{
bigbiff bigbiff3ed778a2019-03-12 19:28:31 -04001178#ifndef TW_NO_HAPTICS
Samer Diab (S.a.M.e.R_d)71e9b042014-01-07 20:18:47 +00001179 int vib_value = 0;
1180 GetValue(varName, vib_value);
1181 if (vib_value) {
1182 vibrate(vib_value);
1183 }
bigbiff bigbiff3ed778a2019-03-12 19:28:31 -04001184#endif
Samer Diab (S.a.M.e.R_d)71e9b042014-01-07 20:18:47 +00001185}