La respuesta de Acuario Power parece funcionar bastante bien. Aquí hay algunas adiciones que podría hacer a su solución.
Solo consultar estado de bloqueo
Si simplemente necesita una línea para consultar el estado de bloqueo, esto debería evaluarse como verdadero si está bloqueado y falso si está desbloqueado.
isLocked=$(gdbus call -e -d com.canonical.Unity -o /com/canonical/Unity/Session -m com.canonical.Unity.Session.IsLocked | grep -ioP "(true)|(false)")
Consultar el estado de bloqueo y el tiempo de seguimiento desde el último cambio de estado
Ahora, si necesita realizar un seguimiento de cuánto tiempo ha estado bloqueada la pantalla, es posible que desee adoptar un enfoque diferente.
#!/bin/bash
# To implement this, you can put this at the top of a bash script or you can run
# it the subshell in a separate process and pull the functions into other scripts.
# We need a file to keep track of variable inside subshell the file will contain
# two elements, the state and timestamp of time changed, separated by a tab.
# A timestamp of 0 indicates that the state has not changed since we started
# polling for changes and therefore, the time lapsed in the current state is
# unknown.
vars="/tmp/lock-state"
# start watching the screen lock state
(
# set the initial value for lock state
[ "$(gdbus call -e -d com.canonical.Unity -o /com/canonical/Unity/Session -m com.canonical.Unity.Session.IsLocked | grep -ioP "(true)|(false)")" == "true" ] && state="locked" || state="unlocked"
printf "%s\t%d" $state 0 > "$vars"
# start watching changes in state
gdbus monitor -e -d com.canonical.Unity -o /com/canonical/Unity/Session | while read line
do
state=$(grep -ioP "((un)?locked)" <<< "$line")
# If the line read denotes a change in state, save it to a file with timestamp for access outside this subshell
[ "$state" != "" ] && printf "%s\t%d" ${state,,} $(date +%s)> "$vars"
done
) & # don't wait for this subshell to finish
# Get the current state from the vars exported in the subshell
function getState {
echo $(cut -f1 "$vars")
}
# Get the time in seconds that has passed since the state last changed
function getSecondsElapsed {
if [ $(cut -f2 "$vars") -ne 0 ]; then
echo $(($(date +%s)-$(cut -f2 "$vars")))
else
echo "unknown"
fi
}
Esencialmente, este script observa los cambios en el estado de bloqueo de la pantalla. Cuando se producen cambios, la hora y el estado se vuelcan a un archivo. Puede leer este archivo manualmente si lo desea o utilizar las funciones que escribí.
Si desea una marca de tiempo en lugar de la cantidad de segundos, intente:
date -ud @$(getSecondsElapsed) | grep -oP "(\d{2}:){2}\d{2}"
No olvide el -u
interruptor que obliga al programa de fechas a ignorar su zona horaria.