2024-09-22 00:29:36 +09:00
|
|
|
package app
|
|
|
|
|
|
|
|
import (
|
|
|
|
"git.ophivana.moe/cat/fortify/dbus"
|
2024-10-11 02:01:03 +09:00
|
|
|
"git.ophivana.moe/cat/fortify/helper/bwrap"
|
2024-09-22 00:29:36 +09:00
|
|
|
"git.ophivana.moe/cat/fortify/internal/state"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Config is used to seal an *App
|
|
|
|
type Config struct {
|
|
|
|
// D-Bus application ID
|
|
|
|
ID string `json:"id"`
|
|
|
|
// username of the target user to switch to
|
|
|
|
User string `json:"user"`
|
|
|
|
// value passed through to the child process as its argv
|
|
|
|
Command []string `json:"command"`
|
|
|
|
// string representation of the child's launch method
|
|
|
|
Method string `json:"method"`
|
|
|
|
|
|
|
|
// child confinement configuration
|
|
|
|
Confinement ConfinementConfig `json:"confinement"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConfinementConfig defines fortified child's confinement
|
|
|
|
type ConfinementConfig struct {
|
2024-10-11 02:01:03 +09:00
|
|
|
// bwrap sandbox confinement configuration
|
2024-10-11 04:18:15 +09:00
|
|
|
Sandbox *SandboxConfig `json:"sandbox"`
|
2024-10-11 02:01:03 +09:00
|
|
|
|
2024-09-22 00:29:36 +09:00
|
|
|
// reference to a system D-Bus proxy configuration,
|
|
|
|
// nil value disables system bus proxy
|
|
|
|
SystemBus *dbus.Config `json:"system_bus,omitempty"`
|
|
|
|
// reference to a session D-Bus proxy configuration,
|
|
|
|
// nil value makes session bus proxy assume built-in defaults
|
|
|
|
SessionBus *dbus.Config `json:"session_bus,omitempty"`
|
|
|
|
|
|
|
|
// child capability enablements
|
|
|
|
Enablements state.Enablements `json:"enablements"`
|
|
|
|
}
|
2024-10-11 04:18:15 +09:00
|
|
|
|
|
|
|
// SandboxConfig describes resources made available to the sandbox.
|
|
|
|
type SandboxConfig struct {
|
|
|
|
// unix hostname within sandbox
|
|
|
|
Hostname string `json:"hostname,omitempty"`
|
|
|
|
// userns availability within sandbox
|
|
|
|
UserNS bool `json:"userns,omitempty"`
|
|
|
|
// share net namespace
|
|
|
|
Net bool `json:"net,omitempty"`
|
|
|
|
// do not run in new session
|
|
|
|
NoNewSession bool `json:"no_new_session,omitempty"`
|
|
|
|
// mediated access to wayland socket
|
|
|
|
Wayland bool `json:"wayland,omitempty"`
|
|
|
|
|
|
|
|
UID int `json:"uid,omitempty"`
|
|
|
|
GID int `json:"gid,omitempty"`
|
|
|
|
// final environment variables
|
|
|
|
Env map[string]string `json:"env"`
|
|
|
|
|
|
|
|
// paths made available within the sandbox
|
|
|
|
Bind [][2]string `json:"bind"`
|
|
|
|
// paths made available read-only within the sandbox
|
|
|
|
ROBind [][2]string `json:"ro-bind"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *SandboxConfig) Bwrap() *bwrap.Config {
|
|
|
|
if s == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
conf := &bwrap.Config{
|
|
|
|
Net: s.Net,
|
|
|
|
UserNS: s.UserNS,
|
|
|
|
Hostname: s.Hostname,
|
|
|
|
Clearenv: true,
|
|
|
|
SetEnv: s.Env,
|
|
|
|
Bind: s.Bind,
|
|
|
|
ROBind: s.ROBind,
|
|
|
|
Procfs: []string{"/proc"},
|
|
|
|
DevTmpfs: []string{"/dev"},
|
|
|
|
Mqueue: []string{"/dev/mqueue"},
|
|
|
|
NewSession: !s.NoNewSession,
|
|
|
|
DieWithParent: true,
|
|
|
|
}
|
|
|
|
if s.UID > 0 {
|
|
|
|
conf.UID = &s.UID
|
|
|
|
}
|
|
|
|
if s.GID > 0 {
|
|
|
|
conf.GID = &s.GID
|
|
|
|
}
|
|
|
|
|
|
|
|
return conf
|
|
|
|
}
|
2024-10-12 19:46:07 +09:00
|
|
|
|
|
|
|
// Template returns a fully populated instance of Config.
|
|
|
|
func Template() *Config {
|
|
|
|
return &Config{
|
|
|
|
ID: "org.chromium.Chromium",
|
|
|
|
User: "chronos",
|
|
|
|
Command: []string{
|
|
|
|
"chromium",
|
|
|
|
"--ignore-gpu-blocklist",
|
|
|
|
"--disable-smooth-scrolling",
|
|
|
|
"--enable-features=UseOzonePlatform",
|
|
|
|
"--ozone-platform=wayland",
|
|
|
|
},
|
|
|
|
Method: "sudo",
|
|
|
|
Confinement: ConfinementConfig{
|
|
|
|
Sandbox: &SandboxConfig{
|
|
|
|
Hostname: "localhost",
|
|
|
|
UserNS: true,
|
|
|
|
Net: true,
|
|
|
|
NoNewSession: true,
|
|
|
|
Wayland: false,
|
|
|
|
UID: 150,
|
|
|
|
GID: 101,
|
|
|
|
// example API credentials pulled from Google Chrome
|
|
|
|
// DO NOT USE THESE IN A REAL BROWSER
|
|
|
|
Env: map[string]string{
|
|
|
|
"GOOGLE_API_KEY": "AIzaSyBHDrl33hwRp4rMQY0ziRbj8K9LPA6vUCY",
|
|
|
|
"GOOGLE_DEFAULT_CLIENT_ID": "77185425430.apps.googleusercontent.com",
|
|
|
|
"GOOGLE_DEFAULT_CLIENT_SECRET": "OTJgUOQcT7lO7GsGZq2G4IlT",
|
|
|
|
},
|
|
|
|
Bind: [][2]string{{"/sdcard", "/sdcard"}, {"/var/tmp", "/var/tmp"}},
|
|
|
|
ROBind: [][2]string{{"/nix", "/nix"}},
|
|
|
|
},
|
|
|
|
SystemBus: &dbus.Config{
|
|
|
|
See: nil,
|
|
|
|
Talk: []string{"org.bluez", "org.freedesktop.Avahi", "org.freedesktop.UPower"},
|
|
|
|
Own: nil,
|
|
|
|
Call: nil,
|
|
|
|
Broadcast: nil,
|
|
|
|
Log: false,
|
|
|
|
Filter: true,
|
|
|
|
},
|
|
|
|
SessionBus: &dbus.Config{
|
|
|
|
See: nil,
|
|
|
|
Talk: []string{"org.freedesktop.Notifications", "org.freedesktop.FileManager1", "org.freedesktop.ScreenSaver",
|
|
|
|
"org.freedesktop.secrets", "org.kde.kwalletd5", "org.kde.kwalletd6", "org.gnome.SessionManager"},
|
|
|
|
Own: []string{"org.chromium.Chromium.*", "org.mpris.MediaPlayer2.org.chromium.Chromium.*",
|
|
|
|
"org.mpris.MediaPlayer2.chromium.*"},
|
|
|
|
Call: map[string]string{"org.freedesktop.portal.*": "*"},
|
|
|
|
Broadcast: map[string]string{"org.freedesktop.portal.*": "@/org/freedesktop/portal/*"},
|
|
|
|
Log: false,
|
|
|
|
Filter: true,
|
|
|
|
},
|
|
|
|
Enablements: state.EnableWayland.Mask() | state.EnableDBus.Mask() | state.EnablePulse.Mask(),
|
|
|
|
},
|
|
|
|
}
|
|
|
|
}
|