Try to rely less on hardcoded paths
This commit is contained in:
15
lib/args.nim
15
lib/args.nim
@@ -5,9 +5,10 @@ type Args* = object
|
||||
name*: Option[string]
|
||||
cmd*: Option[seq[string]]
|
||||
profile*: Option[string]
|
||||
debug*: bool
|
||||
|
||||
proc getCmd*(args: Args): seq[string] =
|
||||
return args.cmd.get(@[getEnv("SHELL", "/bin/bash")])
|
||||
return args.cmd.get(@[getEnv("SHELL", "/bin/sh")])
|
||||
|
||||
proc getProfile*(args: Args): string =
|
||||
if args.profile.isSome:
|
||||
@@ -16,22 +17,26 @@ proc getProfile*(args: Args): string =
|
||||
return "default"
|
||||
|
||||
proc parseArgs*(): Option[Args] =
|
||||
var args = Args()
|
||||
var args = Args(debug: false)
|
||||
|
||||
var command = newSeq[string]()
|
||||
var parsingSandboxArgs = true
|
||||
var i = 1
|
||||
|
||||
while i <= paramCount():
|
||||
var arg = paramStr(i)
|
||||
|
||||
if arg == "--name":
|
||||
if arg == "--name" and parsingSandboxArgs:
|
||||
args.name = some(paramStr(i + 1))
|
||||
i += 2
|
||||
elif arg == "--profile":
|
||||
elif arg == "--profile" and parsingSandboxArgs:
|
||||
args.profile = some(paramStr(i + 1))
|
||||
i += 2
|
||||
elif arg == "--debug" and parsingSandboxArgs:
|
||||
args.debug = true
|
||||
i += 1
|
||||
else:
|
||||
echo arg
|
||||
parsingSandboxArgs = false
|
||||
command.add(arg)
|
||||
i += 1
|
||||
|
||||
|
||||
@@ -1,3 +1,4 @@
|
||||
import os
|
||||
import posix
|
||||
import sequtils
|
||||
|
||||
@@ -14,4 +15,4 @@ proc addMount*(call: var BwrapCall, mType: string, path: string): var BwrapCall
|
||||
call
|
||||
|
||||
proc exec*(call: var BwrapCall) =
|
||||
discard execv("/usr/bin/bwrap", allocCStringArray(@["bwrap"].concat(call.args)))
|
||||
discard execv("/usr/bin/env", allocCStringArray(@["/usr/bin/env", "bwrap"].concat(call.args)))
|
||||
|
||||
@@ -69,4 +69,12 @@ proc sandboxExec*(args: Args) =
|
||||
if config.allowdri.get(false):
|
||||
enableDri(call)
|
||||
|
||||
call.addArg(args.getCmd).exec()
|
||||
# resolve binary path outside of the sandbox
|
||||
var cmd = args.getCmd
|
||||
|
||||
echo cmd
|
||||
cmd[0] = findExe(cmd[0])
|
||||
|
||||
echo cmd
|
||||
|
||||
call.addArg(cmd).exec()
|
||||
|
||||
Reference in New Issue
Block a user