Created
December 9, 2025 22:32
-
-
Save sssemil/ad1a8046e511c629e98c883cc2848a08 to your computer and use it in GitHub Desktop.
Run whatever in a sandbox via firejail with a bit more convinience
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| #!/usr/bin/env bash | |
| set -e | |
| usage() { | |
| echo "usage: $0 <command> -a <writable_path> [-a <writable_path>...]" | |
| exit 1 | |
| } | |
| if [ "$#" -lt 3 ]; then | |
| usage | |
| fi | |
| # Split first arg into command and its flags | |
| read -ra CMD_PARTS <<< "$1" | |
| CMD="${CMD_PARTS[0]}" | |
| CMD_ARGS=("${CMD_PARTS[@]:1}") | |
| shift | |
| # Collect -a arguments | |
| WRITABLE_PATHS=() | |
| while [ "$#" -gt 0 ]; do | |
| case "$1" in | |
| -a) | |
| shift | |
| [ -z "$1" ] && usage | |
| WRITABLE_PATHS+=("$(readlink -f "$1" 2>/dev/null || echo "$1")") | |
| shift | |
| ;; | |
| *) | |
| break | |
| ;; | |
| esac | |
| done | |
| if [ "${#WRITABLE_PATHS[@]}" -eq 0 ]; then | |
| echo "error: at least one -a <writable_path> required" | |
| exit 1 | |
| fi | |
| # Resolve command to full path | |
| export PATH="$HOME/.local/bin:$HOME/.node/bin:$PATH" | |
| CMD_PATH="$(which "$CMD" 2>/dev/null || readlink -f "$CMD")" | |
| if [ ! -x "$CMD_PATH" ]; then | |
| echo "error: cannot find executable: $CMD" | |
| exit 1 | |
| fi | |
| # Build firejail args | |
| FIREJAIL_ARGS=( | |
| --noprofile | |
| --read-only=/ | |
| --read-only=/home | |
| ) | |
| for P in "${WRITABLE_PATHS[@]}"; do | |
| FIREJAIL_ARGS+=(--noblacklist="$P" --read-write="$P") | |
| done | |
| exec firejail "${FIREJAIL_ARGS[@]}" "$CMD_PATH" "${CMD_ARGS[@]}" "$@" |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment