]> rtime.felk.cvut.cz Git - sojka/lightdm.git/blob - tests/src/test-python-greeter
First pass at reset support
[sojka/lightdm.git] / tests / src / test-python-greeter
1 #!/usr/bin/python
2
3 import sys
4 import os
5 import struct
6 import socket
7 import subprocess
8 import signal
9 from gi.repository import GLib
10 from gi.repository import LightDM
11
12 display = os.getenv ('DISPLAY');
13 xdg_seat = os.getenv ('XDG_SEAT');
14 xdg_vtnr = os.getenv ('XDG_VTNR');
15 xdg_session_cookie = os.getenv ('XDG_SESSION_COOKIE');
16 xdg_session_class = os.getenv ('XDG_SESSION_CLASS');
17 if display is not None:
18     if display.startswith (':'):
19         greeter_id = 'GREETER-X-%s' % display[1:]
20     else:
21         greeter_id = 'GREETER-X-%s' % display
22 else:
23     greeter_id = 'GREETER-?'
24
25 loop = GLib.MainLoop ()
26
27 def sigterm_cb (data):
28     status_notify ('%s TERMINATE SIGNAL=%d' % (greeter_id, signal.SIGTERM))
29     loop.quit ()
30 GLib.unix_signal_add (GLib.PRIORITY_DEFAULT, signal.SIGTERM, sigterm_cb, None)
31
32 status_socket = None
33
34 def status_notify (message):
35     if status_socket is not None:
36         status_socket.send (struct.pack ('i', len (message)) + message)
37     else:
38         sys.stderr.write ('%s\n' % message)
39
40 def request_cb (channel, condition):
41     length = status_socket.recv (4)
42     if len (length) == 0:
43         loop.quit ();
44         return False
45     if len (length) > 0:
46         (l,) = struct.unpack ('i', length)
47         request = status_socket.recv (l)
48
49     r = '%s AUTHENTICATE' % greeter_id
50     if request == r:
51         greeter.authenticate (None)
52
53     r = '%s AUTHENTICATE USERNAME=' % greeter_id
54     if request.startswith (r):
55         greeter.authenticate (request[len(r):])
56
57     r = '%s AUTHENTICATE-GUEST' % greeter_id
58     if request == r:
59         greeter.authenticate_as_guest ()
60
61     r = '%s AUTHENTICATE-AUTOLOGIN' % greeter_id
62     if request == r:
63         greeter.authenticate_autologin ()
64
65     r = '%s AUTHENTICATE-REMOTE SESSION=' % greeter_id
66     if request.startswith (r):
67         greeter.authenticate_remote (request[len(r):], None)
68
69     r = '%s RESPOND TEXT=\"' % greeter_id
70     if request.startswith (r):
71         greeter.respond (request[len (r):-1])
72
73     r = '%s CANCEL-AUTHENTICATION' % greeter_id
74     if request == r:
75         greeter.cancel_authentication ()
76
77     r = '%s START-SESSION' % greeter_id
78     if request == r:
79         if not greeter.start_session_sync (None):
80             status_notify ('%s SESSION-FAILED' % greeter_id)
81
82     r = '%s START-SESSION SESSION=' % greeter_id
83     if request.startswith (r):
84         if not greeter.start_session_sync (request[len(r):]):
85             status_notify ('%s SESSION-FAILED' % greeter_id)
86
87     r = '%s LOG-USER-LIST-LENGTH' % greeter_id
88     if request == r:
89         status_notify ('%s LOG-USER-LIST-LENGTH N=%d' % (greeter_id, LightDM.UserList.get_instance ().get_length ()))
90
91     r = '%s LOG-USER USERNAME=' % greeter_id
92     if request.startswith (r):
93         username = request[len(r):]
94         user = LightDM.UserList.get_instance ().get_user_by_name (username)
95         status_notify ('%s LOG-USER USERNAME=%s' % (greeter_id, user.get_name ()))
96
97     r = '%s LOG-USER-LIST' % greeter_id
98     if request == r:
99         users = LightDM.UserList.get_instance ().get_users ();
100         for user in users:
101             status_notify ('%s LOG-USER USERNAME=%s' % (greeter_id, user.get_name ()))
102
103     r = '%s LOG-LAYOUT' % greeter_id
104     if request == r:
105         layout = LightDM.get_layout ().get_name ()
106         status_notify ('%s LOG-LAYOUT LAYOUT=%s' % (greeter_id, layout))
107
108     r = '%s LOG-LAYOUT USERNAME=' % greeter_id
109     if request.startswith (r):
110         username = request[len(r):]
111         user = LightDM.UserList.get_instance ().get_user_by_name (username)
112         layout = user.get_layout ()
113         if layout is None:
114             layout = ''
115         status_notify ('%s LOG-LAYOUT USERNAME=%s LAYOUT=%s' % (greeter_id, username, layout))
116
117     r = '%s LOG-LANGUAGE USERNAME=' % greeter_id
118     if request.startswith (r):
119         username = request[len(r):]
120         user = LightDM.UserList.get_instance ().get_user_by_name (username)
121         language = user.get_language ()
122         if language is None:
123             language = ''
124         status_notify ('%s LOG-LANGUAGE USERNAME=%s LANGUAGE=%s' % (greeter_id, username, language))
125
126     r = '%s GET-CAN-SUSPEND' % greeter_id
127     if request == r:
128         if LightDM.get_can_suspend ():
129             allowed = "TRUE"
130         else:
131             allowed = "FALSE"
132         status_notify ('%s CAN-SUSPEND ALLOWED=%s' % (greeter_id, allowed))
133
134     r = '%s SUSPEND' % greeter_id
135     if request == r:
136         try:
137             LightDM.suspend ()
138         except:
139             status_notify ('%s FAIL-SUSPEND' % greeter_id)
140
141     r = '%s GET-CAN-HIBERNATE' % greeter_id
142     if request == r:
143         if LightDM.get_can_hibernate ():
144             allowed = "TRUE"
145         else:
146             allowed = "FALSE"
147         status_notify ('%s CAN-HIBERNATE ALLOWED=%s' % (greeter_id, allowed))
148
149     r = '%s HIBERNATE' % greeter_id
150     if request == r:
151         try:
152             LightDM.hibernate ()
153         except:
154             status_notify ('%s FAIL-HIBERNATE' % greeter_id)
155
156     r = '%s GET-CAN-RESTART' % greeter_id
157     if request == r:
158         if LightDM.get_can_restart ():
159             allowed = "TRUE"
160         else:
161             allowed = "FALSE"
162         status_notify ('%s CAN-RESTART ALLOWED=%s' % (greeter_id, allowed))
163
164     r = '%s RESTART' % greeter_id
165     if request == r:
166         try:
167             LightDM.restart ()
168         except:
169             status_notify ('%s FAIL-RESTART' % greeter_id)
170
171     r = '%s GET-CAN-SHUTDOWN' % greeter_id
172     if request == r:
173         if LightDM.get_can_shutdown ():
174             allowed = "TRUE"
175         else:
176             allowed = "FALSE"
177         status_notify ('%s CAN-SHUTDOWN ALLOWED=%s' % (greeter_id, allowed))
178
179     r = '%s SHUTDOWN' % greeter_id
180     if request == r:
181         try:
182             LightDM.shutdown ()
183         except:
184             status_notify ('%s FAIL-SHUTDOWN' % greeter_id)
185
186     return True
187
188 def print_hints (greeter):
189     if greeter.get_select_user_hint () is not None:
190         status_notify ('%s SELECT-USER-HINT USERNAME=%s' % (greeter_id, greeter.get_select_user_hint ()))
191     if greeter.get_select_guest_hint ():
192         status_notify ('%s SELECT-GUEST-HINT' % greeter_id)
193     if greeter.get_lock_hint ():
194         status_notify ('%s LOCK-HINT' % greeter_id)
195     if not greeter.get_has_guest_account_hint ():
196         status_notify ('%s HAS-GUEST-ACCOUNT-HINT=FALSE' % greeter_id)
197     if greeter.get_hide_users_hint ():
198         status_notify ('%s HIDE-USERS-HINT' % greeter_id)
199     if greeter.get_show_manual_login_hint ():
200         status_notify ('%s SHOW-MANUAL-LOGIN-HINT' % greeter_id)
201     if not greeter.get_show_remote_login_hint ():
202         status_notify ('%s SHOW-REMOTE-LOGIN-HINT=FALSE' % greeter_id)
203
204 path = os.getenv ('LIGHTDM_TEST_ROOT') + '/.s'
205 status_socket = socket.socket (socket.AF_UNIX, socket.SOCK_STREAM)
206 status_socket.connect (path)
207 GLib.io_add_watch (status_socket.fileno (), GLib.IO_IN | GLib.IO_HUP, request_cb)
208
209 status_text = '%s START' % greeter_id
210 if xdg_seat is not None:
211     status_text += ' XDG_SEAT=%s' % xdg_seat
212 if xdg_vtnr is not None:
213     status_text += ' XDG_VTNR=%s' % xdg_vtnr
214 if xdg_session_cookie is not None:
215     status_text += ' XDG_SESSION_COOKIE=%s' % xdg_session_cookie
216 if xdg_session_class is not None:
217     status_text += ' XDG_SESSION_CLASS=%s' % xdg_session_class
218 status_notify (status_text)
219
220 config = GLib.KeyFile ()
221 config.load_from_file (os.getenv ('LIGHTDM_TEST_ROOT') + '/script', GLib.KeyFileFlags.NONE)
222
223 # NOTE: There don't seem to be any good X bindings so we have to mock up our own...
224 if display is not None:
225     (host, display_number) = display.split (':')
226     if host == '':
227         x_socket = socket.socket (socket.AF_UNIX, socket.SOCK_STREAM)
228         x_socket.connect (os.getenv ('LIGHTDM_TEST_ROOT') + '/.x' + display)
229     else:
230         x_socket = socket.socket (socket.AF_INET, socket.SOCK_STREAM)
231         x_socket.connect ((host, 6000 + int (display_number)))
232
233     status_notify ('%s CONNECT-XSERVER' % (greeter_id))
234
235 def show_message_cb (greeter, text, type):
236     status_notify ('%s SHOW-MESSAGE TEXT=\"%s\"' % (greeter_id, text))
237
238 def show_prompt_cb (greeter, text, type):
239     status_notify ('%s SHOW-PROMPT TEXT=\"%s\"' % (greeter_id, text))
240
241 def authentication_complete_cb (greeter):
242     if greeter.get_is_authenticated ():
243         is_authenticated = 'TRUE'
244     else:
245         is_authenticated = 'FALSE'
246     if greeter.get_authentication_user () is not None:
247         status_notify ('%s AUTHENTICATION-COMPLETE USERNAME=%s AUTHENTICATED=%s' % (greeter_id, greeter.get_authentication_user (), is_authenticated))
248     else:
249         status_notify ('%s AUTHENTICATION-COMPLETE AUTHENTICATED=%s' % (greeter_id, is_authenticated))
250
251 def autologin_timer_expired_cb (greeter):
252     status_notify ('%s AUTOLOGIN-TIMER-EXPIRED' % greeter_id)
253
254 greeter = LightDM.Greeter ()
255 greeter.connect ('show-message', show_message_cb)
256 greeter.connect ('show-prompt', show_prompt_cb)
257 greeter.connect ('authentication-complete', authentication_complete_cb)
258 greeter.connect ('autologin-timer-expired', autologin_timer_expired_cb)
259
260 def user_added_cb (user_list, user):
261     status_notify ('%s USER-ADDED USERNAME=%s' % (greeter_id, user.get_name ()))
262 def user_removed_cb (user_list, user):
263     status_notify ('%s USER-REMOVED USERNAME=%s' % (greeter_id, user.get_name ()))
264 log_user_changes = False
265 try:
266     log_user_changes = config.get_boolean ('test-greeter-config', 'log-user-changes')
267 except:
268     pass
269 if log_user_changes:
270     LightDM.UserList.get_instance ().connect ('user-added', user_added_cb)
271     LightDM.UserList.get_instance ().connect ('user-removed', user_removed_cb)
272
273 def idle_cb (greeter):
274     status_notify ('%s IDLE' % (greeter_id))
275 def reset_cb (greeter):
276     status_notify ('%s RESET' % (greeter_id))
277     print_hints (greeter)
278 resettable = False
279 try:
280     resettable = config.get_boolean ('test-greeter-config', 'resettable')
281 except:
282     pass
283 if resettable:
284     LightDM.Greeter.get_instance ().set_resettable (True)
285     LightDM.Greeter.get_instance ().connect ('idle', idle_cb)
286     LightDM.Greeter.get_instance ().connect ('reset', reset_cb)
287
288 status_notify ('%s CONNECT-TO-DAEMON' % greeter_id)
289 if not greeter.connect_sync ():
290     status_notify ('%s FAIL-CONNECT-DAEMON' % greeter_id)
291     exit (1)
292
293 status_notify ('%s CONNECTED-TO-DAEMON' % greeter_id)
294
295 print_hints (greeter)
296
297 loop.run ()