9 Commits

Author SHA1 Message Date
8242b06085 Revert "Update YouTube.ps1"
This reverts commit bdca80cf21.
2024-01-02 14:17:04 +07:00
bdca80cf21 Update YouTube.ps1 2024-01-02 01:16:22 +07:00
271a6e13c6 Update YouTube.ps1 2024-01-02 01:11:11 +07:00
7f15206c6d Fix indents
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-12-01 21:08:39 +07:00
dab245fc0d Update Build.yml
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-12-01 13:03:21 +07:00
aec3595c1f Update YouTube.ps1
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-12-01 12:58:17 +07:00
6d79dcd962 Update Build.ps1
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-12-01 12:57:50 +07:00
c6fe465f1e Update README.md
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-08-28 13:21:14 +07:00
7c399049ae Change step names in CI
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2023-08-28 13:21:00 +07:00
4 changed files with 52 additions and 65 deletions

View File

@@ -1,9 +1,6 @@
name: Build name: Build
on: on:
push:
tags:
- "*"
workflow_dispatch: workflow_dispatch:
jobs: jobs:
@@ -13,37 +10,37 @@ jobs:
steps: steps:
- uses: actions/checkout@main - uses: actions/checkout@main
- name: Installing AngleSharp - name: Install AngleSharp
run: | run: |
Install-Package AngleSharp -Source https://www.nuget.org/api/v2 -SkipDependencies -Force Install-Package AngleSharp -Source https://www.nuget.org/api/v2 -SkipDependencies -Force
- name: Downloading YouTube - name: Download YouTube
run: | run: |
New-Item -Path Temp -ItemType Directory -Force New-Item -Path Temp -ItemType Directory -Force
. Scripts\YouTube.ps1 . Scripts\YouTube.ps1
- name: Downloading ReVanced CLI - name: Download ReVanced CLI
run: | run: |
. Scripts\ReVanced_CLI.ps1 . Scripts\ReVanced_CLI.ps1
- name: Downloading ReVanced Patches - name: Download ReVanced Patches
run: | run: |
. Scripts\ReVanced_Patches.ps1 . Scripts\ReVanced_Patches.ps1
- name: Downloading ReVanced Integrations - name: Download ReVanced Integrations
run: | run: |
. Scripts\ReVanced_Intergrations.ps1 . Scripts\ReVanced_Intergrations.ps1
- name: Downloading Vanced MicroG - name: Download Vanced MicroG
run: | run: |
. Scripts\MicroG.ps1 . Scripts\MicroG.ps1
- name: Downloading and expanding Zulu JDK - name: Download and expanding Zulu JDK
run: | run: |
. Scripts\Zulu_JDK.ps1 . Scripts\Zulu_JDK.ps1
- name: Building - name: Build
run: | run: |
$JavaPath = (Resolve-Path -Path "Temp\jdk_windows-x64_bin\zulu*win_x64\bin\java.exe").Path $JavaPath = (Resolve-Path -Path "Temp\jdk_windows-x64_bin\zulu*win_x64\bin\java.exe").Path
@@ -60,7 +57,7 @@ jobs:
--out "Temp\revanced.apk" ` --out "Temp\revanced.apk" `
"Temp\youtube.apk" "Temp\youtube.apk"
- name: Creating archive - name: Create archive
run: | run: |
Get-ChildItem Temp\Temp -Recurse -Force Get-ChildItem Temp\Temp -Recurse -Force
$Parameters = @{ $Parameters = @{
@@ -71,7 +68,7 @@ jobs:
} }
Compress-Archive @Parameters Compress-Archive @Parameters
- name: Creating Release Notes - name: Create Release Notes
id: read_release id: read_release
run: | run: |
# https://en.wikipedia.org/wiki/Percent-encoding # https://en.wikipedia.org/wiki/Percent-encoding
@@ -81,10 +78,9 @@ jobs:
$ReleaseName = Get-Date -f "yyyy.MM.dd" $ReleaseName = Get-Date -f "yyyy.MM.dd"
echo "RELEASE_NAME=$ReleaseName" >> $env:GITHUB_ENV echo "RELEASE_NAME=$ReleaseName" >> $env:GITHUB_ENV
- name: Uploading to Releases - name: Upload to Releases
uses: softprops/action-gh-release@master uses: softprops/action-gh-release@master
with: with:
tag_name: ${{ env.RELEASE_NAME }} tag_name: ${{ env.RELEASE_NAME }}
token: ${{ github.token }}
files: ReVanced.zip
body_path: ${{ steps.read_release.outputs.ReleaseBody }} body_path: ${{ steps.read_release.outputs.ReleaseBody }}
files: ReVanced.zip

View File

@@ -41,30 +41,26 @@ $versions = ($JSON | Where-Object -FilterScript {$_.compatiblePackages.name -eq
$LatestSupported = $versions | Sort-Object -Descending -Unique | Select-Object -First 1 $LatestSupported = $versions | Sort-Object -Descending -Unique | Select-Object -First 1
$LatestSupported = $LatestSupported.replace(".", "-") $LatestSupported = $LatestSupported.replace(".", "-")
# Trying to find correct APK link (not BUNDLE) # Try to find correct NON-Bundle version
# https://www.apkmirror.com/apk/google-inc/youtube/
$apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/"
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink Uri = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-android-apk-download/"
UseBasicParsing = $false # Disabled UseBasicParsing = $false # Disabled
Verbose = $true Verbose = $true
} }
$Request = Invoke-Webrequest @Parameters $URLParse = (Invoke-Webrequest @Parameters).Links.outerHTML | Where-Object -FilterScript {$_ -like "*YouTube $($LatestSupported.replace("-", ".")) (nodpi)*"}
$Request.ParsedHtml.getElementsByClassName("table-row headerFont") | ForEach-Object -Process { # Check if variable contains a data
foreach ($child in $_.children) if ($URLParse)
{ {
if ($child.innerText -eq "nodpi") $URL = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-android-apk-download/"
{ }
$apkPackageLink = ($_.getElementsByTagName("a") | Select-Object -First 1).nameProp else
break {
} $URL = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/youtube-$($LatestSupported)-2-android-apk-download/"
}
} }
$apkMirrorLink += $apkPackageLink # actual APK link (not BUNDLE)
# Get unique key to generate direct link # Get unique key to generate direct link
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink Uri = $URL
UseBasicParsing = $false # Disabled UseBasicParsing = $false # Disabled
Verbose = $true Verbose = $true
} }
@@ -72,7 +68,7 @@ $Request = Invoke-Webrequest @Parameters
$nameProp = $Request.ParsedHtml.getElementsByClassName("accent_bg btn btn-flat downloadButton") | ForEach-Object -Process {$_.nameProp} $nameProp = $Request.ParsedHtml.getElementsByClassName("accent_bg btn btn-flat downloadButton") | ForEach-Object -Process {$_.nameProp}
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink + "/download/$($nameProp)" Uri = "$($URL)/download/$($nameProp)"
UseBasicParsing = $false # Disabled UseBasicParsing = $false # Disabled
Verbose = $true Verbose = $true
} }
@@ -150,7 +146,8 @@ $Parameters = @{
Invoke-RestMethod @Parameters Invoke-RestMethod @Parameters
# Sometimes older version of zulu-jdk causes conflict, so remove older version before proceeding. # Sometimes older version of zulu-jdk causes conflict, so remove older version before proceeding.
if (Test-Path -Path "$WorkingFolder\ReVanced\jdk") { if (Test-Path -Path "$WorkingFolder\ReVanced\jdk")
{
Remove-Item -Path "$WorkingFolder\ReVanced\jdk" -Recurse -Force Remove-Item -Path "$WorkingFolder\ReVanced\jdk" -Recurse -Force
} }

View File

@@ -11,10 +11,9 @@ Build ReVanced package (.apk) easily than ever using latest ReVanced patches and
* To build `revanced.apk` locally you need just to run [`Build.ps1`](https://github.com/JDM170/ReVanced_Builder/blob/main/Build.ps1) via PowerShell; * To build `revanced.apk` locally you need just to run [`Build.ps1`](https://github.com/JDM170/ReVanced_Builder/blob/main/Build.ps1) via PowerShell;
* All [patches](https://github.com/revanced/revanced-patches) except the followings applied to `revanced.apk`: * All [patches](https://github.com/revanced/revanced-patches) except the followings applied to `revanced.apk`:
* always-autorepeat * always-autorepeat
* enable-wide-searchbar * hide-captions-button
* disable-fullscreen-panels * hide-timestamp
* premium-heading * hide-seekbar
* tablet-mini-player
* The script downloads latest available YouTube package (having parsed [JSON](https://github.com/revanced/revanced-patches/blob/main/patches.json)) supported by ReVanced Team from <https://apkmirror.com> and all dependencies and build package using [Zulu JDK](https://www.azul.com/downloads/?package=jdk); * The script downloads latest available YouTube package (having parsed [JSON](https://github.com/revanced/revanced-patches/blob/main/patches.json)) supported by ReVanced Team from <https://apkmirror.com> and all dependencies and build package using [Zulu JDK](https://www.azul.com/downloads/?package=jdk);
* Script installs no apps — everything will be held in your `Script location folder\ReVanced`; * Script installs no apps — everything will be held in your `Script location folder\ReVanced`;
* After compiling you get `revanced.apk` & `microg.apk` ready to be installed; * After compiling you get `revanced.apk` & `microg.apk` ready to be installed;
@@ -22,11 +21,7 @@ Build ReVanced package (.apk) easily than ever using latest ReVanced patches and
### By using CI/CD ### By using CI/CD
```powershell Trigger the [`Build`](https://github.com/JDM170/ReVanced_Builder/actions/workflows/Build.yml) action manually to create [release page](https://github.com/JDM170/ReVanced_Builder/releases/latest) with configured release notes showing dependencies used for building.
git clone https://github.com/JDM170/ReVanced_Builder
```
Trigger the [`Build`](https://github.com/JDM170/ReVanced_Builder/actions/workflows/Build.yml) Action manually to create [release page](https://github.com/JDM170/ReVanced_Builder/releases/latest) with configured release notes showing dependencies used for building.
![image](https://user-images.githubusercontent.com/10544660/187949763-82fd7a07-8e4e-4527-b631-11920077141f.png) ![image](https://user-images.githubusercontent.com/10544660/187949763-82fd7a07-8e4e-4527-b631-11920077141f.png)
@@ -41,7 +36,11 @@ Trigger the [`Build`](https://github.com/JDM170/ReVanced_Builder/actions/workflo
## Links ## Links
* [APKMirror](https://apkmirror.com)
* [ReVanced CLI](https://github.com/revanced/revanced-cli)
* [ReVanced Patches](https://github.com/revanced/revanced-patches) * [ReVanced Patches](https://github.com/revanced/revanced-patches)
* [ReVanced Manager](https://github.com/revanced/revanced-manager) * [ReVanced Integrations](https://github.com/revanced/revanced-integrations)
* [Telegram](https://t.me/sophia_chat) * [Vanced MicroG](https://github.com/TeamVanced/VancedMicroG)
* [AngleSharp](https://github.com/AngleSharp/AngleSharp) * [AngleSharp](https://github.com/AngleSharp/AngleSharp)
* [Zulu JDK](https://github.com/ScoopInstaller/Java)
* [Sophia Telegram chat](https://t.me/sophia_chat)

View File

@@ -16,31 +16,26 @@ Add-Type -Path $AngleSharpAssemblyPath
# Create parser object # Create parser object
$angleparser = New-Object -TypeName AngleSharp.Html.Parser.HtmlParser $angleparser = New-Object -TypeName AngleSharp.Html.Parser.HtmlParser
# Trying to find correct APK link (not BUNDLE) # Try to find correct NON-Bundle version
# https://www.apkmirror.com/apk/google-inc/youtube/
$apkMirrorLink = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupported)-release/"
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink Uri = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupportedYT)-release/youtube-$($LatestSupportedYT)-android-apk-download/"
UseBasicParsing = $false # Disabled UseBasicParsing = $false # Disabled
Verbose = $true Verbose = $true
} }
$Request = Invoke-Webrequest @Parameters $URLParse = (Invoke-Webrequest @Parameters).Links.outerHTML | Where-Object -FilterScript {$_ -like "*YouTube $($LatestSupported) (nodpi)*"}
$Parsed = $angleparser.ParseDocument($Request.Content) # Check if variable contains a data
$Parsed.All | Where-Object -FilterScript {$_.ClassName -match "table-row headerFont"} | ForEach-Object -Process { if ($URLParse)
foreach($child in $_.children) {
{ $URL = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupportedYT)-release/youtube-$($LatestSupportedYT)-android-apk-download/"
if ($child.InnerHtml -eq "nodpi") }
{ else
$apkPackageLink = (($_.getElementsByTagName("a") | Select-Object -First 1).Href).Substring(57) {
break $URL = "https://www.apkmirror.com/apk/google-inc/youtube/youtube-$($LatestSupportedYT)-release/youtube-$($LatestSupportedYT)-2-android-apk-download/"
}
}
} }
$apkMirrorLink += $apkPackageLink # actual APK link (not BUNDLE)
# Get unique key to generate direct link # Get unique key to generate direct link
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink Uri = $URL
UseBasicParsing = $false # Disabled UseBasicParsing = $false # Disabled
Verbose = $true Verbose = $true
} }
@@ -49,7 +44,7 @@ $Parsed = $angleparser.ParseDocument($Request.Content)
$Key = $Parsed.All | Where-Object -FilterScript {$_.ClassName -match "accent_bg btn btn-flat downloadButton"} | ForEach-Object -Process {$_.Search} $Key = $Parsed.All | Where-Object -FilterScript {$_.ClassName -match "accent_bg btn btn-flat downloadButton"} | ForEach-Object -Process {$_.Search}
$Parameters = @{ $Parameters = @{
Uri = $apkMirrorLink + "download/$($Key)" Uri = "$($URL)/download/$($Key)"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
@@ -66,4 +61,4 @@ $Parameters = @{
} }
Invoke-Webrequest @Parameters Invoke-Webrequest @Parameters
echo "LatestSupportedYT=$LatestSupportedYT" >> $env:GITHUB_ENV echo "LatestSupportedYT=$LatestSupported" >> $env:GITHUB_ENV