Chciałbym uruchomić ekran, jeśli sesja Gnome jest zablokowana i odblokowana. Czy istnieje sposób, w jaki mogę to przechwycić i wykonać pewne czynności, gdy pulpit jest zablokowany lub odblokowany?
Chciałbym uruchomić ekran, jeśli sesja Gnome jest zablokowana i odblokowana. Czy istnieje sposób, w jaki mogę to przechwycić i wykonać pewne czynności, gdy pulpit jest zablokowany lub odblokowany?
Odpowiedzi:
Wygaszacz ekranu Gnome emituje pewne sygnały na dbus, gdy coś się dzieje.
Tutaj dokumentacja (z kilkoma przykładami).
Możesz napisać skrypt, który działa:
dbus-monitor --session "type='signal',interface='org.gnome.ScreenSaver'"
i to robi to, czego potrzebujesz w dowolnym momencie, dbus-monitor
drukuje wiersz o zablokowanym / odblokowanym ekranie.
Oto polecenie bash, aby zrobić to, czego potrzebujesz:
dbus-monitor --session "type='signal',interface='org.gnome.ScreenSaver'" |
while read x; do
case "$x" in
*"boolean true"*) echo SCREEN_LOCKED;;
*"boolean false"*) echo SCREEN_UNLOCKED;;
esac
done
Wystarczy wymienić echo SCREEN_LOCKED
i na echo SCREEN_UNLOCKED
to, czego potrzebujesz.
gnome-screensaver-command
już tam jest. Przechodząc -a
do gnome-screensaver-command
ciebie będzie zablokować ekran, podczas gdy będziesz go odblokować -d
. W każdym razie większość aplikacji gnome intensywnie korzysta z dbus, więc będziesz mógł robić z nim wiele niesamowitych rzeczy.
W Ubuntu 14.04 zdarzenie DBus dla odblokowania blokady ekranu zmieniło się, a nowy skrypt do powiązania z zablokowaniem i odblokowaniem ekranu wygląda następująco
dbus-monitor --session "type='signal',interface='com.ubuntu.Upstart0_6'" | \
(
while true; do
read X
if echo $X | grep "desktop-lock" &> /dev/null; then
SCREEN_LOCKED;
elif echo $X | grep "desktop-unlock" &> /dev/null; then
SCREEN_UNLOCKED;
fi
done
)
W dzisiejszych czasach myślę, że lepiej jest słuchać LockedHint
wiadomości zamiast wygaszacza ekranu. W ten sposób nie jesteś przywiązany do implementacji wygaszacza ekranu.
Oto prosty skrypt, aby to zrobić:
gdbus monitor -y -d org.freedesktop.login1 | grep LockedHint
Daje to:
/org/freedesktop/login1/session/_32: org.freedesktop.DBus.Properties.PropertiesChanged ('org.freedesktop.login1.Session', {'LockedHint': <true>}, @as [])
/org/freedesktop/login1/session/_32: org.freedesktop.DBus.Properties.PropertiesChanged ('org.freedesktop.login1.Session', {'LockedHint': <false>}, @as [])
Ubuntu 16.04: rozwiązanie ozma nie działało dla mnie, jednak to:
dbus-monitor --session "type=signal,interface=com.canonical.Unity.Session,member=Unlocked" |
while read MSG; do
LOCK_STAT=`echo $MSG | awk '{print $NF}'`
if [[ "$LOCK_STAT" == "member=Unlocked" ]]; then
echo "was unlocked"
fi
done
Rozwijanie już udzielonej odpowiedzi.
Jeśli spróbujesz uruchomić skrypt z wnętrza sesji screen
lub tmux
, najpierw musisz znaleźć poprawny $DBUS_SESSION_BUS_ADDRESS
i przekazać go jako argument dbus-monitor
zamiast --session
. Również jeśli uruchamiasz go jako demon, powinieneś upewnić się, że działa tylko jedna instancja na raz (np. Z plikiem blokady) i że skrypt czyści się po sobie trap
. Poniższy przykład będzie działał jako demon w większości obecnych środowisk Gnome (testowany na Ubuntu GNOME 16.04):
#!/bin/bash
set -o nounset # good practice, exit if unset variable used
pidfile=/tmp/lastauth.pid # lock file path
logfile=/tmp/lastauth.log # log file path
cleanup() { # when cleaning up:
rm -f $pidfile # * remove the lock file
trap - INT TERM EXIT # * reset kernel signal catching
exit # * stop the daemon
}
log() { # simple logging format example
echo $(date +%Y-%m-%d\ %X) -- $USER -- "$@" >> $logfile
}
if [ -e "$pidfile" ]; then # if lock file exists, exit
log $0 already running...
exit
fi
trap cleanup INT TERM EXIT # call cleanup() if e.g. killed
log daemon started...
echo $$ > $pidfile # create lock file with own PID inside
# usually `dbus-daemon` address can be guessed (`-s` returns 1st PID found)
export $(grep -z DBUS_SESSION_BUS_ADDRESS /proc/$(pidof -s dbus-daemon)/environ)
expr='type=signal,interface=org.gnome.ScreenSaver' # DBus watch expression here
dbus-monitor --address $DBUS_SESSION_BUS_ADDRESS "$expr" | \
while read line; do
case "$line" in
*"boolean true"*) log session locked;;
*"boolean false"*) log session unlocked;;
esac
done
cleanup # let's not leave orphaned lock file when the loop ends (e.g. dbus dies)
Jeśli to nie działa, prawdopodobnie dlatego, że:
Jeśli korzystasz z Kubuntu lub używasz KDE / Plazmy jako środowiska graficznego org.freedesktop.ScreenSaver
, musisz nasłuchiwać interfejsu , więc skrypt do odsłuchiwania tego zdarzenia wyglądałby następująco:
dbus-monitor --session "type='signal',interface='org.freedesktop.ScreenSaver'" |
while read x; do
case "$x" in
*"boolean true"*) echo SCREEN_LOCKED;;
*"boolean false"*) echo SCREEN_UNLOCKED;;
esac
done
Personalization>Notifications>Notifications>Screensaver
.
upstart
wsparcie zadania sesjidesktop-lock
i desktop-unlock
wydarzenia w start on
zwrotce. Wystarczy utworzyć zadanie .conf dla użytkownika z odpowiednimi wyzwalaczami i poleceniami do wywołania poniżej $XDG_CONFIG_HOME/upstart/
lub $HOME/.config/upstart
podobnego przykładu poniżej:
description "some job description"
start on desktop-lock
script
/path/to/your/executable
end script
to działało dla mnie w Ubuntu 16.04
dbus-monitor --session "type=signal,interface=org.gnome.ScreenSaver" |
while read MSG; do
LOCK_STAT=`echo $MSG | grep boolean | awk '{print $2}'`
if [[ "$LOCK_STAT" == "true" ]]; then
echo "was locked"
else
echo "was un-locked"
fi
done