diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-10 18:07:22 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-10 18:07:22 +0000 |
commit | c04dcc2e7d834218ef2d4194331e383402495ae1 (patch) | |
tree | 7333e38d10d75386e60f336b80c2443c1166031d /xbmc/addons/interfaces/Network.cpp | |
parent | Initial commit. (diff) | |
download | kodi-c04dcc2e7d834218ef2d4194331e383402495ae1.tar.xz kodi-c04dcc2e7d834218ef2d4194331e383402495ae1.zip |
Adding upstream version 2:20.4+dfsg.upstream/2%20.4+dfsg
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'xbmc/addons/interfaces/Network.cpp')
-rw-r--r-- | xbmc/addons/interfaces/Network.cpp | 181 |
1 files changed, 181 insertions, 0 deletions
diff --git a/xbmc/addons/interfaces/Network.cpp b/xbmc/addons/interfaces/Network.cpp new file mode 100644 index 0000000..63151f3 --- /dev/null +++ b/xbmc/addons/interfaces/Network.cpp @@ -0,0 +1,181 @@ +/* + * Copyright (C) 2005-2018 Team Kodi + * This file is part of Kodi - https://kodi.tv + * + * SPDX-License-Identifier: GPL-2.0-or-later + * See LICENSES/README.md for more information. + */ + +#include "Network.h" + +#include "ServiceBroker.h" +#include "URL.h" +#include "addons/binary-addons/AddonDll.h" +#include "addons/kodi-dev-kit/include/kodi/Network.h" +#include "network/DNSNameCache.h" +#include "network/Network.h" +#include "utils/SystemInfo.h" +#include "utils/URIUtils.h" +#include "utils/log.h" + +namespace ADDON +{ + +void Interface_Network::Init(AddonGlobalInterface *addonInterface) +{ + addonInterface->toKodi->kodi_network = new AddonToKodiFuncTable_kodi_network(); + + addonInterface->toKodi->kodi_network->wake_on_lan = wake_on_lan; + addonInterface->toKodi->kodi_network->get_ip_address = get_ip_address; + addonInterface->toKodi->kodi_network->get_hostname = get_hostname; + addonInterface->toKodi->kodi_network->get_user_agent = get_user_agent; + addonInterface->toKodi->kodi_network->is_local_host = is_local_host; + addonInterface->toKodi->kodi_network->is_host_on_lan = is_host_on_lan; + addonInterface->toKodi->kodi_network->dns_lookup = dns_lookup; + addonInterface->toKodi->kodi_network->url_encode = url_encode; +} + +void Interface_Network::DeInit(AddonGlobalInterface* addonInterface) +{ + if (addonInterface->toKodi) /* <-- needed as long as the old addon way is used */ + { + delete addonInterface->toKodi->kodi_network; + addonInterface->toKodi->kodi_network = nullptr; + } +} + +bool Interface_Network::wake_on_lan(void* kodiBase, const char* mac) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr || mac == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}', mac='{}')", __FUNCTION__, + kodiBase, static_cast<const void*>(mac)); + return false; + } + + return CServiceBroker::GetNetwork().WakeOnLan(mac); +} + +char* Interface_Network::get_ip_address(void* kodiBase) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}')", __FUNCTION__, + kodiBase); + return nullptr; + } + + std::string titleIP; + CNetworkInterface* iface = CServiceBroker::GetNetwork().GetFirstConnectedInterface(); + if (iface) + titleIP = iface->GetCurrentIPAddress(); + else + titleIP = "127.0.0.1"; + + char* buffer = nullptr; + if (!titleIP.empty()) + buffer = strdup(titleIP.c_str()); + return buffer; +} + +char* Interface_Network::get_hostname(void* kodiBase) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}')", __FUNCTION__, + kodiBase); + return nullptr; + } + + std::string hostname; + if (!CServiceBroker::GetNetwork().GetHostName(hostname)) + return nullptr; + + char* buffer = nullptr; + if (!hostname.empty()) + buffer = strdup(hostname.c_str()); + return buffer; +} + +char* Interface_Network::get_user_agent(void* kodiBase) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}')", __FUNCTION__, + kodiBase); + return nullptr; + } + + std::string string = CSysInfo::GetUserAgent(); + char* buffer = nullptr; + if (!string.empty()) + buffer = strdup(string.c_str()); + return buffer; +} + +bool Interface_Network::is_local_host(void* kodiBase, const char* hostname) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr || hostname == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}', hostname='{}')", + __FUNCTION__, kodiBase, static_cast<const void*>(hostname)); + return false; + } + + return CServiceBroker::GetNetwork().IsLocalHost(hostname); +} + +bool Interface_Network::is_host_on_lan(void* kodiBase, const char* hostname, bool offLineCheck) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr || hostname == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}', hostname='{}')", + __FUNCTION__, kodiBase, static_cast<const void*>(hostname)); + return false; + } + + return URIUtils::IsHostOnLAN(hostname, offLineCheck); +} + +char* Interface_Network::dns_lookup(void* kodiBase, const char* url, bool* ret) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr || url == nullptr || ret == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}', url='{}', ret='{}')", + __FUNCTION__, kodiBase, static_cast<const void*>(url), static_cast<void*>(ret)); + return nullptr; + } + + std::string string; + *ret = CDNSNameCache::Lookup(url, string); + char* buffer = nullptr; + if (!string.empty()) + buffer = strdup(string.c_str()); + return buffer; +} + +char* Interface_Network::url_encode(void* kodiBase, const char* url) +{ + CAddonDll* addon = static_cast<CAddonDll*>(kodiBase); + if (addon == nullptr || url == nullptr) + { + CLog::Log(LOGERROR, "Interface_Network::{} - invalid data (addon='{}', url='{}')", __FUNCTION__, + kodiBase, static_cast<const void*>(url)); + return nullptr; + } + + std::string string = CURL::Encode(url); + char* buffer = nullptr; + if (!string.empty()) + buffer = strdup(string.c_str()); + return buffer; +} + +} /* namespace ADDON */ |