Add lock on screensaver
This commit is contained in:
parent
55b3383fb9
commit
c0367b2c75
|
@ -6,3 +6,7 @@ func DisableDumpable() error {
|
||||||
// no additional dumping protection
|
// no additional dumping protection
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func MonitorLocks(onlock func) error {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -2,8 +2,58 @@
|
||||||
|
|
||||||
package processsecurity
|
package processsecurity
|
||||||
|
|
||||||
import "golang.org/x/sys/unix"
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/godbus/dbus/v5"
|
||||||
|
"golang.org/x/sys/unix"
|
||||||
|
)
|
||||||
|
|
||||||
func DisableDumpable() error {
|
func DisableDumpable() error {
|
||||||
return unix.Prctl(unix.PR_SET_DUMPABLE, 0, 0, 0, 0)
|
return unix.Prctl(unix.PR_SET_DUMPABLE, 0, 0, 0, 0)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func MonitorLocks(onlock func()) error {
|
||||||
|
bus, err := dbus.SessionBus()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = bus.AddMatchSignal(dbus.WithMatchInterface("org.gnome.ScreenSaver"))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
err = bus.AddMatchSignal(dbus.WithMatchMember("org.freedesktop.ScreenSaver"))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
signals := make(chan *dbus.Signal, 10)
|
||||||
|
bus.Signal(signals)
|
||||||
|
for {
|
||||||
|
select {
|
||||||
|
case message := <-signals:
|
||||||
|
fmt.Println("Message:", message)
|
||||||
|
fmt.Println("name ", message.Name)
|
||||||
|
if message.Name == "org.gnome.ScreenSaver.ActiveChanged" {
|
||||||
|
if len(message.Body) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
locked, err := message.Body[0].(bool)
|
||||||
|
if err || locked {
|
||||||
|
onlock()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if message.Name == "org.freedesktop.ScreenSaver.ActiveChanged" {
|
||||||
|
if len(message.Body) == 0 {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
locked, err := message.Body[0].(bool)
|
||||||
|
if err || locked {
|
||||||
|
onlock()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
|
@ -153,6 +153,15 @@ func StartUnixAgent(path string, runtimeConfig config.RuntimeConfig) error {
|
||||||
}
|
}
|
||||||
|
|
||||||
processsecurity.DisableDumpable()
|
processsecurity.DisableDumpable()
|
||||||
|
err = processsecurity.MonitorLocks(func() {
|
||||||
|
cfg.Lock()
|
||||||
|
vault.Clear()
|
||||||
|
vault.Keyring.Lock()
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("Could not monitor screensaver: %s", err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
if !runtimeConfig.WebsocketDisabled {
|
if !runtimeConfig.WebsocketDisabled {
|
||||||
go bitwarden.RunWebsocketDaemon(ctx, vault, &cfg)
|
go bitwarden.RunWebsocketDaemon(ctx, vault, &cfg)
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,6 +116,15 @@ func StartVirtualAgent(runtimeConfig config.RuntimeConfig) (chan []byte, chan []
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
processsecurity.DisableDumpable()
|
processsecurity.DisableDumpable()
|
||||||
|
err = processsecurity.MonitorLocks(func() {
|
||||||
|
cfg.Lock()
|
||||||
|
vault.Clear()
|
||||||
|
vault.Keyring.Lock()
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
log.Warn("Could not monitor screensaver: %s", err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
for {
|
for {
|
||||||
time.Sleep(TokenRefreshInterval)
|
time.Sleep(TokenRefreshInterval)
|
||||||
|
|
Loading…
Reference in New Issue