Я хотів би запустити екран, якщо сеанс Gnome заблокований та розблокований. Чи є спосіб я перехопити це та виконати певні дії, коли робочий стіл заблокований чи розблокований?
Я хотів би запустити екран, якщо сеанс Gnome заблокований та розблокований. Чи є спосіб я перехопити це та виконати певні дії, коли робочий стіл заблокований чи розблокований?
Відповіді:
Заставка Gnome випромінює деякі сигнали на dbus, коли щось відбувається.
Ось документація (з деякими прикладами).
Ви можете написати сценарії, які виконуються:
dbus-monitor --session "type='signal',interface='org.gnome.ScreenSaver'"
і це робить те, що вам потрібно в будь-який час, dbus-monitor
друкує рядок про заблокований / розблокований екран.
Ось команда bash зробити те, що потрібно:
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
Просто замініть echo SCREEN_LOCKED
і echo SCREEN_UNLOCKED
тим, що вам потрібно.
gnome-screensaver-command
вже є. Перейшовши -a
до gnome-screensaver-command
вас, ви заблокуєте екран, при цьому розблокуйте його -d
. У будь-якому випадку більшість програм gnome широко використовують dbus, тому ви зможете зробити багато дивовижних речей з ним.
У ubuntu 14.04 подія DBus для розблокування екрана змінилася, і новий сценарій прив’язки до подій блокування екрана та розблокування виглядає наступним чином
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
)
Сьогодні я думаю, що краще слухати повідомлення, LockedHint
а не заставки. Таким чином, ви не прив’язані до реалізації заставки.
Ось простий сценарій для цього:
gdbus monitor -y -d org.freedesktop.login1 | grep LockedHint
Дає це:
/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: рішення ozma не працювало для мене, однак це:
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
Розгортання вже даної відповіді.
Якщо ви спробуєте запустити сценарій всередині screen
або tmux
сеансу, вам потрібно спочатку знайти правильний $DBUS_SESSION_BUS_ADDRESS
і передати його як аргумент dbus-monitor
замість --session
. Крім того, якщо ви запускаєте його як демон, ви повинні переконатися, що одночасно працює лише один екземпляр (наприклад, з файлом блокування), і що сценарій очищається після себе trap
. Наступний приклад буде працювати як демон у більшості поточних середовищ Gnome (тестований на 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)
Якщо це не працює для вас, можливо, це:
Якщо ви перебуваєте на Kubuntu або використовуєте KDE / Plasma в якості робочого середовища, вам потрібно прослухати інтерфейс org.freedesktop.ScreenSaver
, тому сценарій для прослуховування цієї події виглядатиме так:
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
Підтримка завдань сесіїdesktop-lock
та desktop-unlock
події в start on
строфі. Просто створіть роботу .conf для свого користувача з відповідними тригерами та командами для виклику під $XDG_CONFIG_HOME/upstart/
чи $HOME/.config/upstart
подібним прикладом нижче:
description "some job description"
start on desktop-lock
script
/path/to/your/executable
end script
це те, що працювало для мене в 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