このスレッド に基づいて、LXDEセッションを考慮して/etc/acpi/powerbtn.sh
スクリプトを変更しました。
# getXuser gets the X user belonging to the display in $displaynum.
# If you want the foreground X user, use getXconsole!
getXuser() {
user=`pinky -fw | awk '{ if ($2 == ":'$displaynum'" || $(NF) == ":'$displaynum'" ) { print $1; exit; } }'`
if [ x"$user" = x"" ]; then
startx=`pgrep -n startx`
if [ x"$startx" != x"" ]; then
user=`ps -o user --no-headers $startx`
fi
fi
if [ x"$user" != x"" ]; then
userhome=`getent passwd $user | cut -d: -f6`
export XAUTHORITY=$userhome/.Xauthority
else
export XAUTHORITY=""
fi
export XUSER=$user
}
if [ -n $(pidof lxsession) ]; then
for x in /tmp/.X11-unix/*; do
displaynum=`echo $x | sed s#/tmp/.X11-unix/X##`
getXuser;
if [ x"$XAUTHORITY" != x"" ]; then
export DISPLAY=":$displaynum"
export _LXSESSION_PID=`pidof lxsession`
lxsession-logout
exit
fi
done
fi
# If all else failed, just initiate a plain shutdown.
/sbin/shutdown -h now "Power button pressed"
このスクリプトは、ユーザーとルートの両方としてターミナルで実行すると正常に機能しますが、ACPIDで実行すると機能しません。
スクリプトがACPIによってトリガーされる唯一のケースは、gnome-terminalでルートセッションを開いている場合です。
何が悪いのか分かりますか?何が起こっているのかを理解するのに役立つ、私が提供できる他の情報はありますか?
環境変数を手動で設定しようとしましたが、そうすると、スクリプトは、rootを使用してコマンドを初めて起動するまでしか機能しません。
システム情報:
Ubuntu 12.04.2 LTS
シングルユーザー
lXDE/Openboxを実行している
編集:
いくつかの診断を実行しましたが、ACPIDで実行すると、XUSERとXAUTHORITYの両方が空のままであることがわかりました。しかし、理由はわかりません。
そのため、デバッグ作業を行った後、最終的にpinky
によるユーザー検出まで問題を追跡することができました。奇妙な理由でpinky -fw
は、通常の状況ではユーザー表示を一覧表示しません。ルートセッションを開始した後でのみ、正しい表示を検出できます。
# DEBUG OUTPUT WITHOUT ROOT SESSION
##################
displaynum: 0 # correct
##################
pinkyfw: bob tty7 04:09 Aug 18 17:59
pinky: Login Name TTY Idle When Where
bob Bob tty7 04:09 Aug 18 17:59 # notice the missing
################## # information on display used
pinkytest: bob # testing a workaround
user: # empty because awk didin't find a match for ":0" in pinky -fw
##################
# DEBUG OUTPUT WITH ROOT SESSION
##################
displaynum: 0 # correct
##################
pinkyfw: bob tty7 04:04 Aug 18 17:59
bob pts/3 Aug 18 21:59 :0
pinky: Login Name TTY Idle When Where
bob Bob tty7 04:04 Aug 18 17:59
bob Bob pts/3 Aug 18 21:59 :0 # after starting a root session
##################
pinkytest: bob
user: bob # awk found a match for ":0"
##################
# DEBUG OUTPUT WITHOUT ROOT SESSION, WORKAROUND APPLIED
##################
displaynum: 0 # correct
##################
pinkyfw: bob tty7 04:09 Aug 18 17:59
pinky: Login Name TTY Idle When Where
bob Bob tty7 04:09 Aug 18 17:59
##################
pinkytest: bob
user: bob
##################
これは私が適用した回避策です:
getXuser() {
user=`pinky -fw | awk '{ if ($2 == ":'$displaynum'" || $(NF) == ":'$displaynum'" ) { print $1; exit; } }'`
if [ x"$user" = x"" ]; then
startx=`pgrep -n startx`
if [ x"$startx" != x"" ]; then
user=`ps -o user --no-headers $startx`
fi
fi
if [ x"$user" = x"" ]; then # lines added
user=$(pinky -fw | awk '{ print $1; exit; }') # lines added
fi # lines added
if [ x"$user" != x"" ]; then
userhome=`getent passwd $user | cut -d: -f6`
export XAUTHORITY=$userhome/.Xauthority
else
export XAUTHORITY=""
fi
export XUSER=$user
}
残念ながら、Linuxでのpinky
とユーザー管理については、この回避策がさらに問題を引き起こす可能性があるかどうかを判断するのに十分ではありません。ユーザー名をハードコーディングしてファイルに表示するよりも良いと思います(試しても機能しませんでした)。