mirror of
https://github.com/freedomofpress/dangerzone.git
synced 2025-04-28 18:02:38 +02:00
Compare commits
4 commits
2bcafe0f3b
...
21c02a5614
Author | SHA1 | Date | |
---|---|---|---|
21c02a5614 | |||
![]() |
5ed4a048a0 | ||
![]() |
50627d375c | ||
![]() |
6cb9f46cae |
3 changed files with 17 additions and 6 deletions
13
.github/workflows/scan_released.yml
vendored
13
.github/workflows/scan_released.yml
vendored
|
@ -6,14 +6,21 @@ on:
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
security-scan-container:
|
security-scan-container:
|
||||||
runs-on: ubuntu-latest
|
strategy:
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- runs-on: ubuntu-latest
|
||||||
|
arch: i686
|
||||||
|
- runs-on: macos-latest
|
||||||
|
arch: arm64
|
||||||
|
runs-on: ${{ matrix.runs-on }}
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
- name: Checkout
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
- name: Download container image for the latest release
|
- name: Download container image for the latest release
|
||||||
run: |
|
run: |
|
||||||
VERSION=$(curl https://api.github.com/repos/freedomofpress/dangerzone/releases/latest | jq -r '.tag_name')
|
VERSION=$(curl https://api.github.com/repos/freedomofpress/dangerzone/releases/latest | jq -r '.tag_name')
|
||||||
wget https://github.com/freedomofpress/dangerzone/releases/download/${VERSION}/container.tar.gz
|
wget https://github.com/freedomofpress/dangerzone/releases/download/${VERSION}/container.${{ matrix.arch }}.tar.gz -O container.tar.gz
|
||||||
- name: Load container image
|
- name: Load container image
|
||||||
run: docker load -i container.tar.gz
|
run: docker load -i container.tar.gz
|
||||||
# NOTE: Scan first without failing, else we won't be able to read the scan
|
# NOTE: Scan first without failing, else we won't be able to read the scan
|
||||||
|
@ -30,7 +37,7 @@ jobs:
|
||||||
uses: github/codeql-action/upload-sarif@v3
|
uses: github/codeql-action/upload-sarif@v3
|
||||||
with:
|
with:
|
||||||
sarif_file: ${{ steps.scan_container.outputs.sarif }}
|
sarif_file: ${{ steps.scan_container.outputs.sarif }}
|
||||||
category: container
|
category: container-${{ matrix.arch }}
|
||||||
- name: Inspect container scan report
|
- name: Inspect container scan report
|
||||||
run: cat ${{ steps.scan_container.outputs.sarif }}
|
run: cat ${{ steps.scan_container.outputs.sarif }}
|
||||||
- name: Scan container image
|
- name: Scan container image
|
||||||
|
|
|
@ -248,7 +248,7 @@ class Container(IsolationProvider):
|
||||||
else:
|
else:
|
||||||
msg = (
|
msg = (
|
||||||
f"{Container.CONTAINER_NAME} images found, but IDs do not match."
|
f"{Container.CONTAINER_NAME} images found, but IDs do not match."
|
||||||
f"Found: {found_image_id}, Expected: {','.join(expected_image_ids)}"
|
f" Found: {found_image_id}, Expected: {','.join(expected_image_ids)}"
|
||||||
)
|
)
|
||||||
if raise_on_error:
|
if raise_on_error:
|
||||||
raise ImageNotPresentException(msg)
|
raise ImageNotPresentException(msg)
|
||||||
|
|
|
@ -70,14 +70,18 @@ class Qubes(IsolationProvider):
|
||||||
standard streams explicitly, so that we can afterwards use `Popen.wait()` to
|
standard streams explicitly, so that we can afterwards use `Popen.wait()` to
|
||||||
learn if the qube terminated.
|
learn if the qube terminated.
|
||||||
|
|
||||||
|
Note that we don't close the stderr stream because we want to read debug logs
|
||||||
|
from it. In the rare case where a qube cannot terminate because it's stuck
|
||||||
|
writing at stderr (this is not the expected behavior), we expect that the
|
||||||
|
process will still be forcefully killed after the soft termination timeout
|
||||||
|
expires.
|
||||||
|
|
||||||
[1]: https://github.com/freedomofpress/dangerzone/issues/563#issuecomment-2034803232
|
[1]: https://github.com/freedomofpress/dangerzone/issues/563#issuecomment-2034803232
|
||||||
"""
|
"""
|
||||||
if p.stdin:
|
if p.stdin:
|
||||||
p.stdin.close()
|
p.stdin.close()
|
||||||
if p.stdout:
|
if p.stdout:
|
||||||
p.stdout.close()
|
p.stdout.close()
|
||||||
if p.stderr:
|
|
||||||
p.stderr.close()
|
|
||||||
|
|
||||||
def teleport_dz_module(self, wpipe: IO[bytes]) -> None:
|
def teleport_dz_module(self, wpipe: IO[bytes]) -> None:
|
||||||
"""Send the dangerzone module to another qube, as a zipfile."""
|
"""Send the dangerzone module to another qube, as a zipfile."""
|
||||||
|
|
Loading…
Reference in a new issue