9 from gi.repository import GLib
10 from gi.repository import LightDM
12 display = os.getenv ('DISPLAY');
13 if display is not None:
14 if display.startswith (':'):
15 greeter_id = 'GREETER-X-%s' % display[1:]
17 greeter_id = 'GREETER-X-%s' % display
19 greeter_id = 'GREETER-?'
21 loop = GLib.MainLoop ()
23 def sigterm_cb (data):
24 status_notify ('%s TERMINATE SIGNAL=%d' % (greeter_id, signal.SIGTERM))
26 GLib.unix_signal_add (GLib.PRIORITY_DEFAULT, signal.SIGTERM, sigterm_cb, None)
30 def status_notify (message):
31 if status_socket is not None:
32 status_socket.send (struct.pack ('i', len (message)) + message)
34 sys.stderr.write ('%s\n' % message)
36 def request_cb (channel, condition):
37 length = status_socket.recv (4)
42 (l,) = struct.unpack ('i', length)
43 request = status_socket.recv (l)
45 r = '%s AUTHENTICATE' % greeter_id
47 greeter.authenticate (None)
49 r = '%s AUTHENTICATE USERNAME=' % greeter_id
50 if request.startswith (r):
51 greeter.authenticate (request[len(r):])
53 r = '%s AUTHENTICATE-GUEST' % greeter_id
55 greeter.authenticate_as_guest ()
57 r = '%s AUTHENTICATE-AUTOLOGIN' % greeter_id
59 greeter.authenticate_autologin ()
61 r = '%s AUTHENTICATE-REMOTE SESSION=' % greeter_id
62 if request.startswith (r):
63 greeter.authenticate_remote (request[len(r):], None)
65 r = '%s RESPOND TEXT=\"' % greeter_id
66 if request.startswith (r):
67 greeter.respond (request[len (r):-1])
69 r = '%s CANCEL-AUTHENTICATION' % greeter_id
71 greeter.cancel_authentication ()
73 r = '%s START-SESSION' % greeter_id
75 if not greeter.start_session_sync (None):
76 status_notify ('%s SESSION-FAILED' % greeter_id)
78 r = '%s START-SESSION SESSION=' % greeter_id
79 if request.startswith (r):
80 if not greeter.start_session_sync (request[len(r):]):
81 status_notify ('%s SESSION-FAILED' % greeter_id)
83 r = '%s LOG-USER-LIST-LENGTH' % greeter_id
85 status_notify ('%s LOG-USER-LIST-LENGTH N=%d' % (greeter_id, LightDM.UserList.get_instance ().get_length ()))
87 r = '%s LOG-USER USERNAME=' % greeter_id
88 if request.startswith (r):
89 username = request[len(r):]
90 user = LightDM.UserList.get_instance ().get_user_by_name (username)
91 status_notify ('%s LOG-USER USERNAME=%s' % (greeter_id, user.get_name ()))
93 r = '%s LOG-USER-LIST' % greeter_id
95 users = LightDM.UserList.get_instance ().get_users ();
97 status_notify ('%s LOG-USER USERNAME=%s' % (greeter_id, user.get_name ()))
99 r = '%s LOG-LAYOUT' % greeter_id
101 layout = LightDM.get_layout ().get_name ()
102 status_notify ('%s LOG-LAYOUT LAYOUT=%s' % (greeter_id, layout))
104 r = '%s LOG-LAYOUT USERNAME=' % greeter_id
105 if request.startswith (r):
106 username = request[len(r):]
107 user = LightDM.UserList.get_instance ().get_user_by_name (username)
108 layout = user.get_layout ()
111 status_notify ('%s LOG-LAYOUT USERNAME=%s LAYOUT=%s' % (greeter_id, username, layout))
113 r = '%s LOG-LANGUAGE USERNAME=' % greeter_id
114 if request.startswith (r):
115 username = request[len(r):]
116 user = LightDM.UserList.get_instance ().get_user_by_name (username)
117 language = user.get_language ()
120 status_notify ('%s LOG-LANGUAGE USERNAME=%s LANGUAGE=%s' % (greeter_id, username, language))
122 r = '%s GET-CAN-SUSPEND' % greeter_id
124 if LightDM.get_can_suspend ():
128 status_notify ('%s CAN-SUSPEND ALLOWED=%s' % (greeter_id, allowed))
130 r = '%s SUSPEND' % greeter_id
135 status_notify ('%s FAIL-SUSPEND' % greeter_id)
137 r = '%s GET-CAN-HIBERNATE' % greeter_id
139 if LightDM.get_can_hibernate ():
143 status_notify ('%s CAN-HIBERNATE ALLOWED=%s' % (greeter_id, allowed))
145 r = '%s HIBERNATE' % greeter_id
150 status_notify ('%s FAIL-HIBERNATE' % greeter_id)
152 r = '%s GET-CAN-RESTART' % greeter_id
154 if LightDM.get_can_restart ():
158 status_notify ('%s CAN-RESTART ALLOWED=%s' % (greeter_id, allowed))
160 r = '%s RESTART' % greeter_id
165 status_notify ('%s FAIL-RESTART' % greeter_id)
167 r = '%s GET-CAN-SHUTDOWN' % greeter_id
169 if LightDM.get_can_shutdown ():
173 status_notify ('%s CAN-SHUTDOWN ALLOWED=%s' % (greeter_id, allowed))
175 r = '%s SHUTDOWN' % greeter_id
180 status_notify ('%s FAIL-SHUTDOWN' % greeter_id)
184 path = os.getenv ('LIGHTDM_TEST_ROOT') + '/.s'
185 status_socket = socket.socket (socket.AF_UNIX, socket.SOCK_STREAM)
186 status_socket.connect (path)
187 GLib.io_add_watch (status_socket.fileno (), GLib.IO_IN | GLib.IO_HUP, request_cb)
189 status_notify ('%s START' % greeter_id)
191 config = GLib.KeyFile ()
192 config.load_from_file (os.getenv ('LIGHTDM_TEST_ROOT') + '/script', GLib.KeyFileFlags.NONE)
194 # NOTE: There don't seem to be any good X bindings so we have to mock up our own...
195 if display is not None:
196 (host, display_number) = display.split (':')
198 x_socket = socket.socket (socket.AF_UNIX, socket.SOCK_STREAM)
199 x_socket.connect (os.getenv ('LIGHTDM_TEST_ROOT') + '/.x' + display)
201 x_socket = socket.socket (socket.AF_INET, socket.SOCK_STREAM)
202 x_socket.connect ((host, 6000 + int (display_number)))
204 status_notify ('%s CONNECT-XSERVER' % (greeter_id))
206 def show_message_cb (greeter, text, type):
207 status_notify ('%s SHOW-MESSAGE TEXT=\"%s\"' % (greeter_id, text))
209 def show_prompt_cb (greeter, text, type):
210 status_notify ('%s SHOW-PROMPT TEXT=\"%s\"' % (greeter_id, text))
212 def authentication_complete_cb (greeter):
213 if greeter.get_is_authenticated ():
214 is_authenticated = 'TRUE'
216 is_authenticated = 'FALSE'
217 if greeter.get_authentication_user () is not None:
218 status_notify ('%s AUTHENTICATION-COMPLETE USERNAME=%s AUTHENTICATED=%s' % (greeter_id, greeter.get_authentication_user (), is_authenticated))
220 status_notify ('%s AUTHENTICATION-COMPLETE AUTHENTICATED=%s' % (greeter_id, is_authenticated))
222 def autologin_timer_expired_cb (greeter):
223 status_notify ('%s AUTOLOGIN-TIMER-EXPIRED' % greeter_id)
225 greeter = LightDM.Greeter ()
226 greeter.connect ('show-message', show_message_cb)
227 greeter.connect ('show-prompt', show_prompt_cb)
228 greeter.connect ('authentication-complete', authentication_complete_cb)
229 greeter.connect ('autologin-timer-expired', autologin_timer_expired_cb)
231 def user_added_cb (user_list, user):
232 status_notify ('%s USER-ADDED USERNAME=%s' % (greeter_id, user.get_name ()))
233 def user_removed_cb (user_list, user):
234 status_notify ('%s USER-REMOVED USERNAME=%s' % (greeter_id, user.get_name ()))
235 log_user_changes = False
237 log_user_changes = config.get_boolean ('test-greeter-config', 'log-user-changes')
241 LightDM.UserList.get_instance ().connect ('user-added', user_added_cb)
242 LightDM.UserList.get_instance ().connect ('user-removed', user_removed_cb)
244 status_notify ('%s CONNECT-TO-DAEMON' % greeter_id)
245 if not greeter.connect_sync ():
246 status_notify ('%s FAIL-CONNECT-DAEMON' % greeter_id)
249 status_notify ('%s CONNECTED-TO-DAEMON' % greeter_id)
251 if greeter.get_select_user_hint () is not None:
252 status_notify ('%s SELECT-USER-HINT USERNAME=%s' % (greeter_id, greeter.get_select_user_hint ()))
253 if greeter.get_select_guest_hint ():
254 status_notify ('%s SELECT-GUEST-HINT' % greeter_id)
255 if greeter.get_lock_hint ():
256 status_notify ('%s LOCK-HINT' % greeter_id)
257 if not greeter.get_has_guest_account_hint ():
258 status_notify ('%s HAS-GUEST-ACCOUNT-HINT=FALSE' % greeter_id)
259 if greeter.get_hide_users_hint ():
260 status_notify ('%s HIDE-USERS-HINT' % greeter_id)
261 if greeter.get_show_manual_login_hint ():
262 status_notify ('%s SHOW-MANUAL-LOGIN-HINT' % greeter_id)
263 if not greeter.get_show_remote_login_hint ():
264 status_notify ('%s SHOW-REMOTE-LOGIN-HINT=FALSE' % greeter_id)