10 Commits

Author SHA1 Message Date
33f148cbe6 Update workflow (added if condition for key storage addition step) 2025-11-06 19:25:03 +07:00
cbc170c0ec New workflow step: Add keystore from secrets
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2025-11-01 23:44:49 +07:00
4c356736b0 Update Build.yml
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2025-10-01 19:53:12 +07:00
ca508c0e24 Update Build.ps1
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2025-05-18 23:24:24 +07:00
b879ad95f3 Update Build.ps1
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2025-01-28 21:32:16 +07:00
3edfdcc627 Update Build.yml
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2025-01-28 21:32:03 +07:00
d2ab1f83d7 Update README.md 2025-01-01 18:10:04 +07:00
689cf90f6a Update Build.yml 2025-01-01 16:38:54 +07:00
9c38444051 Update YouTube.ps1
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2024-12-01 18:29:38 +07:00
65dc96ac52 Update files
Signed-off-by: Lev Rusanov <30170278+JDM170@users.noreply.github.com>
2024-12-01 18:23:09 +07:00
7 changed files with 80 additions and 89 deletions

View File

@@ -1,6 +1,8 @@
name: Build name: Build
on: on:
schedule:
- cron: "30 3 1 * *"
workflow_dispatch: workflow_dispatch:
jobs: jobs:
@@ -28,10 +30,6 @@ jobs:
run: | run: |
. Scripts\ReVanced_Patches.ps1 . Scripts\ReVanced_Patches.ps1
- name: Download ReVanced Integrations
run: |
. Scripts\ReVanced_Intergrations.ps1
- name: Download Vanced MicroG - name: Download Vanced MicroG
run: | run: |
. Scripts\MicroG.ps1 . Scripts\MicroG.ps1
@@ -40,18 +38,25 @@ jobs:
run: | run: |
. Scripts\Zulu_JDK.ps1 . Scripts\Zulu_JDK.ps1
- name: Add keystore from secrets
env:
KEYSTORE: ${{ secrets.REVANCED_KEYSTORE }}
if: ${{ env.KEYSTORE != '' }}
run: |
[byte[]]$bytes = [convert]::FromBase64String('${{ env.KEYSTORE }}')
[System.IO.File]::WriteAllBytes("Temp\revanced.keystore", $bytes)
- name: Build - 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
& $JavaPath ` & $JavaPath `
-jar "Temp\revanced-cli.jar" patch ` -jar "Temp\revanced-cli.jar" patch `
--patch-bundle "Temp\revanced-patches.jar" ` --patches "Temp\revanced-patches.rvp" `
--merge "Temp\revanced-integrations.apk" ` --disable "Always repeat" `
--exclude "Always repeat" ` --disable "Disable auto captions" `
--exclude "Hide captions button" ` --disable "Hide timestamp" `
--exclude "Hide timestamp" ` --disable "Hide seekbar" `
--exclude "Hide seekbar" `
--purge ` --purge `
--out "Temp\revanced.apk" ` --out "Temp\revanced.apk" `
"Temp\youtube.apk" "Temp\youtube.apk"
@@ -71,15 +76,16 @@ jobs:
id: read_release id: read_release
run: | run: |
# https://en.wikipedia.org/wiki/Percent-encoding # https://en.wikipedia.org/wiki/Percent-encoding
(Get-Content -Path ReleaseNotesTemplate.md -Encoding utf8 -Raw).replace("YouTubeTag", "${{ env.LatestSupportedYT }}").replace("CLITag", "${{ env.CLIvtag }}").replace("PatchesTag", "${{ env.Patchesvtag }}").replace("IntegrationsTag", "${{ env.IntegrationsTag }}").replace("MicroGTag", "${{ env.MicroGTag }}").replace("ZuluTag", "${{ env.ZuluTag }}") | Set-Content -Path ReleaseNotesTemplate.md -Encoding utf8 -Force (Get-Content -Path ReleaseNotesTemplate.md -Encoding utf8 -Raw).replace("YouTubeTag", "${{ env.LatestSupportedYT }}").replace("CLITag", "${{ env.CLIvtag }}").replace("PatchesTag", "${{ env.Patchesvtag }}").replace("MicroGTag", "${{ env.MicroGTag }}").replace("ZuluTag", "${{ env.ZuluTag }}") | Set-Content -Path ReleaseNotesTemplate.md -Encoding utf8 -Force
# https://trstringer.com/github-actions-multiline-strings/ # https://trstringer.com/github-actions-multiline-strings/
Add-Content -Path $env:GITHUB_OUTPUT -Value "ReleaseBody=ReleaseNotesTemplate.md" Add-Content -Path $env:GITHUB_OUTPUT -Value "ReleaseBody=ReleaseNotesTemplate.md"
$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: Upload to Releases - name: Upload to Releases
uses: softprops/action-gh-release@master uses: softprops/action-gh-release@v2.2.1
with: with:
tag_name: ${{ env.RELEASE_NAME }} tag_name: ${{ env.RELEASE_NAME }}
body_path: ${{ steps.read_release.outputs.ReleaseBody }} body_path: ${{ steps.read_release.outputs.ReleaseBody }}
files: ReVanced.zip files: ReVanced.zip

102
Build.ps1
View File

@@ -28,21 +28,24 @@ if ($Host.Version.Major -eq 5)
} }
# Download all files to "Script location folder\ReVanced" # Download all files to "Script location folder\ReVanced"
$WorkingFolder = Split-Path $MyInvocation.MyCommand.Path -Parent $CurrentFolder = Split-Path $MyInvocation.MyCommand.Path -Parent
if (-not (Test-Path -Path "$WorkingFolder\ReVanced")) if (-not (Test-Path -Path "$CurrentFolder\ReVanced"))
{ {
New-Item -Path "$WorkingFolder\ReVanced" -ItemType Directory -Force New-Item -Path "$CurrentFolder\ReVanced" -ItemType Directory -Force
} }
# Get the latest supported YouTube version to patch # Get the latest supported YouTube version to patch
# https://api.revanced.app/docs/swagger # https://api.revanced.app
$Parameters = @{ $Parameters = @{
Uri = "https://api.revanced.app/v2/patches/latest" Uri = "https://api.revanced.app/v4/patches/list"
UseBasicParsing = $true UseBasicParsing = $true
} }
$JSON = (Invoke-RestMethod @Parameters).patches $JSON = (Invoke-Webrequest @Parameters).Content | ConvertFrom-Json
$versions = ($JSON | Where-Object -FilterScript {$_.compatiblePackages.name -eq "com.google.android.youtube"}).compatiblePackages.versions $versions = ($JSON | Where-Object -FilterScript {$_.name -eq "Video ads"})
$LatestSupported = $versions | Sort-Object -Descending -Unique | Select-Object -First 1 $LatestSupported = $versions.compatiblePackages.'com.google.android.youtube' | Sort-Object -Descending -Unique | Select-Object -First 1
Write-Verbose -Message "" -Verbose
Write-Verbose -Message "Downloading the latest supported YouTube apk" -Verbose
# We need a NON-bundle version # We need a NON-bundle version
<# <#
@@ -56,7 +59,7 @@ $URL = (Invoke-Webrequest @Parameters).Links.href | Where-Object -FilterScript {
$Parameters = @{ $Parameters = @{
Uri = $URL Uri = $URL
OutFile = "$WorkingFolder\ReVanced\youtube.apk" OutFile = "$CurrentFolder\ReVanced\youtube.apk"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
@@ -104,12 +107,14 @@ $URL_Part = $URL_Part.Replace("&amp;", "&")
# Finally, get the real link # Finally, get the real link
$Parameters = @{ $Parameters = @{
Uri = "https://www.apkmirror.com$URL_Part" Uri = "https://www.apkmirror.com$URL_Part"
OutFile = "$WorkingFolder\ReVanced\youtube.apk" OutFile = "$CurrentFolder\ReVanced\youtube.apk"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
Invoke-Webrequest @Parameters Invoke-Webrequest @Parameters
Write-Verbose -Message "" -Verbose
Write-Verbose -Message "Downloading ReVanced CLI" -Verbose
# https://github.com/revanced/revanced-cli # https://github.com/revanced/revanced-cli
$Parameters = @{ $Parameters = @{
Uri = "https://api.github.com/repos/revanced/revanced-cli/releases/latest" Uri = "https://api.github.com/repos/revanced/revanced-cli/releases/latest"
@@ -119,42 +124,31 @@ $Parameters = @{
$URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "application/java-archive"}).browser_download_url $URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "application/java-archive"}).browser_download_url
$Parameters = @{ $Parameters = @{
Uri = $URL Uri = $URL
Outfile = "$WorkingFolder\ReVanced\revanced-cli.jar" Outfile = "$CurrentFolder\ReVanced\revanced-cli.jar"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
Invoke-RestMethod @Parameters Invoke-RestMethod @Parameters
Write-Verbose -Message "" -Verbose
Write-Verbose -Message "Downloading ReVanced patches" -Verbose
# https://github.com/revanced/revanced-patches # https://github.com/revanced/revanced-patches
$Parameters = @{ $Parameters = @{
Uri = "https://api.github.com/repos/revanced/revanced-patches/releases/latest" Uri = "https://api.github.com/repos/revanced/revanced-patches/releases/latest"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
$URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "application/java-archive"}).browser_download_url $URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "text/plain"}).browser_download_url
$Parameters = @{ $Parameters = @{
Uri = $URL Uri = $URL
Outfile = "$WorkingFolder\ReVanced\revanced-patches.jar" Outfile = "$CurrentFolder\ReVanced\revanced-patches.rvp"
UseBasicParsing = $true
Verbose = $true
}
Invoke-RestMethod @Parameters
# https://github.com/revanced/revanced-integrations
$Parameters = @{
Uri = "https://api.github.com/repos/revanced/revanced-integrations/releases/latest"
UseBasicParsing = $true
Verbose = $true
}
$URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "application/vnd.android.package-archive"}).browser_download_url
$Parameters = @{
Uri = $URL
Outfile = "$WorkingFolder\ReVanced\revanced-integrations.apk"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
Invoke-RestMethod @Parameters Invoke-RestMethod @Parameters
Write-Verbose -Message "" -Verbose
Write-Verbose -Message "Downloading ReVanced GmsCore" -Verbose
# https://github.com/ReVanced/GmsCore # https://github.com/ReVanced/GmsCore
$Parameters = @{ $Parameters = @{
Uri = "https://api.github.com/repos/ReVanced/GmsCore/releases/latest" Uri = "https://api.github.com/repos/ReVanced/GmsCore/releases/latest"
@@ -170,7 +164,7 @@ foreach($url in $URL) {
} }
$Parameters = @{ $Parameters = @{
Uri = $url.browser_download_url Uri = $url.browser_download_url
Outfile = "$WorkingFolder\ReVanced\$($url.name)" Outfile = "$CurrentFolder\ReVanced\$($url.name)"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
@@ -178,11 +172,13 @@ foreach($url in $URL) {
} }
# 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 "$CurrentFolder\ReVanced\jdk")
{ {
Remove-Item -Path "$WorkingFolder\ReVanced\jdk" -Recurse -Force Remove-Item -Path "$CurrentFolder\ReVanced\jdk" -Recurse -Force
} }
Write-Verbose -Message "" -Verbose
Write-Verbose -Message "Downloading Azul Zulu" -Verbose
# https://github.com/ScoopInstaller/Java/blob/master/bucket/zulu-jdk.json # https://github.com/ScoopInstaller/Java/blob/master/bucket/zulu-jdk.json
$Parameters = @{ $Parameters = @{
Uri = "https://raw.githubusercontent.com/ScoopInstaller/Java/master/bucket/zulu-jdk.json" Uri = "https://raw.githubusercontent.com/ScoopInstaller/Java/master/bucket/zulu-jdk.json"
@@ -192,7 +188,7 @@ $Parameters = @{
$URL = (Invoke-RestMethod @Parameters).architecture."64bit".url $URL = (Invoke-RestMethod @Parameters).architecture."64bit".url
$Parameters = @{ $Parameters = @{
Uri = $URL Uri = $URL
Outfile = "$WorkingFolder\ReVanced\jdk_windows-x64_bin.zip" Outfile = "$CurrentFolder\ReVanced\jdk_windows-x64_bin.zip"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }
@@ -200,33 +196,41 @@ Invoke-RestMethod @Parameters
# Expand jdk_windows-x64_bin archive # Expand jdk_windows-x64_bin archive
$Parameters = @{ $Parameters = @{
Path = "$WorkingFolder\ReVanced\jdk_windows-x64_bin.zip" Path = "$CurrentFolder\ReVanced\jdk_windows-x64_bin.zip"
DestinationPath = "$WorkingFolder\ReVanced\jdk" DestinationPath = "$CurrentFolder\ReVanced\jdk"
Force = $true Force = $true
Verbose = $true Verbose = $true
} }
Expand-Archive @Parameters Expand-Archive @Parameters
Remove-Item -Path "$WorkingFolder\ReVanced\jdk_windows-x64_bin.zip" -Force Remove-Item -Path "$CurrentFolder\ReVanced\jdk_windows-x64_bin.zip" -Force
# Let's create patched APK # Let's create patched APK
& "$WorkingFolder\ReVanced\jdk\zulu*win_x64\bin\java.exe" ` & "$CurrentFolder\ReVanced\jdk\zulu*win_x64\bin\java.exe" `
-jar "$WorkingFolder\ReVanced\revanced-cli.jar" patch ` -jar "$CurrentFolder\ReVanced\revanced-cli.jar" patch `
--patch-bundle "$WorkingFolder\ReVanced\revanced-patches.jar" ` --patches "$CurrentFolder\ReVanced\revanced-patches.rvp" `
--merge "$WorkingFolder\ReVanced\revanced-integrations.apk" ` --disable "Always repeat" `
--exclude "Always repeat" ` --disable "Disable auto captions" `
--exclude "Hide captions button" ` --disable "Hide timestamp" `
--exclude "Hide timestamp" ` --disable "Hide seekbar" `
--exclude "Hide seekbar" `
--purge ` --purge `
--temporary-files-path "$WorkingFolder\ReVanced\Temp" ` --temporary-files-path "$CurrentFolder\ReVanced\Temp" `
--out "$WorkingFolder\ReVanced\revanced.apk" ` --out "$CurrentFolder\ReVanced\revanced.apk" `
"$WorkingFolder\ReVanced\youtube.apk" "$CurrentFolder\ReVanced\youtube.apk"
# Open working directory with builded files # Open working directory with builded files
# Invoke-Item -Path "$WorkingFolder\ReVanced" # Invoke-Item -Path "$CurrentFolder\ReVanced"
# Remove temp directory, because cli failed to clean up directory # Remove temp directory, because cli failed to clean up directory
# Remove-Item -Path "$WorkingFolder\ReVanced\Temp" -Recurse -Force -Confirm:$false # Remove-Item -Path "$CurrentFolder\ReVanced\Temp" -Recurse -Force -Confirm:$false
Write-Warning -Message "Latest available revanced.apk & microg.apk are ready in `"$WorkingFolder\ReVanced`"" $Files = @(
"$CurrentFolder\ReVanced\Temp",
"$CurrentFolder\ReVanced\jdk",
"$CurrentFolder\ReVanced\revanced-cli.jar",
"$CurrentFolder\ReVanced\revanced-patches.rvp",
"$CurrentFolder\ReVanced\youtube.apk"
)
Remove-Item -Path $Files -Recurse -Force
Write-Warning -Message "Latest available revanced.apk & microg.apk are ready in `"$CurrentFolder\ReVanced`""

View File

@@ -14,7 +14,7 @@ Build ReVanced package (.apk) easily than ever using latest ReVanced patches and
* hide-captions-button * hide-captions-button
* hide-timestamp * hide-timestamp
* hide-seekbar * hide-seekbar
* The script downloads latest available YouTube package (having parsed [ReVanced API](https://api.revanced.app/v2/patches/latest)) supported by ReVanced Team from [APKMirror](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 [ReVanced API](https://api.revanced.app/v4/patches/list)) supported by ReVanced Team from [APKMirror](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;
* Release notes are generated dynamically using the [ReleaseNotesTemplate.md](https://github.com/JDM170/ReVanced_Builder/blob/main/ReleaseNotesTemplate.md) template. * Release notes are generated dynamically using the [ReleaseNotesTemplate.md](https://github.com/JDM170/ReVanced_Builder/blob/main/ReleaseNotesTemplate.md) template.
@@ -30,7 +30,8 @@ Trigger the [`Build`](https://github.com/JDM170/ReVanced_Builder/actions/workflo
## Requirements if you compile locally ## Requirements if you compile locally
* Windows 10 x64 or Windows 11 * Windows 10 x64 or Windows 11
* Windows PowerShell 5.1/7 * Windows PowerShell 5.1
* if you want to use PowerShell 7, you will have to install a 3rd party HTML parser ([AngleSharp](https://github.com/AngleSharp/AngleSharp))
## Links ## Links
@@ -38,7 +39,6 @@ Trigger the [`Build`](https://github.com/JDM170/ReVanced_Builder/actions/workflo
* [APKMirror](https://apkmirror.com) * [APKMirror](https://apkmirror.com)
* [ReVanced CLI](https://github.com/revanced/revanced-cli) * [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 Integrations](https://github.com/revanced/revanced-integrations)
* [ReVanced MicroG](https://github.com/ReVanced/GmsCore) * [ReVanced MicroG](https://github.com/ReVanced/GmsCore)
* [AngleSharp](https://github.com/AngleSharp/AngleSharp) * [AngleSharp](https://github.com/AngleSharp/AngleSharp)
* [Zulu JDK](https://github.com/ScoopInstaller/Java) * [Zulu JDK](https://github.com/ScoopInstaller/Java)

View File

@@ -3,6 +3,5 @@
* YouTube YouTubeTag; * YouTube YouTubeTag;
* ReVanced CLI CLITag; * ReVanced CLI CLITag;
* ReVanced Patches PatchesTag; * ReVanced Patches PatchesTag;
* ReVanced Integrations IntegrationsTag;
* ReVanced MicroG MicroGTag; * ReVanced MicroG MicroGTag;
* Azul Zulu ZuluTag. * Azul Zulu ZuluTag.

View File

@@ -1,18 +0,0 @@
# https://github.com/revanced/revanced-integrations
$Parameters = @{
Uri = "https://api.github.com/repos/revanced/revanced-integrations/releases/latest"
UseBasicParsing = $true
Verbose = $true
}
$apiResult = Invoke-RestMethod @Parameters
$URL = ($apiResult.assets | Where-Object -FilterScript {$_.content_type -eq "application/vnd.android.package-archive"}).browser_download_url
$TAG = $apiResult.tag_name
$Parameters = @{
Uri = $URL
Outfile = "Temp\revanced-integrations.apk"
UseBasicParsing = $true
Verbose = $true
}
Invoke-RestMethod @Parameters
echo "IntegrationsTag=$TAG" >> $env:GITHUB_ENV

View File

@@ -5,11 +5,11 @@ $Parameters = @{
Verbose = $true Verbose = $true
} }
$apiResult = Invoke-RestMethod @Parameters $apiResult = Invoke-RestMethod @Parameters
$URL = ($apiResult.assets | Where-Object -FilterScript {$_.content_type -eq "application/java-archive"}).browser_download_url $URL = ($apiResult.assets | Where-Object -FilterScript {$_.content_type -eq "text/plain"}).browser_download_url
$TAG = $apiResult.tag_name $TAG = $apiResult.tag_name
$Parameters = @{ $Parameters = @{
Uri = $URL Uri = $URL
Outfile = "Temp\revanced-patches.jar" Outfile = "Temp\revanced-patches.rvp"
UseBasicParsing = $true UseBasicParsing = $true
Verbose = $true Verbose = $true
} }

View File

@@ -1,12 +1,12 @@
# Get the latest supported YouTube version to patch # Get the latest supported YouTube version to patch
# https://api.revanced.app/docs/swagger # https://api.revanced.app/docs/swagger
$Parameters = @{ $Parameters = @{
Uri = "https://api.revanced.app/v2/patches/latest" Uri = "https://api.revanced.app/v4/patches/list"
UseBasicParsing = $true UseBasicParsing = $true
} }
$JSON = (Invoke-RestMethod @Parameters).patches $JSON = (Invoke-Webrequest @Parameters).Content | ConvertFrom-Json
$versions = ($JSON | Where-Object -FilterScript {$_.compatiblePackages.name -eq "com.google.android.youtube"}).compatiblePackages.versions $versions = ($JSON | Where-Object -FilterScript {$_.name -eq "Video ads"})
$LatestSupported = $versions | Sort-Object -Descending -Unique | Select-Object -First 1 $LatestSupported = $versions.compatiblePackages.'com.google.android.youtube' | Sort-Object -Descending -Unique | Select-Object -First 1
# We need a NON-bundle version # We need a NON-bundle version
# https://apkpure.net/ru/youtube/com.google.android.youtube/versions # https://apkpure.net/ru/youtube/com.google.android.youtube/versions