Skip to content

Check firmware update #141

Check firmware update

Check firmware update #141

Workflow file for this run

name: Check firmware update
on:
schedule:
- cron: '0 0 * * *'
push:
workflow_dispatch:
jobs:
update:
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
include:
- model: "SM-P613"
region: "PHE"
- model: "SM-P619"
region: "PHE"
steps:
- name: Checkout repo
uses: actions/checkout@v2
with:
submodules: true
- name: Compare latest version with current version
id: check
run: |
need_update=0
latest=`curl --retry 5 --retry-delay 5 http://fota-cloud-dn.ospserver.net/firmware/${{ matrix.region }}/${{ matrix.model }}/version.xml | grep latest | sed 's/^[^>]*>//' | sed 's/<.*//'`
latest_short=`echo $latest | cut -d'/' -f1`
latest_modem=`echo $latest | cut -d'/' -f3`
current=`cat current.${{ matrix.model }}` || need_update=1
[[ $latest != $current ]] && need_update=1
echo ::set-output name=latest_version::$latest
echo ::set-output name=latest_shortversion::$latest_short
echo ::set-output name=latest_modemversion::$latest_modem
echo ::set-output name=need_update::$need_update
- name: Use Node.js 15
if: steps.check.outputs.need_update == 1
uses: actions/setup-node@v1
with:
node-version: 15
- name: Install dependencies
if: steps.check.outputs.need_update == 1
run: sudo npm i -g samfirm
- name: Fetch firmware
if: steps.check.outputs.need_update == 1
run: samfirm -m ${{ matrix.model }} -r ${{ matrix.region }}
- name: Get path of files
if: steps.check.outputs.need_update == 1
id: files
run: |
echo ::set-output name=ap::`find -name AP*`
echo ::set-output name=bl::`find -name BL*`
echo ::set-output name=cp::`find -name CP*`
- name: Check contents of downloaded firmware
if: steps.check.outputs.need_update == 1
run: |
tar tvf ${{ steps.files.outputs.ap }}
tar tvf ${{ steps.files.outputs.bl }}
tar tvf ${{ steps.files.outputs.cp }} || true
- name: Remove unwanted files from AP and BL
if: steps.check.outputs.need_update == 1
run: |
tar vf ${{ steps.files.outputs.ap }} --delete boot.img.lz4 recovery.img.lz4 super.img.lz4 dtbo.img.lz4 persist.img.lz4 userdata.img.lz4 vbmeta.img.lz4 vbmeta_system.img.lz4 meta-data
md5sum ${{ steps.files.outputs.ap }} | sed "s/ .*\// /;s/\.md5$//" >> ${{ steps.files.outputs.ap }}
tar vf ${{ steps.files.outputs.bl }} --delete vbmeta.img.lz4
md5sum ${{ steps.files.outputs.bl }} | sed "s/ .*\// /;s/\.md5$//" >> ${{ steps.files.outputs.bl }}
- name: Update current version
if: steps.check.outputs.need_update == 1
run: |
git config --local user.email "41898282+github-actions[bot]@users.noreply.github.com"
git config --local user.name "github-actions[bot]"
git pull origin ${{github.ref}} --ff-only
echo ${{ steps.check.outputs.latest_version }} > current.${{ matrix.model }}
git add current.${{ matrix.model }}
git commit -m "${{ matrix.model }}: ${{ steps.check.outputs.latest_version }}"
git tag ${{ steps.check.outputs.latest_shortversion }}
- name: Push changes to repo
if: steps.check.outputs.need_update == 1
uses: ad-m/github-push-action@master
with:
tags: true
github_token: ${{ secrets.GITHUB_TOKEN }}
- name: Upload release assets
if: steps.check.outputs.need_update == 1
uses: softprops/action-gh-release@v1
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
tag_name: ${{ steps.check.outputs.latest_shortversion }}
files: |
${{ steps.files.outputs.ap }}
${{ steps.files.outputs.bl }}
${{ steps.files.outputs.cp }}