6 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
2 changed files with 45 additions and 25 deletions

View File

@@ -1,6 +1,8 @@
name: Build
on:
schedule:
- cron: "30 3 1 * *"
workflow_dispatch:
jobs:
@@ -36,6 +38,14 @@ jobs:
run: |
. 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
run: |
$JavaPath = (Resolve-Path -Path "Temp\jdk_windows-x64_bin\zulu*win_x64\bin\java.exe").Path
@@ -73,9 +83,9 @@ jobs:
echo "RELEASE_NAME=$ReleaseName" >> $env:GITHUB_ENV
- name: Upload to Releases
# https://github.com/softprops/action-gh-release/issues/556#issuecomment-2556947371
uses: softprops/action-gh-release@v2.1.0
uses: softprops/action-gh-release@v2.2.1
with:
tag_name: ${{ env.RELEASE_NAME }}
body_path: ${{ steps.read_release.outputs.ReleaseBody }}
files: ReVanced.zip

View File

@@ -28,10 +28,10 @@ if ($Host.Version.Major -eq 5)
}
# Download all files to "Script location folder\ReVanced"
$WorkingFolder = Split-Path $MyInvocation.MyCommand.Path -Parent
if (-not (Test-Path -Path "$WorkingFolder\ReVanced"))
$CurrentFolder = Split-Path $MyInvocation.MyCommand.Path -Parent
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
@@ -44,6 +44,7 @@ $JSON = (Invoke-Webrequest @Parameters).Content | ConvertFrom-Json
$versions = ($JSON | Where-Object -FilterScript {$_.name -eq "Video ads"})
$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
@@ -58,7 +59,7 @@ $URL = (Invoke-Webrequest @Parameters).Links.href | Where-Object -FilterScript {
$Parameters = @{
Uri = $URL
OutFile = "$WorkingFolder\ReVanced\youtube.apk"
OutFile = "$CurrentFolder\ReVanced\youtube.apk"
UseBasicParsing = $true
Verbose = $true
}
@@ -106,7 +107,7 @@ $URL_Part = $URL_Part.Replace("&amp;", "&")
# Finally, get the real link
$Parameters = @{
Uri = "https://www.apkmirror.com$URL_Part"
OutFile = "$WorkingFolder\ReVanced\youtube.apk"
OutFile = "$CurrentFolder\ReVanced\youtube.apk"
UseBasicParsing = $true
Verbose = $true
}
@@ -123,7 +124,7 @@ $Parameters = @{
$URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "application/java-archive"}).browser_download_url
$Parameters = @{
Uri = $URL
Outfile = "$WorkingFolder\ReVanced\revanced-cli.jar"
Outfile = "$CurrentFolder\ReVanced\revanced-cli.jar"
UseBasicParsing = $true
Verbose = $true
}
@@ -140,7 +141,7 @@ $Parameters = @{
$URL = ((Invoke-RestMethod @Parameters).assets | Where-Object -FilterScript {$_.content_type -eq "text/plain"}).browser_download_url
$Parameters = @{
Uri = $URL
Outfile = "$WorkingFolder\ReVanced\revanced-patches.rvp"
Outfile = "$CurrentFolder\ReVanced\revanced-patches.rvp"
UseBasicParsing = $true
Verbose = $true
}
@@ -163,7 +164,7 @@ foreach($url in $URL) {
}
$Parameters = @{
Uri = $url.browser_download_url
Outfile = "$WorkingFolder\ReVanced\$($url.name)"
Outfile = "$CurrentFolder\ReVanced\$($url.name)"
UseBasicParsing = $true
Verbose = $true
}
@@ -171,9 +172,9 @@ foreach($url in $URL) {
}
# 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
@@ -187,7 +188,7 @@ $Parameters = @{
$URL = (Invoke-RestMethod @Parameters).architecture."64bit".url
$Parameters = @{
Uri = $URL
Outfile = "$WorkingFolder\ReVanced\jdk_windows-x64_bin.zip"
Outfile = "$CurrentFolder\ReVanced\jdk_windows-x64_bin.zip"
UseBasicParsing = $true
Verbose = $true
}
@@ -195,32 +196,41 @@ Invoke-RestMethod @Parameters
# Expand jdk_windows-x64_bin archive
$Parameters = @{
Path = "$WorkingFolder\ReVanced\jdk_windows-x64_bin.zip"
DestinationPath = "$WorkingFolder\ReVanced\jdk"
Path = "$CurrentFolder\ReVanced\jdk_windows-x64_bin.zip"
DestinationPath = "$CurrentFolder\ReVanced\jdk"
Force = $true
Verbose = $true
}
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
& "$WorkingFolder\ReVanced\jdk\zulu*win_x64\bin\java.exe" `
-jar "$WorkingFolder\ReVanced\revanced-cli.jar" patch `
--patches "$WorkingFolder\ReVanced\revanced-patches.rvp" `
& "$CurrentFolder\ReVanced\jdk\zulu*win_x64\bin\java.exe" `
-jar "$CurrentFolder\ReVanced\revanced-cli.jar" patch `
--patches "$CurrentFolder\ReVanced\revanced-patches.rvp" `
--disable "Always repeat" `
--disable "Disable auto captions" `
--disable "Hide timestamp" `
--disable "Hide seekbar" `
--purge `
--temporary-files-path "$WorkingFolder\ReVanced\Temp" `
--out "$WorkingFolder\ReVanced\revanced.apk" `
"$WorkingFolder\ReVanced\youtube.apk"
--temporary-files-path "$CurrentFolder\ReVanced\Temp" `
--out "$CurrentFolder\ReVanced\revanced.apk" `
"$CurrentFolder\ReVanced\youtube.apk"
# 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-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`""