helper: separate helper args fd builder from dbus

This method of passing arguments is used in bubblewrap as well as other tools, this commit separates the argument builder/writer to the helper package and generalise it as an interface.

Signed-off-by: Ophestra Umiker <cat@ophivana.moe>
This commit is contained in:
2024-09-24 16:11:08 +09:00
parent 1cb90c0840
commit 000607da5f
4 changed files with 114 additions and 13 deletions

View File

@@ -4,8 +4,9 @@ import (
"errors"
"os"
"os/exec"
"strings"
"sync"
"git.ophivana.moe/cat/fortify/helper"
)
// Proxy holds references to a xdg-dbus-proxy process, and should never be copied.
@@ -24,7 +25,7 @@ type Proxy struct {
read *chan error
ready *chan bool
seal *string
seal helper.Args
lock sync.RWMutex
}
@@ -41,7 +42,7 @@ func (p *Proxy) String() string {
}
if p.seal != nil {
return *p.seal
return p.seal.String()
}
return "(unsealed dbus proxy)"
@@ -60,21 +61,20 @@ func (p *Proxy) Seal(session, system *Config) error {
return errors.New("no configuration to seal")
}
seal := strings.Builder{}
seal := helper.NewArgs()
var args []string
if session != nil {
if err := session.buildSeal(&seal, p.session); err != nil {
return err
}
args = append(args, session.Args(p.session)...)
}
if system != nil {
if err := system.buildSeal(&seal, p.system); err != nil {
return err
}
args = append(args, system.Args(p.system)...)
}
if err := seal.Seal(args); err != nil {
return err
}
v := seal.String()
p.seal = &v
p.seal = seal
return nil
}

View File

@@ -43,7 +43,7 @@ func (p *Proxy) Start(ready *chan bool) error {
statsP, argsP := p.statP[0], p.argsP[1]
if _, err := argsP.Write([]byte(*p.seal)); err != nil {
if _, err := p.seal.WriteTo(argsP); err != nil {
if err1 := p.cmd.Process.Kill(); err1 != nil {
panic(err1)
}