Allow configuring pylock with command line options
This commit is contained in:
parent
a8e8bacdca
commit
86ab62a5e6
2 changed files with 37 additions and 15 deletions
|
@ -4,7 +4,7 @@ import Idle
|
||||||
|
|
||||||
|
|
||||||
class Locker(object):
|
class Locker(object):
|
||||||
def __init__(self, lockTimeout, doLock, doUnlock, logoutTimeout = 0, doLogout = None, updateLogoutTimeout = None):
|
def __init__(self, lockTimeout, doLock, doUnlock, logoutTimeout = None, doLogout = None, updateLogoutTimeout = None):
|
||||||
self.locked = False
|
self.locked = False
|
||||||
self.lockTimeout = lockTimeout
|
self.lockTimeout = lockTimeout
|
||||||
self.logoutTimeout = logoutTimeout
|
self.logoutTimeout = logoutTimeout
|
||||||
|
@ -13,7 +13,10 @@ class Locker(object):
|
||||||
self.doLogout = doLogout
|
self.doLogout = doLogout
|
||||||
self.updateLogoutTimeout = updateLogoutTimeout
|
self.updateLogoutTimeout = updateLogoutTimeout
|
||||||
|
|
||||||
GLib.timeout_add_seconds(1, self._checkLock)
|
if self.lockTimeout > 0:
|
||||||
|
GLib.timeout_add_seconds(1, self._checkLock)
|
||||||
|
else:
|
||||||
|
GLib.idle_add(self.lock)
|
||||||
|
|
||||||
def _checkLock(self):
|
def _checkLock(self):
|
||||||
if self.locked:
|
if self.locked:
|
||||||
|
|
45
pylock.py
45
pylock.py
|
@ -5,6 +5,7 @@ import sys
|
||||||
import os
|
import os
|
||||||
import pwd
|
import pwd
|
||||||
import locale
|
import locale
|
||||||
|
import argparse
|
||||||
|
|
||||||
from gi.repository import Gtk, Gdk, Gio
|
from gi.repository import Gtk, Gdk, Gio
|
||||||
|
|
||||||
|
@ -14,14 +15,23 @@ from LockWindow import LockWindow
|
||||||
import pam
|
import pam
|
||||||
|
|
||||||
|
|
||||||
|
_ = locale.gettext
|
||||||
|
|
||||||
|
|
||||||
def get_username():
|
def get_username():
|
||||||
return pwd.getpwuid(os.getuid())[0]
|
return pwd.getpwuid(os.getuid())[0]
|
||||||
|
|
||||||
|
|
||||||
theme = 'UzL-login'
|
theme = 'UzL-login'
|
||||||
timeout = 500
|
|
||||||
logoutTimeout = 15
|
|
||||||
username = get_username()
|
parser = argparse.ArgumentParser(prog='pylock', description=_('GTK-based screen locker.'))
|
||||||
|
parser.add_argument('-t', '--timeout', type=int, default=0, help=_('Start in daemon mode that will automatically activate after a given time of inactivity.'))
|
||||||
|
parser.add_argument('-l', '--logout', type=int, default=0, help=_('Allow to logout the current user after a given time.'))
|
||||||
|
parser.add_argument('-c', '--logout-command', help=_('Specifies the command to be called to log out a user.'))
|
||||||
|
parser.add_argument('-u', '--username', default=get_username(), help=_('Set the name of the user that is able to unlock the screen.'))
|
||||||
|
|
||||||
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
def handler(signum, frame):
|
def handler(signum, frame):
|
||||||
|
@ -34,38 +44,47 @@ signal.signal(signal.SIGQUIT, handler)
|
||||||
|
|
||||||
|
|
||||||
locale.setlocale(locale.LC_ALL, '')
|
locale.setlocale(locale.LC_ALL, '')
|
||||||
locale.bindtextdomain('pylock', '/home/neoraider/Devel/Python/pylock/locale')
|
|
||||||
locale.textdomain('pylock')
|
locale.textdomain('pylock')
|
||||||
|
|
||||||
Gtk.Settings.get_default().set_property('gtk-theme-name', theme)
|
Gtk.Settings.get_default().set_property('gtk-theme-name', theme)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
window = LockWindow()
|
window = LockWindow()
|
||||||
|
|
||||||
|
|
||||||
def lock(timeLeft):
|
def lock(timeLeft):
|
||||||
window.updateLockMessage(username, timeLeft)
|
window.updateLockMessage(args.username, timeLeft)
|
||||||
window.lock()
|
window.lock()
|
||||||
|
|
||||||
def logout():
|
def logout():
|
||||||
exit()
|
try:
|
||||||
|
os.system(args.logout_command)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
window.reset()
|
||||||
|
|
||||||
def updateTimeout(timeLeft):
|
def updateTimeout(timeLeft):
|
||||||
window.updateLockMessage(username, timeLeft)
|
window.updateLockMessage(args.username, timeLeft)
|
||||||
|
|
||||||
|
if args.logout_command is None:
|
||||||
|
locker = Locker(args.timeout, lock, window.unlock)
|
||||||
|
else:
|
||||||
|
locker = Locker(args.timeout, lock, window.unlock, args.logout, logout, updateTimeout)
|
||||||
|
|
||||||
|
|
||||||
locker = Locker(timeout, lock, window.unlock, logoutTimeout, logout, updateTimeout)
|
if args.timeout != 0:
|
||||||
|
dbus = DBus(locker)
|
||||||
dbus = DBus(locker)
|
|
||||||
|
|
||||||
|
|
||||||
pamAuth = pam.pam()
|
pamAuth = pam.pam()
|
||||||
|
|
||||||
def tryUnlock(w, password):
|
def tryUnlock(w, password):
|
||||||
if pamAuth.authenticate(username, password):
|
if pamAuth.authenticate(args.username, password):
|
||||||
locker.unlock()
|
locker.unlock()
|
||||||
|
|
||||||
|
if args.timeout == 0:
|
||||||
|
Gtk.main_quit()
|
||||||
else:
|
else:
|
||||||
window.reset()
|
window.reset()
|
||||||
window.setAuthMessage(pamAuth.reason)
|
window.setAuthMessage(pamAuth.reason)
|
||||||
|
|
Reference in a new issue