mirror of
https://codeberg.org/comaps/comaps
synced 2026-01-04 20:03:45 +00:00
[traffic] API to reconfigure a running HttpTrafficSource
Signed-off-by: mvglasow <michael -at- vonglasow.com>
This commit is contained in:
@@ -2589,6 +2589,11 @@ void Framework::SaveTrafficEnabled(bool trafficEnabled)
|
||||
settings::Set(kTrafficEnabledKey, trafficEnabled);
|
||||
}
|
||||
|
||||
void Framework::SetTrafficHttpEnabled(bool enabled)
|
||||
{
|
||||
m_trafficManager.SetHttpTraffSource(enabled, LoadTrafficHttpUrl());
|
||||
}
|
||||
|
||||
bool Framework::LoadTrafficHttpEnabled()
|
||||
{
|
||||
bool enabled;
|
||||
@@ -2602,6 +2607,11 @@ void Framework::SaveTrafficHttpEnabled(bool trafficHttpEnabled)
|
||||
settings::Set(kTrafficHttpEnabledKey, trafficHttpEnabled);
|
||||
}
|
||||
|
||||
void Framework::SetTrafficHttpUrl(std::string url)
|
||||
{
|
||||
m_trafficManager.SetHttpTraffSource(LoadTrafficHttpEnabled(), url);
|
||||
}
|
||||
|
||||
std::string Framework::LoadTrafficHttpUrl()
|
||||
{
|
||||
std::string url;
|
||||
|
||||
@@ -740,9 +740,11 @@ public:
|
||||
bool LoadTrafficEnabled();
|
||||
void SaveTrafficEnabled(bool trafficEnabled);
|
||||
|
||||
void SetTrafficHttpEnabled(bool enabled);
|
||||
bool LoadTrafficHttpEnabled();
|
||||
void SaveTrafficHttpEnabled(bool trafficHttpEnabled);
|
||||
|
||||
void SetTrafficHttpUrl(std::string url);
|
||||
std::string LoadTrafficHttpUrl();
|
||||
void SaveTrafficHttpUrl(std::string trafficHttpUrl);
|
||||
|
||||
|
||||
@@ -923,6 +923,27 @@ bool TrafficManager::IsEnabled() const
|
||||
return m_state != TrafficState::Disabled;
|
||||
}
|
||||
|
||||
void TrafficManager::SetHttpTraffSource(bool enabled, std::string url)
|
||||
{
|
||||
if (IsTestMode())
|
||||
return;
|
||||
|
||||
{
|
||||
std::lock_guard<std::mutex> lock(m_trafficSourceMutex);
|
||||
|
||||
for (auto it = m_trafficSources.begin(); it != m_trafficSources.end(); )
|
||||
if (traffxml::HttpTraffSource* httpSource = dynamic_cast<traffxml::HttpTraffSource*>(it->get()))
|
||||
{
|
||||
httpSource->Close();
|
||||
m_trafficSources.erase(it);
|
||||
}
|
||||
else
|
||||
++it;
|
||||
}
|
||||
if (enabled)
|
||||
traffxml::HttpTraffSource::Create(*this, url);
|
||||
}
|
||||
|
||||
bool TrafficManager::IsInvalidState() const
|
||||
{
|
||||
return m_state == TrafficState::NetworkError;
|
||||
|
||||
@@ -173,6 +173,23 @@ public:
|
||||
*/
|
||||
bool IsEnabled() const;
|
||||
|
||||
/**
|
||||
* @brief Sets the enabled state and URL for the `HttpTraffSource`.
|
||||
*
|
||||
* If the traffic manager is in test mode, this function is a no-op.
|
||||
*
|
||||
* Otherwise this function is expected to be called only if the enabled state and/or URL have
|
||||
* actually changed. Setting both to the current state will remove the current source and create
|
||||
* a new one with identical settings.
|
||||
*
|
||||
* This function currently assumes that there is never more than one `HttpTraffSource` configured
|
||||
* at the same time.
|
||||
*
|
||||
* @param enabled Whether the HTTP TraFF source is enabled.
|
||||
* @param url The URL for the TraFF API.
|
||||
*/
|
||||
void SetHttpTraffSource(bool enabled, std::string url);
|
||||
|
||||
/**
|
||||
* @brief Starts the traffic manager.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user