From 5acbf456735282eba14b8adbcc26538b6bc7705f Mon Sep 17 00:00:00 2001 From: Lev Rusanov <30170278+JDM170@users.noreply.github.com> Date: Tue, 11 Jul 2023 22:11:05 +0700 Subject: [PATCH] Update Scripts/YouTube.ps1 Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com> --- Scripts/YouTube.ps1 | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/Scripts/YouTube.ps1 b/Scripts/YouTube.ps1 index 035eff4..8870c22 100644 --- a/Scripts/YouTube.ps1 +++ b/Scripts/YouTube.ps1 @@ -13,9 +13,31 @@ $LatestSupportedYT = $LatestSupported.replace(".", "-") $AngleSharpAssemblyPath = (Get-ChildItem -Path (Split-Path -Path (Get-Package -Name AngleSharp).Source) -Filter "*.dll" -Recurse | Where-Object -FilterScript {$_ -match "standard"} | Select-Object -Last 1).FullName Add-Type -Path $AngleSharpAssemblyPath +$angleparser = New-Object -TypeName AngleSharp.Html.Parser.HtmlParser + +$apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-18-23-35-release/" +$Parameters = @{ + Uri = $apkMirrorLink + UseBasicParsing = $false # Disabled + Verbose = $true +} +$Request = Invoke-Webrequest @Parameters +$Parsed = $angleparser.ParseDocument($Request.Content) +$Parsed.All | Where-Object -FilterScript {$_.ClassName -match "table-row headerFont"} | ForEach-Object -Process { + foreach($child in $_.children) + { + if ($child.InnerHtml -eq "nodpi") + { + $apkPackageLink = (($_.getElementsByTagName("a") | Select-Object -First 1).Href).Substring(57) + break + } + } +} +$apkMirrorLink += $apkPackageLink + # Get unique key to generate direct link # https://www.apkmirror.com/apk/google-inc/youtube/ -$apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-2-android-apk-download/" +# $apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-2-android-apk-download/" # $apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-android-apk-download/" $Parameters = @{ Uri = $apkMirrorLink @@ -23,7 +45,8 @@ $Parameters = @{ Verbose = $true } $Request = Invoke-Webrequest @Parameters -$Parsed = (New-Object -TypeName AngleSharp.Html.Parser.HtmlParser).ParseDocument($Request.Content) +# $Parsed = (New-Object -TypeName AngleSharp.Html.Parser.HtmlParser).ParseDocument($Request.Content) +$Parsed = $angleparser.ParseDocument($Request.Content) $Key = $Parsed.All | Where-Object -FilterScript {$_.ClassName -match "accent_bg btn btn-flat downloadButton"} | ForEach-Object -Process {$_.Search} $Parameters = @{ @@ -32,7 +55,8 @@ $Parameters = @{ Verbose = $true } $Request = Invoke-Webrequest @Parameters -$Parsed = (New-Object -TypeName AngleSharp.Html.Parser.HtmlParser).ParseDocument($Request.Content) +# $Parsed = (New-Object -TypeName AngleSharp.Html.Parser.HtmlParser).ParseDocument($Request.Content) +$Parsed = $angleparser.ParseDocument($Request.Content) $Key = ($Parsed.All | Where-Object -FilterScript { $_.InnerHtml -eq "here" }).Search # Finally, get the real link