Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(net): add option -x to unshare network #130

Merged
merged 11 commits into from
Oct 31, 2023
2 changes: 1 addition & 1 deletion completions/try.bash
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ _try() {

case "${cmd}" in
(try)
opts="-n -y -v -h -i -D -U summary commit explore"
opts="-n -y -v -h -x -i -D -U summary commit explore"
if [[ ${cur} == -* || ${COMP_CWORD} -eq 1 ]]
then
COMPREPLY=( $(compgen -W "${opts}" -- "${cur}") )
Expand Down
4 changes: 4 additions & 0 deletions docs/try.1.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,10 @@ While using *try* you can choose to commit the result to the filesystem or compl

: Show a usage message (and exit).

-x

: Unshare the network namespace.
ezrizhu marked this conversation as resolved.
Show resolved Hide resolved


## Options

Expand Down
16 changes: 16 additions & 0 deletions test/network.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#!/bin/sh

TRY_TOP="${TRY_TOP:-$(git rev-parse --show-toplevel --show-superproject-working-tree)}"
TRY="$TRY_TOP/try"

# Test if network works normally
"$TRY" curl 1.1 || return 1

# Test if ping fails when network is unshared
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What is curl 1.1 supposed to do? You say ping but run curl. Maybe use ping 8.8.8.8?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

curl 1.1 expands to curl 1.0.0.1, which gets you the frontpage of cloudflare's public dns resolver, ping doesn't work due to #131

# curl exit code 7 means Failed to connect to host.
"$TRY" -x curl 1.1
if [ $? -eq 7 ]; then
ezrizhu marked this conversation as resolved.
Show resolved Hide resolved
return 0;
else
return 1;
fi
12 changes: 9 additions & 3 deletions try
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,11 @@ EOF
# --pid: create a new process namespace (needed fr procfs to work right)
# --fork: necessary if we do --pid
# "Creation of a persistent PID namespace will fail if the --fork option is not also specified."
unshare --mount --map-root-user --user --pid --fork "$mount_and_execute"
if [ -z "$EXTRA_NS" ]; then
ezrizhu marked this conversation as resolved.
Show resolved Hide resolved
unshare --mount --map-root-user --user --pid --fork "$mount_and_execute"
else
unshare --mount --map-root-user --user --pid --fork --net "$mount_and_execute"
fi
TRY_EXIT_STATUS=$?

################################################################################
Expand Down Expand Up @@ -476,10 +480,11 @@ error() {

usage() {
cat >&2 <<EOF
Usage: $TRY_COMMAND [-nvhy] [-i PATTERN] [-D DIR] [-U PATH] CMD [ARG ...]
Usage: $TRY_COMMAND [-nvhyx] [-i PATTERN] [-D DIR] [-U PATH] CMD [ARG ...]

-n don't commit or prompt for commit (overrides -y)
-y assume yes to all prompts (overrides -n)
-x unshare the network namespace
ezrizhu marked this conversation as resolved.
Show resolved Hide resolved
-i PATTERN ignore paths that match PATTERN on summary and commit
-D DIR work in DIR (implies -n)
-U PATH path to unionfs helper (e.g., mergerfs, unionfs-fuse)
Expand Down Expand Up @@ -508,7 +513,7 @@ NO_COMMIT="interactive"
# Includes all patterns given using the `-i` flag; will be used with `grep -f`
IGNORE_FILE="$(mktemp)"

while getopts ":yvnhi:D:U:" opt
while getopts ":yvnhxi:D:U:" opt
do
case "$opt" in
(y) NO_COMMIT="commit";;
Expand All @@ -528,6 +533,7 @@ do
fi
UNION_HELPER="$OPTARG"
export UNION_HELPER;;
(x) EXTRA_NS="net";;
(h|*) usage
exit 0;;
esac
Expand Down