Bad workaround for local appimage daemon

This commit is contained in:
dav 2024-08-14 15:38:52 -07:00 committed by David Zhong
parent 9a262a1243
commit 37fb4f4974

View file

@ -68,27 +68,32 @@ impl AsyncComponent for DaemonGroup {
) {
match msg {
DaemonGroupMsg::LaunchLocal => {
// TODO: Handle error condition
const BURROW_LOCAL_DAEMON_PATH: &str = "/tmp/burrow-detached-daemon";
let burrow_original_bin = std::env::vars()
.find(|(k, _)| k == "APPDIR")
.map(|(_, v)| v + "/usr/bin/burrow")
.unwrap_or("/usr/bin/burrow".to_owned());
Command::new("cp")
.arg(&burrow_original_bin)
.arg(BURROW_LOCAL_DAEMON_PATH)
.output()
.unwrap();
let mut burrow_bin =
String::from_utf8(Command::new("mktemp").output().unwrap().stdout).unwrap();
burrow_bin.pop();
let privileged_spawn_script = format!(
r#"TEMP=$(mktemp -p /root)
cp {} $TEMP
chmod +x $TEMP
setcap CAP_NET_BIND_SERVICE,CAP_NET_ADMIN+eip $TEMP
mv $TEMP /tmp/burrow-detached-daemon"#,
burrow_original_bin
r#"chmod +x {}
setcap CAP_NET_BIND_SERVICE,CAP_NET_ADMIN+eip {}"#,
BURROW_LOCAL_DAEMON_PATH, BURROW_LOCAL_DAEMON_PATH
)
.replace('\n', "&&");
// TODO: Handle error condition
Command::new("pkexec")
.arg("sh")
.arg("-c")
@ -97,7 +102,7 @@ mv $TEMP /tmp/burrow-detached-daemon"#,
.output()
.unwrap();
Command::new("/tmp/burrow-detached-daemon")
Command::new(BURROW_LOCAL_DAEMON_PATH)
.env("RUST_LOG", "debug")
.arg("daemon")
.spawn()