xautolock: como desbloquear automaticamente a atividade do usuário?

4

Eu preciso executar um script após um período de inatividade do usuário. Para isso eu uso o programa maravilhoso xautolock .

Agora, também preciso executar outro script quando a atividade for retomada (por exemplo, o mouse é movido ou uma tecla é pressionada).

Como faço isso? Qualquer tipo de anti-xautolock? Um xautoUNlock?

Ou, talvez, qualquer outra maneira fácil de captar o momento em que a "ociosidade" pára?

    
por Alexander Shcheblikin 14.11.2013 / 02:28

1 resposta

2

Eu escrevi o seguinte script para verificar se há inatividade e atualizar o status ocioso da sessão com systemd-logind de acordo. (Normalmente isso seria feito pelo gerenciador de sessão, mas eu não executo um.) Isso permite que o sistema coloque o sistema em suspensão automaticamente (com base em IdleAction e IdleActionSec em /etc/systemd/logind.conf ), considerando ambos os X11 e ssh logins ao determinar se o sistema está ocioso. Baseado parcialmente em this e este .

Você pode modificar a classe login1_idle para executar os scripts desejados.

#!/usr/bin/python

import ctypes
import os
import dbus
import time

# Timing parameters, in s
idle_threshold = 60 # Amount of idle time required to consider things truly idle
check_interval = 50 # How often to check the X server idle indication

class login1_idle:
  def __init__(self):
    self.flag = 0
    bus = dbus.SystemBus()
    seat = bus.get_object('org.freedesktop.login1',
                          '/org/freedesktop/login1/seat/'
                           + os.environ['XDG_SEAT'])
    active_session = seat.Get('org.freedesktop.login1.Seat',
                              'ActiveSession',
                              dbus_interface='org.freedesktop.DBus.Properties')
    session_obj_path = active_session[1]
    self.session = bus.get_object('org.freedesktop.login1', session_obj_path);

  def on_busy(self):
    self.flag = 0
    self.session.SetIdleHint(False,
                             dbus_interface='org.freedesktop.login1.Session')

  def on_idle(self):
    self.flag = 1
    self.session.SetIdleHint(True,
                             dbus_interface='org.freedesktop.login1.Session')

class XScreenSaverInfo(ctypes.Structure):
  """ typedef struct { ... } XScreenSaverInfo; """
  _fields_ = [('window',      ctypes.c_ulong), # screen saver window
              ('state',       ctypes.c_int),   # off,on,disabled
              ('kind',        ctypes.c_int),   # blanked,internal,external
              ('since',       ctypes.c_ulong), # milliseconds
              ('idle',        ctypes.c_ulong), # milliseconds
              ('event_mask',  ctypes.c_ulong)] # events

xlib = ctypes.cdll.LoadLibrary('libX11.so')
display = xlib.XOpenDisplay(os.environ['DISPLAY'])
xss = ctypes.cdll.LoadLibrary('libXss.so.1')
xss.XScreenSaverAllocInfo.restype = ctypes.POINTER(XScreenSaverInfo)
xssinfo = xss.XScreenSaverAllocInfo()

idle = login1_idle()

while True:
  xss.XScreenSaverQueryInfo(display, xlib.XDefaultRootWindow(display), xssinfo)

  #print "idle: %d ms" % xssinfo.contents.idle

  if xssinfo.contents.idle > idle_threshold * 1000 and not idle.flag:
    print time.strftime('%c') + " doing on_idle"
    idle.on_idle()

  elif xssinfo.contents.idle < idle_threshold * 1000 and idle.flag:
    print time.strftime('%c') + " doing on_busy"
    idle.on_busy()

  #print idle.session.Get('org.freedesktop.login1.Session',
  #                       'IdleHint',
  #                       dbus_interface='org.freedesktop.DBus.Properties')

  time.sleep(check_interval)

Outra questão semelhante com uma implementação do C / bash é Executa um comando quando o sistema está ocioso e quando está ativo novamente .

    
por 14.07.2014 / 00:26