Tengo la siguiente regla que llama a mi secuencia de comandos cuando conecto o desconecto mi ThinkPad:
# /lib/udev/rules.d/81-thinkpad-dock.rules
KERNEL=="dock.0", ATTR{docked}=="0", RUN+="/usr/bin/think-dock-hook off"
KERNEL=="dock.0", ATTR{docked}=="1", RUN+="/usr/bin/think-dock-hook on"
Ese es el guión que se llamará:
# /usr/bin/think-dock-hook
# Find the user who is currently logged in on the primary screen.
user="$(who -u | grep -F '(:0)' | head -n 1 | awk '{print $1}')"
su -c "bash -x /usr/bin/think-dock $setto" "$user" >> /root/think-dock.log 2>&1 &
Y el guión que luego se llama hace algo con xrandr.
Lo que pasa es que puedo ejecutar think-dock oncomo mi usuario ( mu) y funciona. Puedo sudo -iy corro think-dock-hook ony funciona también. Pero cuando dejo udevejecutarlo, solo aparece el siguiente error de xrandr:
# output of bash -x think-dock on
+ xrandr --output LVDS1 --auto
Can't open display
Ahora si llamo xrandrdesde mi sudo -ishell, obtengo:
No protocol specified
No protocol specified
Can't open display :0
Sin embargo, si lo hago su -c xrandr mudesde mi sudo -ishell, obtengo el resultado esperado.
Así que no entiendo realmente, el script llamado desde udevfalla.

grep -F '(:0)'debería sergrep -F '(:0.0)'; También intente pegarseDISPLAY=:0.0delante de/usr/bin/think-dockDISPLAYparece bueno Miswhopantallas(:0)aunque. Así que no creo que grep sería mejor así.DISPLAYfrentebash, parece funcionar ahora. ¡Gracias!whotenía0.0, pero de todos modos. Como funcionó, agregaré laDISPLAYparte como respuesta; por favor aceptalo. ¡Gracias!Respuestas:
DISPLAYvariable de entornoroot(que udev se ejecuta como) no tiene unDISPLAYconjunto predeterminado ; incluso si lo hizo,su -cno preserva el medio ambiente por defectoAsí que pásalo explícitamente a bash, y eso debería resolver tu problema, por ejemplo:
fuente