From 66f0ef8c94eda9385dacc9de46a5e17f46c331ba Mon Sep 17 00:00:00 2001 From: phunkyfish Date: Sat, 6 Aug 2022 10:30:25 +0100 Subject: [PATCH 1/2] URL encode last part of tvg logo URL as they can be based on channel names --- src/iptvsimple/data/Channel.cpp | 23 +++++++++++-- src/iptvsimple/utilities/WebUtils.cpp | 47 +++++++++++++++++++++++++++ src/iptvsimple/utilities/WebUtils.h | 2 ++ 3 files changed, 70 insertions(+), 2 deletions(-) diff --git a/src/iptvsimple/data/Channel.cpp b/src/iptvsimple/data/Channel.cpp index 1fcec266b..1cdddeb90 100644 --- a/src/iptvsimple/data/Channel.cpp +++ b/src/iptvsimple/data/Channel.cpp @@ -126,10 +126,29 @@ void Channel::SetIconPathFromTvgLogo(const std::string& tvgLogo, std::string& ch kodi::UnknownToUTF8(m_iconPath, m_iconPath); - // urlencode channel logo when set from channel name and source is Remote Path - // append extension as channel name wouldn't have it + // urlencode channel logo when set from channel name and source is Remote Path, append extension as channel wouldn't cover this if (logoSetFromChannelName && Settings::GetInstance().GetLogoPathType() == PathType::REMOTE_PATH) + { m_iconPath = utilities::WebUtils::UrlEncode(m_iconPath); + } + else if (m_iconPath.find("://") != std::string::npos) + { + // we also want to check the last part of a URL to ensure it's valid as quite often they are based on channel names + // the path should be fine + + size_t pos = m_iconPath.find_last_of("/"); + if (pos != std::string::npos) + { + const std::string urlPath = m_iconPath.substr(0, pos + 1); + std::string urlFile = m_iconPath.substr(pos + 1); + if (!utilities::WebUtils::IsEncoded(urlFile)) + { + urlFile = utilities::WebUtils::UrlEncode(urlFile); + + m_iconPath = urlPath + urlFile; + } + } + } if (m_iconPath.find("://") == std::string::npos) { diff --git a/src/iptvsimple/utilities/WebUtils.cpp b/src/iptvsimple/utilities/WebUtils.cpp index 4d812b447..39b077733 100644 --- a/src/iptvsimple/utilities/WebUtils.cpp +++ b/src/iptvsimple/utilities/WebUtils.cpp @@ -42,6 +42,53 @@ const std::string WebUtils::UrlEncode(const std::string& value) return escaped.str(); } +namespace +{ + +char from_hex(char ch) { + return isdigit(ch) ? ch - '0' : tolower(ch) - 'a' + 10; +} + +} // unamed namespace + +const std::string WebUtils::UrlDecode(const std::string& value) +{ + char h; + std::ostringstream escaped; + escaped.fill('0'); + + for (auto i = value.begin(), n = value.end(); i != n; ++i) + { + std::string::value_type c = (*i); + + if (c == '%') + { + if (i[1] && i[2]) + { + h = from_hex(i[1]) << 4 | from_hex(i[2]); + escaped << h; + i += 2; + } + } + else if (c == '+') + { + escaped << ' '; + } + else + { + escaped << c; + } + } + + return escaped.str(); +} + +bool WebUtils::IsEncoded(const std::string& value) +{ + // Note this is not perfect as '+' symbols will mess this up, they should in general be avoided in preference of '%20' + return UrlDecode(value) != value; +} + std::string WebUtils::ReadFileContentsStartOnly(const std::string& url, int* httpCode) { std::string strContent; diff --git a/src/iptvsimple/utilities/WebUtils.h b/src/iptvsimple/utilities/WebUtils.h index 7b00ce895..f05dc84f8 100644 --- a/src/iptvsimple/utilities/WebUtils.h +++ b/src/iptvsimple/utilities/WebUtils.h @@ -22,6 +22,8 @@ namespace iptvsimple { public: static const std::string UrlEncode(const std::string& value); + static const std::string UrlDecode(const std::string& value); + static bool IsEncoded(const std::string& value); static std::string ReadFileContentsStartOnly(const std::string& url, int* httpCode); static bool IsHttpUrl(const std::string& url); static std::string RedactUrl(const std::string& url); From 054861cd98be80092a8ed1d1930f73a233064b35 Mon Sep 17 00:00:00 2001 From: phunkyfish Date: Sat, 6 Aug 2022 10:32:45 +0100 Subject: [PATCH 2/2] changelog and version - 19.2.0 --- pvr.iptvsimple/addon.xml.in | 5 ++++- pvr.iptvsimple/changelog.txt | 3 +++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/pvr.iptvsimple/addon.xml.in b/pvr.iptvsimple/addon.xml.in index f71d7e202..d02a5d17e 100644 --- a/pvr.iptvsimple/addon.xml.in +++ b/pvr.iptvsimple/addon.xml.in @@ -1,7 +1,7 @@ @ADDON_DEPENDS@ @@ -21,6 +21,9 @@ icon.png +v19.2.0 +- URL encode last part of tvg logo URL as they can be based on channel names + v19.1.1 - Fix ch-number tag being ignored diff --git a/pvr.iptvsimple/changelog.txt b/pvr.iptvsimple/changelog.txt index 9b924b76c..d16e2488e 100644 --- a/pvr.iptvsimple/changelog.txt +++ b/pvr.iptvsimple/changelog.txt @@ -1,3 +1,6 @@ +v19.2.0 +- URL encode last part of tvg logo URL as they can be based on channel names + v19.1.1 - Fix ch-number tag being ignored