From 2b6505d420bb1076f6c2c7f0c4966e4d3caf4be7 Mon Sep 17 00:00:00 2001 From: Jan Krupa Date: Tue, 19 Nov 2024 13:43:38 +0100 Subject: [PATCH] [coco] Update Becker interface on ESP - On ESP, restart FujiNet after Becker enable/disable Serial port driver on ESP was not happy when loaded/unloaded from web server task. - On ESP, no Becker host:port setting in WebUI Default settings is to listen on all IPs (i.e. WiFi IP on FN-ESP) --- data/webui/template/www/index.tmpl.html | 9 +++++++ lib/config/fnConfig.h | 7 +++++ lib/http/httpServiceConfigurator.cpp | 36 +++++++++++++------------ 3 files changed, 35 insertions(+), 17 deletions(-) diff --git a/data/webui/template/www/index.tmpl.html b/data/webui/template/www/index.tmpl.html index f1c164ddf..0641be9b8 100644 --- a/data/webui/template/www/index.tmpl.html +++ b/data/webui/template/www/index.tmpl.html @@ -1343,6 +1343,13 @@

Need help? Go to the ⓘ + + Reboot FujiNet after changing this value. + + + {% endif %} + {% endif %}
diff --git a/lib/config/fnConfig.h b/lib/config/fnConfig.h index 9d7030161..342e3b728 100755 --- a/lib/config/fnConfig.h +++ b/lib/config/fnConfig.h @@ -459,7 +459,14 @@ class fnConfig struct boip_info { bool boip_enabled = false; +#ifdef ESP_PLATFORM + // CoCo: DriveWire server (listen) -> listen on all IPs by default + // Atari: NetSIO hub (connect to) -> hub host/IP must be specified + std::string host = ""; +#else + // On PC, limit connections to/from local machine by default std::string host = "localhost"; +#endif int port = CONFIG_DEFAULT_BOIP_PORT; }; diff --git a/lib/http/httpServiceConfigurator.cpp b/lib/http/httpServiceConfigurator.cpp index 6b5efd76f..7e6ac7438 100644 --- a/lib/http/httpServiceConfigurator.cpp +++ b/lib/http/httpServiceConfigurator.cpp @@ -569,7 +569,12 @@ void fnHttpServiceConfigurator::config_boip(std::string enable_boip, std::string Debug_printf("Set Bus Over IP: %s,%s\n", enable_boip.c_str(), boip_host_port.c_str()); // Store our change in Config - if (!boip_host_port.empty()) + if (boip_host_port.empty()) + { + Config.store_boip_host(""); + Config.store_boip_port(CONFIG_DEFAULT_BOIP_PORT); + } + else { std::size_t found = boip_host_port.find(':'); std::string host = boip_host_port; @@ -577,42 +582,39 @@ void fnHttpServiceConfigurator::config_boip(std::string enable_boip, std::string if (found != std::string::npos) { host = boip_host_port.substr(0, found); - if (host.empty()) - host = "localhost"; port = std::atoi(boip_host_port.substr(found+1).c_str()); if (port < 1 || port > 65535) port = CONFIG_DEFAULT_BOIP_PORT; } - Config.store_boip_port(port); Config.store_boip_host(host.c_str()); + Config.store_boip_port(port); + } - // Update settings + // Update settings (on ESP reboot is needed) +#ifndef ESP_PLATFORM #if defined(BUILD_ATARI) -# ifndef ESP_PLATFORM - // fnSioCom is not available on Atari FN-ESP - fnSioCom.set_netsio_host(Config.get_boip_host().c_str(), Config.get_boip_port()); -# endif + fnSioCom.set_netsio_host(Config.get_boip_host().c_str(), Config.get_boip_port()); #elif defined(BUILD_COCO) - fnDwCom.set_becker_host(Config.get_boip_host().c_str(), Config.get_boip_port()); + fnDwCom.set_becker_host(Config.get_boip_host().c_str(), Config.get_boip_port()); #endif - } +#endif + if (!enable_boip.empty()) { Config.store_boip_enabled(util_string_value_is_true(enable_boip)); } - // Save changes - Config.save(); - // Apply settings + // Apply settings (on ESP reboot is needed) +#ifndef ESP_PLATFORM #if defined(BUILD_ATARI) -# ifndef ESP_PLATFORM - // fnSioCom is not available on Atari FN-ESP fnSioCom.reset_sio_port(Config.get_boip_enabled() ? SioCom::sio_mode::NETSIO : SioCom::sio_mode::SERIAL); -# endif #elif defined(BUILD_COCO) fnDwCom.reset_drivewire_port(Config.get_boip_enabled() ? DwCom::dw_mode::BECKER : DwCom::dw_mode::SERIAL); +#endif #endif + // Save changes + Config.save(); } void fnHttpServiceConfigurator::config_pclink_enabled(std::string enabled)