source: zero-server-wizard/trunk/fuentes/install-files/usr/share/zero-server-wizard/independent.py @ 4602

Last change on this file since 4602 was 4602, checked in by hectorgh, 3 years ago

adding newer translations

File size: 15.5 KB
Line 
1import os
2import os.path
3import xmlrpclib
4import datetime
5import subprocess
6import sys
7import multiprocessing
8from cStringIO import StringIO
9
10
11import lliurex.net
12try:
13        import gi
14        gi.require_version('Gtk', '3.0')
15        from gi.repository import Gtk,Gdk,GLib
16except:
17        pass
18
19import gettext
20_=gettext.gettext
21
22
23DNS1="172.27.111.5"
24DNS2="172.27.111.6"
25
26class Independent:
27       
28       
29        def __init__(self,core,server_conf=None):
30               
31                self.id="INDEPENDENT"
32                self.scripts_path="/usr/share/zero-server-wizard/types/independent/actions/"
33                self.template={}
34                if server_conf!=None:
35                        try:
36                                for item in server_conf["variables"]:
37                                        self.template[item]=None
38                        except:
39                                pass
40                               
41
42               
43                self.core=core
44               
45        #def __init__
46       
47        def start_gui(self,standalone=False):
48               
49                self.standalone=standalone
50               
51                builder=self.core.builder
52
53               
54                self.apply_button=builder.get_object("apply_button")
55                self.internal_speed_label=builder.get_object("internal_iface_speed_label")
56                self.external_speed_label=builder.get_object("external_iface_speed_label")
57                self.password_entry=builder.get_object("password_entry")
58                self.password_entry1=builder.get_object("password_entry1")
59                self.password_entry.connect("changed",self.password_changed)
60                self.password_entry1.connect("changed",self.password_changed)
61                self.srv_name_entry=builder.get_object("srv_name_entry")
62                self.srv_domain_entry=builder.get_object("srv_domain_entry")
63                self.internal_combobox=builder.get_object("internal_combobox")
64                self.internal_combobox.set_name("Button")
65                self.external_combobox=builder.get_object("external_combobox")
66               
67                self.internal_ip_entry=builder.get_object("srvip_entry")
68                self.internal_mask_entry=builder.get_object("internal_mask_entry")
69                self.external_ip_entry=builder.get_object("external_ip_entry")
70                self.external_mask_entry=builder.get_object("external_mask_entry")
71                self.external_gateway_entry=builder.get_object("external_gateway_entry")
72                self.dns1_entry=builder.get_object("dns1_entry")
73                self.dns2_entry=builder.get_object("dns2_entry")
74                self.pass_label=builder.get_object("pass_label")
75                self.dhcp_radiobutton=builder.get_object("dhcp_radiobutton")
76                self.dhcp_radiobutton.connect("toggled",self.radio_button_changed)
77                self.manual_radiobutton=builder.get_object("manual_radiobutton")
78                self.manual_expander=builder.get_object("manual_expander")
79                self.manual_expander.set_sensitive(False)
80                self.apply_button.connect("clicked",self.apply_clicked)
81                self.apply_button.set_sensitive(False)
82                self.apply_button.set_name("Button")
83               
84               
85                self.set_default_gui_values()
86               
87
88                if standalone:
89                       
90                        Gtk.main()
91
92               
93        #def start_gui
94       
95        def radio_button_changed(self,widget):
96
97                self.manual_expander.set_sensitive(not self.dhcp_radiobutton.get_active())
98                self.manual_expander.set_expanded(not self.dhcp_radiobutton.get_active())
99               
100        #def radio_button_changed
101       
102        def password_changed(self,widget):
103               
104                if self.password_entry.get_text()!=self.password_entry1.get_text():
105                        self.pass_label.set_markup("<span fgcolor='red'>" + _("Passwords do not match") +"</span>")
106                        self.apply_button.set_sensitive(False)
107                else:
108                        self.pass_label.set_markup("")
109                        self.apply_button.set_sensitive(True)
110                       
111
112               
113        #def
114       
115        def set_default_gui_values(self):
116               
117                self.iiface_model=Gtk.ListStore(str)
118                self.eiface_model=Gtk.ListStore(str)
119               
120                self.internal_combobox.set_model(self.iiface_model)
121                self.external_combobox.set_model(self.eiface_model)
122                rendi=Gtk.CellRendererText()
123                self.internal_combobox.pack_start(rendi,True)
124                self.internal_combobox.add_attribute(rendi,"text",0)
125                self.internal_combobox.connect("changed",self.get_link_speed,0)
126                rende=Gtk.CellRendererText()
127                self.external_combobox.pack_start(rende,True)
128                self.external_combobox.add_attribute(rende,"text",0)
129                self.external_combobox.connect("changed",self.get_link_speed,1)
130                self.interfaces=lliurex.net.get_devices_info()         
131               
132               
133                for item in self.interfaces:
134                        if "eth" in item["name"]:
135                                self.iiface_model.append([item["name"]])
136                                self.eiface_model.append([item["name"]])
137                               
138                       
139                self.internal_combobox.set_active(0)
140                if len(self.iiface_model)>1:
141                        self.external_combobox.set_active(1)
142                else:
143                        self.external_combobox.set_active(0)
144                       
145               
146                self.srv_domain_entry.set_text(self.template.setdefault("srv_domain_name","aula1"))
147                self.internal_ip_entry.set_text(self.template.setdefault("srv_ip","10.2.1.254"))
148                self.internal_mask_entry.set_text(self.template.setdefault("internal_mask","255.255.255.0"))
149                self.dns1_entry.set_text(DNS1)
150                self.dns2_entry.set_text(DNS2)
151               
152                try:
153                       
154                        f=open("/etc/hostname")
155                        line=f.readline().strip("\n")
156                        f.close()
157                        self.srv_name_entry.set_text(self.template.setdefault("srv_name",line))
158                except:
159                        pass
160                       
161               
162               
163        #def set_default_gui_values
164       
165        def apply_clicked(self,widget):
166               
167
168                self.get_gui_values()
169               
170               
171        #def apply_clicked
172       
173        def get_gui_values(self):
174               
175                iter=self.internal_combobox.get_active_iter()
176                if iter!=None:
177                        self.template["internal_iface"]=self.iiface_model.get(iter,0)[0]
178                else:
179                        self.template["internal_iface"]=None
180                iter=self.external_combobox.get_active_iter()
181                if iter!=None:
182                        self.template["external_iface"]=self.eiface_model.get(iter,0)[0]
183                else:
184                        self.template["external_iface"]=None
185               
186                self.template["adminpassword"]=self.password_entry.get_text()
187                self.template["srv_name"]=self.srv_name_entry.get_text()
188                self.template["srv_name"]=''.join(e for e in self.template["srv_name"] if e.isalnum())
189                self.template["srv_domain_name"]=self.srv_domain_entry.get_text()
190                self.template["srv_domain_name"]=''.join(e for e in self.template["srv_domain_name"] if e.isalnum())
191                self.template["srv_ip"]=self.internal_ip_entry.get_text()
192                self.template["internal_mask"]=self.internal_mask_entry.get_text()
193                if self.dhcp_radiobutton.get_active():
194                        self.template["external_mode"]="dhcp"
195
196                else:
197                        self.template["external_mode"]="manual"
198
199                self.template["external_ip"]=self.external_ip_entry.get_text()
200                self.template["external_mask"]=self.external_mask_entry.get_text()
201                self.template["external_gateway"]=self.external_gateway_entry.get_text()
202                self.template["dns1"]=self.dns1_entry.get_text()
203                self.template["dns2"]=self.dns2_entry.get_text()
204               
205                self.check_values()
206       
207       
208        def check_values(self):
209               
210
211                        error_msg=""
212                        '''
213                        if self.template["internal_iface"]==self.template["external_iface"]:
214                                error_msg+="* External and internal interfaces must be different.\n"
215                        '''
216                        if not lliurex.net.is_valid_ip(self.template["srv_ip"]):
217                                error_msg+="* " + _("Internal IP must be a valid IP.")+"\n"
218
219                        if not lliurex.net.is_valid_ip(self.template["internal_mask"]):
220                                error_msg+="* " + _("Internal mask must be a valid IP.") + "\n"
221                               
222                        if self.template["srv_name"]=="":
223                                error_msg+="* " + _("Server name cannot be an empty string.") + "\n"
224                        if self.template["srv_domain_name"]=="":
225                                error_msg+="* " + _("Server domain name cannot be an empty string.") +"\n"
226                       
227                       
228                        if self.template["external_mode"]=="manual":
229
230                                if self.template["external_ip"]=='' or not lliurex.net.is_valid_ip(self.template["external_ip"]):
231                                        error_msg+="* " + _("External IP must be a valid IP.")+"\n"
232                                if self.template["external_mask"]=="" or not lliurex.net.is_valid_ip(self.template["external_mask"]):
233                                        error_msg+="* " + _("External mask must be a valid IP.")+"\n"
234                                if self.template["external_gateway"]=="" or not lliurex.net.is_valid_ip(self.template["external_gateway"]):
235                                        error_msg+="* " + _("External gateway must be a valid IP.")+"\n"
236                               
237                               
238                        if self.template["dns1"]=="" or not lliurex.net.is_valid_ip(self.template["dns1"]):
239                                error_msg+="* " + _("DNS1 must be a valid IP.")+"\n"
240                        if self.template["dns2"]=="" or not lliurex.net.is_valid_ip(self.template["dns2"]):
241                                error_msg+="* " + _("DNS2 must be a valid IP.")+"\n"
242                               
243                        if error_msg!="":
244                                builder = Gtk.Builder()
245                                if os.path.exists("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/warning.glade"):
246                                        builder.add_from_file("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/warning.glade")
247                                else:
248                                        builder.add_from_file("/usr/share/zero-server-wizard/rsrc/warning.glade")
249                                       
250                                       
251                                window=builder.get_object("window1")
252                                msg_label=builder.get_object("msg_label")
253                                close_button=builder.get_object("close_button")
254                                def hide(widget):
255                                        window.destroy()
256                                close_button.connect("clicked",hide)
257                                msg_label.set_text(error_msg.strip("\n"))
258                                window.show()                           
259                       
260                        else:
261                               
262                                builder=Gtk.Builder()
263                                if os.path.exists("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/progress_window.glade"):
264                                        builder.add_from_file("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/progress_window.glade")
265                                else:
266                                        builder.add_from_file("/usr/share/zero-server-wizard/rsrc/progress_window.glade")                               
267                                       
268                                       
269                                self.error_msg=None
270                                window=builder.get_object("window1")
271                                review_textview=builder.get_object("textbuffer1")
272                                exec_textview=builder.get_object("textbuffer2")
273                                apply_button=builder.get_object("apply_button")
274                                close_button=builder.get_object("close_button")
275                                pbar=builder.get_object("progressbar1")
276                                terminal_box=builder.get_object("scrolledwindow2")
277                               
278                                                               
279                                #ret_textview=builder.get_object("ret_textview")
280                                widgets=[close_button,pbar]
281                                self.pulsating=False
282                               
283                               
284                                msg=""
285                               
286                                msg+="[ "+"SERVER NAME"+" ] = " + self.template["srv_name"] + "\n"
287                                msg+="[ "+"SERVER DOMAIN NAME"+" ] = " + self.template["srv_domain_name"] + "\n"
288                                msg+="[ "+"INTERNAL INTERFACE"+" ] = " + self.template["internal_iface"] + "\n"
289                                msg+="[ "+"INTERNAL IP"+" ] = " + self.template["srv_ip"] + "\n"
290                                msg+="[ "+"INTERNAL MASK"+" ] = " + self.template["internal_mask"] + "\n"
291                                msg+="[ "+"EXTERNAL INTERFACE"+" ] = " + self.template["external_iface"] + "\n"
292                                msg+="[ "+"EXTERNAL MODE"+" ] = " + self.template["external_mode"] + "\n"
293                                if self.template["external_mode"]!="dhcp":
294                                        msg+="[ "+"EXTERNAL IP"+" ] = " + self.template["external_ip"] + "\n"
295                                        msg+="[ "+"EXTERNAL MASK"+" ] = " + self.template["external_mask"] + "\n"
296                                        msg+="[ "+"EXTERNAL GATEWAY"+" ] = " + self.template["external_gateway"] + "\n"
297                                msg+="[ "+"DNS"+" ] = " + str(self.template["dns1"]) + ", " + str(self.template["dns2"])+ "\n"
298                                       
299
300                               
301                                review_textview.set_text(msg)
302                                       
303                               
304                               
305                                def pulsating():
306                                        pbar.pulse()
307                                       
308                                        try:
309                                                f=open("/tmp/.zsw-log","r")
310                                                tmp="".join(f.readlines())
311                                                if self.msg_thread!=tmp:
312                                                        self.msg_thread=tmp
313                                                        exec_textview.set_text(tmp)
314                                                       
315                                                f.close()
316                                        except:
317                                                pass
318                                               
319                                       
320                                       
321                                        if not os.path.exists("/tmp/.zsw-on"):
322                                                pbar.set_fraction(1)
323                                                close_button.set_sensitive(True)
324                                               
325                                               
326                                               
327                                                if os.path.exists("/tmp/.zsw-error"):
328                                               
329                                                        f=open("/tmp/.zsw-error","r")
330                                                        self.error_msg=f.readline()
331                                                        f.close()
332                                                        os.remove("/tmp/.zsw-error")
333                                               
334                                                        builder = Gtk.Builder()
335                                                        if os.path.exists("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/warning.glade"):
336                                                                builder.add_from_file("/srv/svn/pandora/zero-server-wizard/trunk/install-files/usr/share/zero-server-wizard/rsrc/warning.glade")
337                                                        else:
338                                                                builder.add_from_file("/usr/share/zero-server-wizard/rsrc/warning.glade")
339                                                               
340                                                               
341                                                        window2=builder.get_object("window1")
342                                                        msg_label=builder.get_object("msg_label")
343                                                        close_button2=builder.get_object("close_button")
344                                                        def hide(widget):
345                                                                window2.destroy()
346                                                        close_button2.connect("clicked",hide)
347                                                        msg_label.set_markup("<b>"+self.error_msg+"</b>")
348                                                        window2.set_title("Error")
349                                                        window2.show() 
350                                                       
351                                                        return False
352                                                       
353                                                else:
354                                                        label = Gtk.Label(_("Initialization complete. A reboot is required."))
355                                                        dialog = Gtk.Dialog("Zero Server Wizard", None, Gtk.DialogFlags.MODAL | Gtk.DialogFlags.DESTROY_WITH_PARENT, (Gtk.STOCK_OK, Gtk.ResponseType.ACCEPT))
356                                                        img=Gtk.Image.new_from_stock(Gtk.STOCK_APPLY,Gtk.IconSize.DIALOG)
357                                                        hbox=Gtk.HBox()
358                                                        hbox.pack_start(img,True,True,5)
359                                                        hbox.pack_start(label,True,True,5)
360                                                        hbox.show_all()
361                                                        dialog.vbox.pack_start(hbox,True,True,10)
362                                                        label.show()
363                                                        dialog.set_border_width(6)
364                                                        response = dialog.run()
365
366                                                        sys.exit(0)
367                                               
368                                               
369                                               
370                                        return True
371                               
372                                def apply_clicked(widget,data):
373                                        self.pulsating=True
374                                        f=open("/tmp/.zsw-on","w")
375                                        f.close()
376                                        self.msg_thread=""
377                                        self.prv_msg=None
378                                        widget.set_sensitive(False)
379                                        t=multiprocessing.Process(target=self.execute,args=(self.template,True,))
380                                        #t.daemon=True
381                                        t.start()
382                                        close_button.set_sensitive(False)
383                                        GLib.timeout_add(100,pulsating)
384                                       
385                                def destroy(uno,dos):
386                                        try:
387                                                if self.pulsating:
388                                                        return True
389                                                else:
390                                                        window.destroy()
391                                        except:
392                                                pass
393                                               
394
395                                       
396                                #def apply_clicked
397                               
398                               
399                                def close(widget):
400                                        window.destroy()
401
402
403
404                                apply_button.connect("clicked",apply_clicked,None)
405                                close_button.connect("clicked",close)
406                                window.connect("delete_event",destroy)
407                               
408                                window.show()
409                               
410                                pass
411                                #def init_done
412                               
413
414        #def check_values
415       
416        def get_link_speed(self,widget,id):
417               
418                tree_iter = widget.get_active_iter()
419                if tree_iter != None:
420                        model = widget.get_model()
421                        try:
422                                speed=lliurex.net.get_device_info(model[tree_iter][0])["Speed"][0]
423                        except:
424                                speed="Unknown speed"
425                        if id==0:
426                                self.internal_speed_label.set_text(speed)
427                        else:
428                                self.external_speed_label.set_text(speed)
429                               
430               
431        #def get_link_speed
432       
433        def external_mode_signal(self,widget):
434               
435                self.manual_external_box.set_sensitive(not self.dhcp_radiobutton.get_active())
436               
437        #def ems
438       
439       
440        def close_window(self,widget):
441                if self.standalone:
442                        Gtk.main_quit()
443               
444               
445        #def close_window
446       
447       
448        def execute(self,template,gui=False):
449               
450                print("[INDEPENDENT] Executing independent configuration...")
451                       
452                #self.template=template
453                self.log("Executing Independent configuration...")
454
455                self.core.template=dict(self.core.template.items() + self.template.items())
456                self.template=self.core.template
457               
458                if not self.template.has_key("remote_ip"):
459                        self.template["remote_ip"]="localhost"
460               
461               
462                if os.path.exists("/tmp/.zsw-log"):
463                        os.remove("/tmp/.zsw-log")
464               
465                for f in sorted(os.listdir("/usr/share/zero-server-wizard/types/independent/actions/")):
466                        if os.path.isfile(self.scripts_path+f):
467                               
468                                try:
469                                        if f.endswith(".py"):
470                                                self.log("Excuting " + f + " ...")
471                                                print("[INDEPENDENT] Executing " + f + " ...")
472                                                if not gui:
473                                                        execfile(self.scripts_path+f,locals())
474                                                else:
475                                                       
476                                                        #.set_text(ret_textview.get_buffer().get_text(ret_textview.get_buffer().get_start_iter(),ret_textview.get_buffer().get_end_iter(),True)+ "\npor aqui")
477                                                        #msg+=("[INDEPENDENT] Executing " + f + " ... ")
478                                                        f_=open("/tmp/.zsw-log","a")
479                                                        f_.write("[INDEPENDENT] Executing " + f + " ... ")
480                                                        f_.close()
481                                                        execfile(self.scripts_path+f,locals())
482                                                        f_=open("/tmp/.zsw-log","a")
483                                                        f_.write(" OK\n")
484                                                        f_.close()
485                                                       
486
487
488                                                       
489                                except Exception as e:
490                                        print "[ERROR!] " + str(e)
491
492                                        try:
493                                                f=open("/tmp/.zsw-error","w")
494                                                f.write(e.message)
495                                                f.close()
496                                        except:
497                                                pass
498                                       
499                                        if os.path.exists("/tmp/.zsw-on"):
500                                                os.remove("/tmp/.zsw-on")
501                                        return False
502               
503                if gui:
504                        if os.path.exists("/tmp/.zsw-on"):
505                                os.remove("/tmp/.zsw-on")
506               
507                return True     
508               
509        #def execute
510       
511        def log(self,line):
512               
513                independent_log="/tmp/independent"
514                f=open(independent_log,"a")
515                f.write( "[ "+datetime.datetime.today().strftime("%d/%m/%y %H:%M:%S") + " ] " + line + "\n")
516                f.close()
517               
518               
519        #def log
520       
521       
522       
523       
524#class Independent
Note: See TracBrowser for help on using the repository browser.