Added DBus interface
This commit is contained in:
parent
fdce6479b9
commit
541c5bedec
2 changed files with 78 additions and 4 deletions
66
DBus.py
Normal file
66
DBus.py
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
from gi.repository import GLib, Gio
|
||||||
|
|
||||||
|
from ctypes import CDLL, POINTER, Structure, CFUNCTYPE, pointer
|
||||||
|
from ctypes import c_void_p, c_char_p, c_bool
|
||||||
|
from ctypes.util import find_library
|
||||||
|
|
||||||
|
from functools import partial
|
||||||
|
|
||||||
|
|
||||||
|
dbus_xml = '''
|
||||||
|
<node>
|
||||||
|
<interface name="net.universe_factory.Pylock">
|
||||||
|
<method name="Lock"/>
|
||||||
|
</interface>
|
||||||
|
</node>
|
||||||
|
'''
|
||||||
|
|
||||||
|
gio = CDLL(find_library('gio-2.0'))
|
||||||
|
|
||||||
|
nodeInfo = Gio.DBusNodeInfo.new_for_xml(dbus_xml)
|
||||||
|
interfaceInfo = nodeInfo.lookup_interface('net.universe_factory.Pylock')
|
||||||
|
|
||||||
|
METHOD_CALL_FUNC = CFUNCTYPE(None, c_void_p, c_char_p, c_char_p, c_char_p, c_char_p, c_void_p, c_void_p, c_void_p)
|
||||||
|
GET_PROPERTY_FUNC = CFUNCTYPE(c_void_p, c_void_p, c_char_p, c_char_p, c_char_p, c_char_p, c_void_p, c_void_p)
|
||||||
|
SET_PROPERTY_FUNC = CFUNCTYPE(c_bool, c_void_p, c_char_p, c_char_p, c_char_p, c_char_p, c_void_p, c_void_p, c_void_p)
|
||||||
|
|
||||||
|
def method_call(locker, connection, sender, object_path, interface_name, method_name, parameters, invocation, user_data):
|
||||||
|
assert str(method_name, 'ascii') == 'Lock'
|
||||||
|
|
||||||
|
locker.lock()
|
||||||
|
gio.g_dbus_method_invocation_return_value(invocation, hash(GLib.Variant.new_tuple()))
|
||||||
|
|
||||||
|
@GET_PROPERTY_FUNC
|
||||||
|
def get_property(connection, sender, object_path, interface_name, property_name, error, user_data):
|
||||||
|
assert False
|
||||||
|
|
||||||
|
@SET_PROPERTY_FUNC
|
||||||
|
def set_property(connection, sender, object_path, interface_name, property_name, value, error, user_data):
|
||||||
|
assert False
|
||||||
|
|
||||||
|
class VTable(Structure):
|
||||||
|
_fields_ = [
|
||||||
|
("method_call", METHOD_CALL_FUNC),
|
||||||
|
("get_property", GET_PROPERTY_FUNC),
|
||||||
|
("set_property", SET_PROPERTY_FUNC)
|
||||||
|
]
|
||||||
|
|
||||||
|
def __init__(self, locker):
|
||||||
|
Structure.__init__(self)
|
||||||
|
self.method_call = METHOD_CALL_FUNC(partial(method_call, locker))
|
||||||
|
self.get_property = get_property
|
||||||
|
self.set_property = set_property
|
||||||
|
|
||||||
|
gio.g_dbus_connection_register_object.argtypes = [c_void_p, c_char_p, c_void_p, POINTER(VTable), c_void_p, c_void_p, c_void_p]
|
||||||
|
gio.g_dbus_method_invocation_return_value.argtypes = [c_void_p, c_void_p]
|
||||||
|
|
||||||
|
|
||||||
|
class DBus(object):
|
||||||
|
def __init__(self, locker):
|
||||||
|
self.vtable = VTable(locker)
|
||||||
|
|
||||||
|
Gio.bus_own_name(Gio.BusType.SESSION, 'net.universe_factory.Pylock', Gio.BusNameOwnerFlags.NONE, self.bus_aquired, None, None)
|
||||||
|
|
||||||
|
def bus_aquired(self, connection, name):
|
||||||
|
b = lambda s: bytes(s, 'ascii')
|
||||||
|
gio.g_dbus_connection_register_object(c_void_p(hash(connection)), b('/net/universe_factory/Pylock'), c_void_p(hash(interfaceInfo)), pointer(self.vtable), None, None, None)
|
16
pylock.py
16
pylock.py
|
@ -6,8 +6,9 @@ import os
|
||||||
import pwd
|
import pwd
|
||||||
import locale
|
import locale
|
||||||
|
|
||||||
from gi.repository import Gtk, Gdk
|
from gi.repository import Gtk, Gdk, Gio
|
||||||
|
|
||||||
|
from DBus import DBus
|
||||||
from Locker import Locker
|
from Locker import Locker
|
||||||
from LockWindow import LockWindow
|
from LockWindow import LockWindow
|
||||||
import pam
|
import pam
|
||||||
|
@ -18,7 +19,7 @@ def get_username():
|
||||||
|
|
||||||
|
|
||||||
theme = 'UzL-login'
|
theme = 'UzL-login'
|
||||||
timeout = 5
|
timeout = 500
|
||||||
logoutTimeout = 15
|
logoutTimeout = 15
|
||||||
username = get_username()
|
username = get_username()
|
||||||
|
|
||||||
|
@ -39,8 +40,11 @@ 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(username, timeLeft)
|
||||||
window.lock()
|
window.lock()
|
||||||
|
@ -51,9 +55,13 @@ def logout():
|
||||||
def updateTimeout(timeLeft):
|
def updateTimeout(timeLeft):
|
||||||
window.updateLockMessage(username, timeLeft)
|
window.updateLockMessage(username, timeLeft)
|
||||||
|
|
||||||
locker = Locker(timeout, lock, window.unlock, logoutTimeout, logout, updateTimeout)
|
|
||||||
pamAuth = pam.pam()
|
|
||||||
|
|
||||||
|
locker = Locker(timeout, lock, window.unlock, logoutTimeout, logout, updateTimeout)
|
||||||
|
|
||||||
|
dbus = DBus(locker)
|
||||||
|
|
||||||
|
|
||||||
|
pamAuth = pam.pam()
|
||||||
|
|
||||||
def tryUnlock(w, password):
|
def tryUnlock(w, password):
|
||||||
if pamAuth.authenticate(username, password):
|
if pamAuth.authenticate(username, password):
|
||||||
|
|
Reference in a new issue