Compare commits

...

6 Commits

8 changed files with 128 additions and 120 deletions

2
.gitignore vendored
View File

@ -1,6 +1,6 @@
/.idea /.idea
/.vscode /.vscode
/downloaded downloaded/
/src/commit /src/commit
/src/cache/* /src/cache/*
/src/vendor /src/vendor

View File

@ -24,10 +24,10 @@ class Playlist extends BasicPlaylist
empty($params['pls']) && throw new \Exception( empty($params['pls']) && throw new \Exception(
"Плейлист с ID=$id обязан иметь параметр pls или redirect" "Плейлист с ID=$id обязан иметь параметр pls или redirect"
); );
$this->url = str_replace(['http://', 'https://'], '', base_url($id)); $this->url = base_url($id);
$this->name = empty($params['name']) ? "Плейлист #$id" : $params['name']; $this->name = empty($params['name']) ? "Плейлист #$id" : $params['name'];
$this->desc = empty($params['desc']) ? null : $params['desc']; $this->desc = empty($params['desc']) ? null : $params['desc'];
$this->pls = empty($params['pls']) ? null : $params['pls']; $this->pls = $params['pls'];
$this->src = empty($params['src']) ? null : $params['src']; $this->src = empty($params['src']) ? null : $params['src'];
} }

36
src/composer.lock generated
View File

@ -8,16 +8,16 @@
"packages": [ "packages": [
{ {
"name": "illuminate/collections", "name": "illuminate/collections",
"version": "v9.26.1", "version": "v9.36.4",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/illuminate/collections.git", "url": "https://github.com/illuminate/collections.git",
"reference": "3bda212d2c245b3261cd9af690dfd47d9878cebf" "reference": "32e3cd051cf1d12c1e7d5f7bb5a52d0dae8b7a8b"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/illuminate/collections/zipball/3bda212d2c245b3261cd9af690dfd47d9878cebf", "url": "https://api.github.com/repos/illuminate/collections/zipball/32e3cd051cf1d12c1e7d5f7bb5a52d0dae8b7a8b",
"reference": "3bda212d2c245b3261cd9af690dfd47d9878cebf", "reference": "32e3cd051cf1d12c1e7d5f7bb5a52d0dae8b7a8b",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
@ -59,11 +59,11 @@
"issues": "https://github.com/laravel/framework/issues", "issues": "https://github.com/laravel/framework/issues",
"source": "https://github.com/laravel/framework" "source": "https://github.com/laravel/framework"
}, },
"time": "2022-08-22T14:29:59+00:00" "time": "2022-10-06T14:13:23+00:00"
}, },
{ {
"name": "illuminate/conditionable", "name": "illuminate/conditionable",
"version": "v9.26.1", "version": "v9.36.4",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/illuminate/conditionable.git", "url": "https://github.com/illuminate/conditionable.git",
@ -109,16 +109,16 @@
}, },
{ {
"name": "illuminate/contracts", "name": "illuminate/contracts",
"version": "v9.26.1", "version": "v9.36.4",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/illuminate/contracts.git", "url": "https://github.com/illuminate/contracts.git",
"reference": "0d1dd1a7e947072319f2e641cc50081219606502" "reference": "d57130115694b4f6a98d064bea31cdb09d7784f8"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/illuminate/contracts/zipball/0d1dd1a7e947072319f2e641cc50081219606502", "url": "https://api.github.com/repos/illuminate/contracts/zipball/d57130115694b4f6a98d064bea31cdb09d7784f8",
"reference": "0d1dd1a7e947072319f2e641cc50081219606502", "reference": "d57130115694b4f6a98d064bea31cdb09d7784f8",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
@ -153,11 +153,11 @@
"issues": "https://github.com/laravel/framework/issues", "issues": "https://github.com/laravel/framework/issues",
"source": "https://github.com/laravel/framework" "source": "https://github.com/laravel/framework"
}, },
"time": "2022-08-18T14:18:13+00:00" "time": "2022-09-15T13:31:42+00:00"
}, },
{ {
"name": "illuminate/macroable", "name": "illuminate/macroable",
"version": "v9.26.1", "version": "v9.36.4",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/illuminate/macroable.git", "url": "https://github.com/illuminate/macroable.git",
@ -593,16 +593,16 @@
}, },
{ {
"name": "twig/twig", "name": "twig/twig",
"version": "v3.4.2", "version": "v3.4.3",
"source": { "source": {
"type": "git", "type": "git",
"url": "https://github.com/twigphp/Twig.git", "url": "https://github.com/twigphp/Twig.git",
"reference": "e07cdd3d430cd7e453c31b36eb5ad6c0c5e43077" "reference": "c38fd6b0b7f370c198db91ffd02e23b517426b58"
}, },
"dist": { "dist": {
"type": "zip", "type": "zip",
"url": "https://api.github.com/repos/twigphp/Twig/zipball/e07cdd3d430cd7e453c31b36eb5ad6c0c5e43077", "url": "https://api.github.com/repos/twigphp/Twig/zipball/c38fd6b0b7f370c198db91ffd02e23b517426b58",
"reference": "e07cdd3d430cd7e453c31b36eb5ad6c0c5e43077", "reference": "c38fd6b0b7f370c198db91ffd02e23b517426b58",
"shasum": "" "shasum": ""
}, },
"require": { "require": {
@ -653,7 +653,7 @@
], ],
"support": { "support": {
"issues": "https://github.com/twigphp/Twig/issues", "issues": "https://github.com/twigphp/Twig/issues",
"source": "https://github.com/twigphp/Twig/tree/v3.4.2" "source": "https://github.com/twigphp/Twig/tree/v3.4.3"
}, },
"funding": [ "funding": [
{ {
@ -665,7 +665,7 @@
"type": "tidelift" "type": "tidelift"
} }
], ],
"time": "2022-08-12T06:47:24+00:00" "time": "2022-09-28T08:42:51+00:00"
} }
], ],
"packages-dev": [], "packages-dev": [],

View File

@ -39,10 +39,9 @@ awk '
ARGV[1] = "/tmp/" file_name ARGV[1] = "/tmp/" file_name
} }
print "" print ""
print "\033[20m\033[97mNote 1:\033[0m operation may take some time." print "\033[20m\033[97mNote 1:\033[0m operation may take some time, press CTRL+C to stop."
print "\033[20m\033[97mNote 2:\033[0m press CTRL+C to skip current channel or CTRL+Z to kill process." print "\033[20m\033[97mNote 2:\033[0m results may be inaccurate, you should use proper IPTV software to re-check."
print "\033[20m\033[97mNote 3:\033[0m results may be inaccurate, you should use proper IPTV software to re-check." print "\033[20m\033[97mNote 3:\033[0m error codes listed here - https://everything.curl.dev/usingcurl/returns"
print "\033[20m\033[97mNote 4:\033[0m error codes listed here - https://everything.curl.dev/usingcurl/returns"
print "--------------------" print "--------------------"
} }
{ {

View File

@ -16,7 +16,16 @@
# #
################################################# #################################################
rm -rf ./downloaded TOOLS_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )";
mkdir -p ./downloaded && \ DL_DIR="$TOOLS_DIR/downloaded"
cd ./downloaded && \ INI_FILE="$(dirname "$TOOLS_DIR")/playlists.ini"
grep -P "pls='(.*)'" ../playlists.ini | sed "s/^pls=//g" | sed "s/'//g" | tr -d '\r' | xargs wget
rm -rf "$DL_DIR" && \
mkdir -p "$DL_DIR" && \
cd "$DL_DIR" && \
cat "$INI_FILE" \
| grep -P "pls\s*=\s*'(.*)'" \
| sed "s#^pls\s*=\s*##g" \
| sed "s#'##g" \
| tr -d '\r' \
| xargs wget

View File

@ -16,9 +16,10 @@
# #
################################################# #################################################
SCRIPT_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )"; TOOLS_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )";
[ ! -d ./downloaded ] && echo "Error: ./downloaded directory does not exist. Run $SCRIPT_DIR/tools/download-all.sh" && exit 1 DL_DIR="$TOOLS_DIR/downloaded"
[ ! "$(ls -A ./downloaded)" ] && echo "Error: ./downloaded directory is empty. Run $SCRIPT_DIR/tools/download-all.sh" && exit 2 [ ! -d "$DL_DIR" ] && echo "Error: 'tools/downloaded' directory does not exist. Run tools/download-all.sh" && exit 1
for file in ./downloaded/*; do [ ! "$(ls -A "$DL_DIR")" ] && echo "Error: 'tools/downloaded' directory is empty. Run tools/download-all.sh" && exit 2
"$SCRIPT_DIR"/find-in-pls.sh "$1" "$file" for file in $TOOLS_DIR/downloaded/*; do
$TOOLS_DIR/find-in-pls.sh "$1" "$file"
done done

View File

@ -22,59 +22,63 @@
# #
################################################# #################################################
awk ' channel="$1"
BEGIN { playlist="$2"
IGNORECASE=1 playlist_url="$playlist"
channel = ARGV[1] regex_ch="^#extinf:\s*-?[01]\s*.*,(.*${channel,,}.*)"
playlist = ARGV[2] regex_url="^https?:\/\/.*$"
found_count = 0
found_last = 0
regex_ch = tolower(sprintf("^#EXTINF:.+,\s*(.*%s.*)", channel))
regex_url = "^https?:\/\/.*$"
print "--------------------" is_downloaded=0
print "\033[20m\033[97mPlaylist:\033[0m " playlist download_dir="/tmp/$(date '+%s%N')"
print "\033[20m\033[97mChannel to find:\033[0m " channel
if (playlist ~ /^http(s)?:\/\/.*/) { found_count=0
parts_count = split(playlist, parts, "/") found_last=0
file_name = parts[parts_count] line_count=1
code = system("wget " playlist " -qO /tmp/" file_name " > /dev/null")
if (code == 0) {
print "Saved in /tmp/" file_name
} else {
print "ERROR: cannot download playlist: " playlist
exit 1
}
playlist = "/tmp/" file_name
}
ARGV[1] = playlist if [[ "$playlist" =~ $regex_url ]]; then
delete ARGV[2] mkdir -p "$download_dir"
print "--------------------" cd "$download_dir"
} wget "$playlist" -q > /dev/null
{ if [ $? -eq 0 ]; then
sub("\r$", "", $0) # crlf -> lf is_downloaded=1
if (tolower($0) ~ tolower(regex_ch)) { playlist="$download_dir/$(ls -1 "$download_dir")"
found_count++ cd -
print "\n\033[32m" FNR " FOUND:\033[0m\t" $0 else
found_last = FNR echo "ERROR: cannot download playlist: $playlist"
} exit 1
if (found_last > 0) { fi
if (tolower($0) ~ tolower(regex_url)) { fi
print "\t\t" $0
found_last = 0 echo "--------------------"
} echo -e "\033[20m\033[97mChannel:\033[0m $channel"
} echo -e "\033[20m\033[97mPlaylist:\033[0m $playlist_url"
} echo -e "\033[20m\033[97mRegex:\033[0m $regex_ch"
END { echo "--------------------"
if (found_count == 0) {
print "\033[91mNothing found\033[0m" while read line; do
} else { if [[ "${line,,}" =~ $regex_ch ]]; then
print "--------------------" echo -e "\n\033[32m$line_count FOUND:\033[0m\t$line"
print "\033[20m\033[97mPlaylist:\033[0m " playlist ((found_count += 1))
print "\033[20m\033[97mChannel found:\033[0m " channel found_last=$found_count
print "\033[20m\033[97mFound:\033[0m\033[32m " found_count "\033[0m" fi
} if [ $found_last -gt 0 ]; then
} if [[ "${line,,}" =~ $regex_url ]]; then
' $1 $2 echo -e "\t\t$line"
found_last=0
fi
fi
((line_count += 1))
done < $playlist
if [ $found_count -eq 0 ]; then
echo -e "\033[91mNothing found\033[0m"
else
echo "--------------------"
echo -e "\033[20m\033[97mPlaylist:\033[0m $playlist_url"
echo -e "\033[20m\033[97mChannel:\033[0m $channel"
echo -e "\033[20m\033[97mFound:\033[0m\033[32m $found_count\033[0m"
fi
if [ $is_downloaded -eq 1 ]; then
rm -rf "$download_dir"
fi

View File

@ -1,4 +1,3 @@
#!/bin/bash #!/bin/bash
################################################# #################################################
@ -20,41 +19,37 @@
# #
################################################# #################################################
#SCRIPT_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )"; TOOLS_DIR="$( cd -- "$( dirname -- "${BASH_SOURCE[0]:-$0}"; )" &> /dev/null && pwd 2> /dev/null; )";
SCRIPT_DIR="$(cd "$(dirname "$0")" >/dev/null 2>&1 && pwd)" DL_DIR="$TOOLS_DIR/downloaded"
[ ! -d ./downloaded ] && echo "Error: ./downloaded directory does not exist. Run $SCRIPT_DIR/tools/download-all.sh" && exit 1 [ ! -d "$DL_DIR" ] && echo "Error: 'tools/downloaded' directory does not exist. Run tools/download-all.sh" && exit 1
[ ! "$(ls -A ./downloaded)" ] && echo "Error: ./downloaded directory is empty. Run $SCRIPT_DIR/tools/download-all.sh" && exit 2 [ ! "$(ls -A "$DL_DIR")" ] && echo "Error: 'tools/downloaded' directory is empty. Run tools/download-all.sh" && exit 2
channel="$1"
playlist="$2"
regex_ch="^#extinf:\s*-?[01]\s*.*,(.*${channel,,}.*)"
regex_url="^https?:\/\/.*$"
found_count=0
found_last=0
echo "#EXTM3U" echo "#EXTM3U"
echo "# Autogenerated at `date +%d.%m.%Y`" echo "# Autogenerated at `date +%d.%m.%Y`"
echo "# https://github.com/anthonyaxenov/iptv" echo "# https://github.com/anthonyaxenov/iptv"
echo echo
for file in ./downloaded/*; do for file in ./downloaded/*; do
awk ' while read line; do
BEGIN { if [[ "${line,,}" =~ $regex_ch ]]; then
IGNORECASE=1 echo -e "$line"
"date +%Y-%m-%d" | getline date ((found_count += 1))
channel = ARGV[1] found_last=$found_count
playlist = ARGV[2] fi
ARGV[1] = playlist if [ $found_last -gt 0 ]; then
delete ARGV[2] if [[ "${line,,}" =~ $regex_url ]]; then
found_count = 0 echo -e "$line\n"
found_last = 0 found_last=0
regex_ch = tolower(sprintf("^#EXTINF:.+,\s*(.*%s.*)", channel)) fi
regex_url = "^https?:\/\/.*$" fi
} done < $file
{
sub("\r$", "", $0) # crlf -> lf
if (tolower($0) ~ tolower(regex_ch)) {
print $0
found_count++
found_last = FNR
}
if (found_last > 0) {
if (tolower($0) ~ tolower(regex_url)) {
print $0 "\n"
found_last = 0
}
}
}
' "$1" "$file"
done done