Add debug log setting and custom endpoint settings
This commit is contained in:
parent
190d650887
commit
bc3e5afe51
7 changed files with 95 additions and 30 deletions
|
@ -284,6 +284,22 @@ void setupPreferences()
|
||||||
setBlockHeight(preferences.getUInt("blockHeight", INITIAL_BLOCK_HEIGHT));
|
setBlockHeight(preferences.getUInt("blockHeight", INITIAL_BLOCK_HEIGHT));
|
||||||
setPrice(preferences.getUInt("lastPrice", INITIAL_LAST_PRICE), CURRENCY_USD);
|
setPrice(preferences.getUInt("lastPrice", INITIAL_LAST_PRICE), CURRENCY_USD);
|
||||||
|
|
||||||
|
if (!preferences.isKey("enableDebugLog")) {
|
||||||
|
preferences.putBool("enableDebugLog", DEFAULT_ENABLE_DEBUG_LOG);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!preferences.isKey("ceEnabled")) {
|
||||||
|
preferences.putBool("ceEnabled", DEFAULT_CUSTOM_ENDPOINT_ENABLED);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!preferences.isKey("ceEndpoint")) {
|
||||||
|
preferences.putString("ceEndpoint", DEFAULT_CUSTOM_ENDPOINT);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!preferences.isKey("ceDisableSSL")) {
|
||||||
|
preferences.putBool("ceDisableSSL", DEFAULT_CUSTOM_ENDPOINT_DISABLE_SSL);
|
||||||
|
}
|
||||||
|
|
||||||
if (preferences.getBool("ownDataSource", DEFAULT_OWN_DATA_SOURCE))
|
if (preferences.getBool("ownDataSource", DEFAULT_OWN_DATA_SOURCE))
|
||||||
ScreenHandler::setCurrentCurrency(preferences.getUChar("lastCurrency", CURRENCY_USD));
|
ScreenHandler::setCurrentCurrency(preferences.getUChar("lastCurrency", CURRENCY_USD));
|
||||||
else
|
else
|
||||||
|
@ -767,3 +783,8 @@ const char* getWebUiFilename() {
|
||||||
return "littlefs_4MB.bin";
|
return "littlefs_4MB.bin";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool debugLogEnabled()
|
||||||
|
{
|
||||||
|
return preferences.getBool("enableDebugLog", DEFAULT_ENABLE_DEBUG_LOG);
|
||||||
|
}
|
||||||
|
|
|
@ -77,6 +77,8 @@ String getHwRev();
|
||||||
bool isWhiteVersion();
|
bool isWhiteVersion();
|
||||||
String getFsRev();
|
String getFsRev();
|
||||||
|
|
||||||
|
bool debugLogEnabled();
|
||||||
|
|
||||||
void addScreenMapping(int value, const char* name);
|
void addScreenMapping(int value, const char* name);
|
||||||
// void addScreenMapping(int value, const String& name);
|
// void addScreenMapping(int value, const String& name);
|
||||||
// void addScreenMapping(int value, const std::string& name);
|
// void addScreenMapping(int value, const std::string& name);
|
||||||
|
|
|
@ -17,7 +17,9 @@
|
||||||
#define DEFAULT_DISABLE_LEDS false
|
#define DEFAULT_DISABLE_LEDS false
|
||||||
#define DEFAULT_DISABLE_FL false
|
#define DEFAULT_DISABLE_FL false
|
||||||
#define DEFAULT_OWN_DATA_SOURCE true
|
#define DEFAULT_OWN_DATA_SOURCE true
|
||||||
#define DEFAULT_STAGING_SOURCE false
|
#define DEFAULT_CUSTOM_SOURCE false
|
||||||
|
#define DEFAULT_CUSTOM_EP "ws-staging.btclock.dev"
|
||||||
|
#define DEFAULT_CUSTOM_SSL true
|
||||||
#define DEFAULT_MOW_MODE false
|
#define DEFAULT_MOW_MODE false
|
||||||
#define DEFAULT_SUFFIX_SHARE_DOT false
|
#define DEFAULT_SUFFIX_SHARE_DOT false
|
||||||
|
|
||||||
|
@ -77,3 +79,12 @@
|
||||||
#define DEFAULT_VERTICAL_DESC true
|
#define DEFAULT_VERTICAL_DESC true
|
||||||
|
|
||||||
#define DEFAULT_MINING_POOL_LOGOS_URL "https://git.btclock.dev/btclock/mining-pool-logos/raw/branch/main"
|
#define DEFAULT_MINING_POOL_LOGOS_URL "https://git.btclock.dev/btclock/mining-pool-logos/raw/branch/main"
|
||||||
|
|
||||||
|
#define DEFAULT_ENABLE_DEBUG_LOG false
|
||||||
|
|
||||||
|
#define DEFAULT_DISABLE_FL false
|
||||||
|
#define DEFAULT_OWN_DATA_SOURCE true
|
||||||
|
#define DEFAULT_CUSTOM_ENDPOINT_ENABLED false
|
||||||
|
#define DEFAULT_CUSTOM_ENDPOINT "ws-staging.btclock.dev"
|
||||||
|
#define DEFAULT_CUSTOM_ENDPOINT_DISABLE_SSL false
|
||||||
|
#define DEFAULT_MOW_MODE false
|
||||||
|
|
|
@ -36,6 +36,10 @@ void taskMiningPoolStatsFetch(void *pvParameters)
|
||||||
poolInterface->setPoolUser(poolUser);
|
poolInterface->setPoolUser(poolUser);
|
||||||
std::string apiUrl = poolInterface->getApiUrl();
|
std::string apiUrl = poolInterface->getApiUrl();
|
||||||
http.begin(apiUrl.c_str());
|
http.begin(apiUrl.c_str());
|
||||||
|
if (debugLogEnabled())
|
||||||
|
{
|
||||||
|
Serial.printf("Fetching mining pool stats from %s\r\n", apiUrl.c_str());
|
||||||
|
}
|
||||||
poolInterface->prepareRequest(http);
|
poolInterface->prepareRequest(http);
|
||||||
int httpCode = http.GET();
|
int httpCode = http.GET();
|
||||||
if (httpCode == 200)
|
if (httpCode == 200)
|
||||||
|
@ -44,10 +48,20 @@ void taskMiningPoolStatsFetch(void *pvParameters)
|
||||||
JsonDocument doc;
|
JsonDocument doc;
|
||||||
deserializeJson(doc, payload);
|
deserializeJson(doc, payload);
|
||||||
|
|
||||||
|
if (debugLogEnabled())
|
||||||
|
{
|
||||||
|
Serial.printf("Mining pool stats response: %s\r\n", payload.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
PoolStats stats = poolInterface->parseResponse(doc);
|
PoolStats stats = poolInterface->parseResponse(doc);
|
||||||
|
|
||||||
miningPoolStatsHashrate = stats.hashrate;
|
miningPoolStatsHashrate = stats.hashrate;
|
||||||
|
|
||||||
|
if (debugLogEnabled())
|
||||||
|
{
|
||||||
|
Serial.printf("Mining pool stats parsed hashrate: %s\r\n", stats.hashrate.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
if (stats.dailyEarnings)
|
if (stats.dailyEarnings)
|
||||||
{
|
{
|
||||||
miningPoolStatsDailyEarnings = *stats.dailyEarnings;
|
miningPoolStatsDailyEarnings = *stats.dailyEarnings;
|
||||||
|
|
|
@ -267,7 +267,10 @@ void handleNostrZapCallback(const String &subId, nostr::SignedNostrEvent *event)
|
||||||
|
|
||||||
std::array<std::string, NUM_SCREENS> textEpdContent = parseZapNotify(zapAmount, preferences.getBool("useSatsSymbol", DEFAULT_USE_SATS_SYMBOL));
|
std::array<std::string, NUM_SCREENS> textEpdContent = parseZapNotify(zapAmount, preferences.getBool("useSatsSymbol", DEFAULT_USE_SATS_SYMBOL));
|
||||||
|
|
||||||
Serial.printf("Got a zap of %llu sats for %s\n", zapAmount, zapPubkey.c_str());
|
if (debugLogEnabled())
|
||||||
|
{
|
||||||
|
Serial.printf("Got a zap of %llu sats for %s\n", zapAmount, zapPubkey.c_str());
|
||||||
|
}
|
||||||
|
|
||||||
uint64_t timerPeriod = 0;
|
uint64_t timerPeriod = 0;
|
||||||
if (isTimerActive())
|
if (isTimerActive())
|
||||||
|
|
|
@ -8,25 +8,36 @@ namespace V2Notify
|
||||||
|
|
||||||
TaskHandle_t v2NotifyTaskHandle;
|
TaskHandle_t v2NotifyTaskHandle;
|
||||||
|
|
||||||
|
String currentHostname;
|
||||||
|
|
||||||
void setupV2Notify()
|
void setupV2Notify()
|
||||||
{
|
{
|
||||||
String hostname = "ws.btclock.dev";
|
String hostname = "ws.btclock.dev";
|
||||||
if (preferences.getBool("stagingSource", DEFAULT_STAGING_SOURCE))
|
if (preferences.getBool("ceEnabled", DEFAULT_CUSTOM_ENDPOINT_ENABLED))
|
||||||
{
|
{
|
||||||
Serial.println(F("Connecting to V2 staging source"));
|
Serial.println(F("Connecting to custom source"));
|
||||||
hostname = "ws-staging.btclock.dev";
|
hostname = preferences.getString("ceEndpoint", DEFAULT_CUSTOM_ENDPOINT);
|
||||||
|
bool useSSL = !preferences.getBool("ceDisableSSL", DEFAULT_CUSTOM_ENDPOINT_DISABLE_SSL);
|
||||||
|
|
||||||
|
if (useSSL) {
|
||||||
|
webSocket.beginSSL(hostname, 443, "/api/v2/ws");
|
||||||
|
} else {
|
||||||
|
webSocket.begin(hostname, 80, "/api/v2/ws");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
Serial.println(F("Connecting to V2 source"));
|
Serial.println(F("Connecting to V2 source"));
|
||||||
|
webSocket.beginSSL(hostname, 443, "/api/v2/ws");
|
||||||
}
|
}
|
||||||
|
|
||||||
webSocket.beginSSL(hostname, 443, "/api/v2/ws");
|
|
||||||
webSocket.onEvent(V2Notify::onWebsocketV2Event);
|
webSocket.onEvent(V2Notify::onWebsocketV2Event);
|
||||||
webSocket.setReconnectInterval(5000);
|
webSocket.setReconnectInterval(5000);
|
||||||
webSocket.enableHeartbeat(15000, 3000, 2);
|
webSocket.enableHeartbeat(15000, 3000, 2);
|
||||||
|
|
||||||
V2Notify::setupV2NotifyTask();
|
V2Notify::setupV2NotifyTask();
|
||||||
|
|
||||||
|
currentHostname = hostname;
|
||||||
}
|
}
|
||||||
|
|
||||||
void onWebsocketV2Event(WStype_t type, uint8_t *payload, size_t length)
|
void onWebsocketV2Event(WStype_t type, uint8_t *payload, size_t length)
|
||||||
|
@ -38,7 +49,9 @@ namespace V2Notify
|
||||||
break;
|
break;
|
||||||
case WStype_CONNECTED:
|
case WStype_CONNECTED:
|
||||||
{
|
{
|
||||||
Serial.print(F("[WSc] Connected to url:"));
|
Serial.print(F("[WSc] Connected to "));
|
||||||
|
Serial.print(currentHostname);
|
||||||
|
Serial.print(F(": "));
|
||||||
Serial.println((char *)payload);
|
Serial.println((char *)payload);
|
||||||
|
|
||||||
JsonDocument response;
|
JsonDocument response;
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
static const char* JSON_CONTENT = "application/json";
|
static const char* JSON_CONTENT = "application/json";
|
||||||
|
|
||||||
static const char *const PROGMEM strSettings[] = {
|
static const char *const PROGMEM strSettings[] = {
|
||||||
"hostnamePrefix", "mempoolInstance", "nostrPubKey", "nostrRelay", "bitaxeHostname", "miningPoolName", "miningPoolUser", "nostrZapPubkey", "httpAuthUser", "httpAuthPass", "gitReleaseUrl", "poolLogosUrl"};
|
"hostnamePrefix", "mempoolInstance", "nostrPubKey", "nostrRelay", "bitaxeHostname", "miningPoolName", "miningPoolUser", "nostrZapPubkey", "httpAuthUser", "httpAuthPass", "gitReleaseUrl", "poolLogosUrl", "ceEndpoint"};
|
||||||
|
|
||||||
static const char *const PROGMEM uintSettings[] = {"minSecPriceUpd", "fullRefreshMin", "ledBrightness", "flMaxBrightness", "flEffectDelay", "luxLightToggle", "wpTimeout", "srcV2Currency"};
|
static const char *const PROGMEM uintSettings[] = {"minSecPriceUpd", "fullRefreshMin", "ledBrightness", "flMaxBrightness", "flEffectDelay", "luxLightToggle", "wpTimeout", "srcV2Currency"};
|
||||||
|
|
||||||
|
@ -15,7 +15,8 @@ static const char *const PROGMEM boolSettings[] = {"fetchEurPrice", "ledTestOnPo
|
||||||
"flAlwaysOn", "flDisable", "flFlashOnUpd",
|
"flAlwaysOn", "flDisable", "flFlashOnUpd",
|
||||||
"mempoolSecure", "useNostr", "bitaxeEnabled",
|
"mempoolSecure", "useNostr", "bitaxeEnabled",
|
||||||
"miningPoolStats", "verticalDesc",
|
"miningPoolStats", "verticalDesc",
|
||||||
"nostrZapNotify", "stagingSource", "httpAuthEnabled"};
|
"nostrZapNotify", "ceEnabled", "httpAuthEnabled",
|
||||||
|
"enableDebugLog", "ceDisableSSL"};
|
||||||
|
|
||||||
AsyncWebServer server(80);
|
AsyncWebServer server(80);
|
||||||
AsyncEventSource events("/events");
|
AsyncEventSource events("/events");
|
||||||
|
@ -458,25 +459,22 @@ void onApiSettingsPatch(AsyncWebServerRequest *request, JsonVariant &json)
|
||||||
|
|
||||||
bool settingsChanged = true;
|
bool settingsChanged = true;
|
||||||
|
|
||||||
if (settings["fgColor"].is<String>())
|
if (settings["invertedColor"].is<bool>())
|
||||||
{
|
{
|
||||||
String fgColor = settings["fgColor"].as<String>();
|
bool inverted = settings["invertedColor"].as<bool>();
|
||||||
uint32_t color = strtol(fgColor.c_str(), NULL, 16);
|
preferences.putBool("invertedColor", inverted);
|
||||||
preferences.putUInt("fgColor", color);
|
if (inverted) {
|
||||||
setFgColor(color);
|
preferences.putUInt("fgColor", GxEPD_WHITE);
|
||||||
Serial.print(F("Setting foreground color to "));
|
preferences.putUInt("bgColor", GxEPD_BLACK);
|
||||||
Serial.println(color);
|
setFgColor(GxEPD_WHITE);
|
||||||
settingsChanged = true;
|
setBgColor(GxEPD_BLACK);
|
||||||
}
|
} else {
|
||||||
if (settings["bgColor"].is<String>())
|
preferences.putUInt("fgColor", GxEPD_BLACK);
|
||||||
{
|
preferences.putUInt("bgColor", GxEPD_WHITE);
|
||||||
String bgColor = settings["bgColor"].as<String>();
|
setFgColor(GxEPD_BLACK);
|
||||||
|
setBgColor(GxEPD_WHITE);
|
||||||
uint32_t color = strtol(bgColor.c_str(), NULL, 16);
|
}
|
||||||
preferences.putUInt("bgColor", color);
|
Serial.printf("Setting invertedColor to %d\r\n", inverted);
|
||||||
setBgColor(color);
|
|
||||||
Serial.print(F("Setting background color to "));
|
|
||||||
Serial.println(bgColor.c_str());
|
|
||||||
settingsChanged = true;
|
settingsChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -627,8 +625,7 @@ void onApiSettingsGet(AsyncWebServerRequest *request)
|
||||||
|
|
||||||
JsonDocument root;
|
JsonDocument root;
|
||||||
root["numScreens"] = NUM_SCREENS;
|
root["numScreens"] = NUM_SCREENS;
|
||||||
root["fgColor"] = getFgColor();
|
root["invertedColor"] = preferences.getBool("invertedColor", getFgColor() == GxEPD_WHITE);
|
||||||
root["bgColor"] = getBgColor();
|
|
||||||
root["timerSeconds"] = getTimerSeconds();
|
root["timerSeconds"] = getTimerSeconds();
|
||||||
root["timerRunning"] = isTimerActive();
|
root["timerRunning"] = isTimerActive();
|
||||||
root["minSecPriceUpd"] = preferences.getUInt(
|
root["minSecPriceUpd"] = preferences.getUInt(
|
||||||
|
@ -657,13 +654,13 @@ void onApiSettingsGet(AsyncWebServerRequest *request)
|
||||||
root["verticalDesc"] = preferences.getBool("verticalDesc", DEFAULT_VERTICAL_DESC);
|
root["verticalDesc"] = preferences.getBool("verticalDesc", DEFAULT_VERTICAL_DESC);
|
||||||
|
|
||||||
root["suffixShareDot"] = preferences.getBool("suffixShareDot", DEFAULT_SUFFIX_SHARE_DOT);
|
root["suffixShareDot"] = preferences.getBool("suffixShareDot", DEFAULT_SUFFIX_SHARE_DOT);
|
||||||
|
root["enableDebugLog"] = preferences.getBool("enableDebugLog", DEFAULT_ENABLE_DEBUG_LOG);
|
||||||
|
|
||||||
root["hostnamePrefix"] = preferences.getString("hostnamePrefix", DEFAULT_HOSTNAME_PREFIX);
|
root["hostnamePrefix"] = preferences.getString("hostnamePrefix", DEFAULT_HOSTNAME_PREFIX);
|
||||||
root["hostname"] = getMyHostname();
|
root["hostname"] = getMyHostname();
|
||||||
root["ip"] = WiFi.localIP();
|
root["ip"] = WiFi.localIP();
|
||||||
root["txPower"] = WiFi.getTxPower();
|
root["txPower"] = WiFi.getTxPower();
|
||||||
root["ownDataSource"] = preferences.getBool("ownDataSource", DEFAULT_OWN_DATA_SOURCE);
|
root["ownDataSource"] = preferences.getBool("ownDataSource", DEFAULT_OWN_DATA_SOURCE);
|
||||||
root["stagingSource"] = preferences.getBool("stagingSource", DEFAULT_STAGING_SOURCE);
|
|
||||||
root["srcV2Currency"] = preferences.getChar("srcV2Currency", DEFAULT_V2_SOURCE_CURRENCY);
|
root["srcV2Currency"] = preferences.getChar("srcV2Currency", DEFAULT_V2_SOURCE_CURRENCY);
|
||||||
|
|
||||||
root["nostrPubKey"] = preferences.getString("nostrPubKey", DEFAULT_NOSTR_NPUB);
|
root["nostrPubKey"] = preferences.getString("nostrPubKey", DEFAULT_NOSTR_NPUB);
|
||||||
|
@ -734,6 +731,10 @@ void onApiSettingsGet(AsyncWebServerRequest *request)
|
||||||
|
|
||||||
root["poolLogosUrl"] = preferences.getString("poolLogosUrl", DEFAULT_MINING_POOL_LOGOS_URL);
|
root["poolLogosUrl"] = preferences.getString("poolLogosUrl", DEFAULT_MINING_POOL_LOGOS_URL);
|
||||||
|
|
||||||
|
root["ceEnabled"] = preferences.getBool("ceEnabled", DEFAULT_CUSTOM_ENDPOINT_ENABLED);
|
||||||
|
root["ceEndpoint"] = preferences.getString("ceEndpoint", DEFAULT_CUSTOM_ENDPOINT);
|
||||||
|
root["ceDisableSSL"] = preferences.getBool("ceDisableSSL", DEFAULT_CUSTOM_ENDPOINT_DISABLE_SSL);
|
||||||
|
|
||||||
AsyncResponseStream *response =
|
AsyncResponseStream *response =
|
||||||
request->beginResponseStream(JSON_CONTENT);
|
request->beginResponseStream(JSON_CONTENT);
|
||||||
serializeJson(root, *response);
|
serializeJson(root, *response);
|
||||||
|
|
Loading…
Reference in a new issue