Fix #12: pin CI actions to SHAs, container to digest, bound deps

Supply-chain hardening for the release pipeline:
- actions/checkout and softprops/action-gh-release pinned from floating major
  tags to commit SHAs (v4.2.2 / v2.2.1) — a moved tag can no longer inject code
  into the job that holds the release token.
- Linux/arm64 build container pinned by manifest-list digest
  (nikolaik/python-nodejs:python3.12-nodejs20@sha256:9ff0859…).
- requirements-gui.txt gains upper bounds so a breaking major (e.g. numpy 3,
  PySide6 7) can't silently change a release binary; current versions still
  satisfy, so no build change.

Deferred (noted on the issue): hash-verifying the Windows get-pip.py / embed-zip
download — low value + fragile (get-pip.py isn't hash-stable) and that fallback
path is dormant now that the runner has Python installed system-wide.

Closes #12

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
Claude-Session: https://claude.ai/code/session_016yT89n4zR4qbrySoSiEyZs
This commit is contained in:
2026-07-01 19:42:51 -04:00
parent 39fcf3fb55
commit 0b0ecc96e7
2 changed files with 16 additions and 14 deletions
+10 -10
View File
@@ -12,7 +12,7 @@ jobs:
windows:
runs-on: windows-latest # self-hosted Windows runner (no Python preinstalled)
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
- name: Build OBDash.exe (PyInstaller)
shell: pwsh
run: |
@@ -45,7 +45,7 @@ jobs:
(Get-FileHash OBDash-windows.exe -Algorithm SHA256).Hash.ToLower() + " OBDash-windows.exe" | Out-File -Encoding ascii OBDash-windows.exe.sha256
- name: Publish to release
if: startsWith(github.ref, 'refs/tags/')
uses: softprops/action-gh-release@v2
uses: softprops/action-gh-release@c95fe1489396fe8a9eb87c0abf8aa5b2ef267fda # v2.2.1
with:
files: |
OBDash-windows.exe
@@ -56,7 +56,7 @@ jobs:
macos:
runs-on: self-hosted-mac
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
- name: Build OBDash.app (PyInstaller)
shell: bash
run: |
@@ -69,7 +69,7 @@ jobs:
shasum -a 256 OBDash-macos.zip > OBDash-macos.zip.sha256
- name: Publish to release
if: startsWith(github.ref, 'refs/tags/')
uses: softprops/action-gh-release@v2
uses: softprops/action-gh-release@c95fe1489396fe8a9eb87c0abf8aa5b2ef267fda # v2.2.1
with:
files: |
OBDash-macos.zip
@@ -79,9 +79,9 @@ jobs:
linux-amd64:
runs-on: docker # Linux x86_64 runner
container: nikolaik/python-nodejs:python3.12-nodejs20 # has python+pip AND node (for checkout)
container: nikolaik/python-nodejs:python3.12-nodejs20@sha256:9ff0859871d1b3c382a39aa23d998929edaaefb31e6b3cb67f30d2f8c832db73 # has python+pip AND node (for checkout)
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
- name: Build OBDash (PyInstaller)
shell: bash
run: |
@@ -93,7 +93,7 @@ jobs:
sha256sum OBDash-linux-x86_64 > OBDash-linux-x86_64.sha256
- name: Publish to release
if: startsWith(github.ref, 'refs/tags/')
uses: softprops/action-gh-release@v2
uses: softprops/action-gh-release@c95fe1489396fe8a9eb87c0abf8aa5b2ef267fda # v2.2.1
with:
files: |
OBDash-linux-x86_64
@@ -103,9 +103,9 @@ jobs:
linux-arm64:
runs-on: arm64 # Raspberry Pi (aarch64) runner
container: nikolaik/python-nodejs:python3.12-nodejs20 # multi-arch: pulls arm64
container: nikolaik/python-nodejs:python3.12-nodejs20@sha256:9ff0859871d1b3c382a39aa23d998929edaaefb31e6b3cb67f30d2f8c832db73 # multi-arch: pulls arm64
steps:
- uses: actions/checkout@v4
- uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
- name: Build OBDash (PyInstaller)
shell: bash
run: |
@@ -117,7 +117,7 @@ jobs:
sha256sum OBDash-linux-aarch64 > OBDash-linux-aarch64.sha256
- name: Publish to release
if: startsWith(github.ref, 'refs/tags/')
uses: softprops/action-gh-release@v2
uses: softprops/action-gh-release@c95fe1489396fe8a9eb87c0abf8aa5b2ef267fda # v2.2.1
with:
files: |
OBDash-linux-aarch64
+6 -4
View File
@@ -1,7 +1,9 @@
# GUI dependencies (cross-platform: Windows / macOS / Linux, incl. Apple Silicon)
# pip install -r requirements-gui.txt
# python run_gui.py
PySide6>=6.6
pyqtgraph>=0.13
numpy>=1.24
pyserial>=3.5
# Upper bounds guard the release binaries against a surprise breaking major bump
# while still resolving to wheels across the range. (bleak is optional — BLE only.)
PySide6>=6.6,<7
pyqtgraph>=0.13,<0.15
numpy>=1.24,<3
pyserial>=3.5,<4