CI mmi is now working every time (for support alphacrypt parental control or other...
[enigma2.git] / lib / python / Screens / Ci.py
index 9bf5b168bc93a1169bd2832083b3b3a0054c3cc1..10e33cfe361a89cca03f9907d8050723f1aece45 100644 (file)
@@ -24,9 +24,8 @@ class CiMmi(Screen):
 
                self.slotid = slotid
 
-               self.Timer = eTimer()
-               self.Timer.timeout.get().append(self.TimerCheck)
-               self.Timer.start(1000)
+               self.timer = eTimer()
+               self.timer.timeout.get().append(self.keyCancel)
 
                #else the skins fails
                self["title"] = Label("")
@@ -56,12 +55,7 @@ class CiMmi(Screen):
 
                self.action = action
 
-               if action == 0:                 #reset
-                       eDVBCI_UI.getInstance().setReset(self.slotid)
-                       self.showWait()
-               elif action == 1:               #init
-                       eDVBCI_UI.getInstance().setInit(self.slotid)
-               elif action == 2:               #start MMI
+               if action == 2:         #start MMI
                        eDVBCI_UI.getInstance().startMMI(self.slotid)
                        self.showWait()
                elif action == 3:               #mmi already there (called from infobar)
@@ -84,7 +78,7 @@ class CiMmi(Screen):
                        self["bottom"].setText(_("please press OK when ready"))
 
        def okbuttonClick(self):
-               print "ok"
+               self.timer.stop()
                if self.tag == "WAIT":
                        print "do nothing - wait"
                elif self.tag == "MENU":
@@ -109,11 +103,11 @@ class CiMmi(Screen):
                        self.showWait()
 
        def closeMmi(self):
-               self.Timer.stop()
-               self.close()
+               self.timer.stop()
+               self.close(self.slotid)
 
        def keyCancel(self):
-               print "keyCancel"
+               self.timer.stop()
                if self.tag == "WAIT":
                        eDVBCI_UI.getInstance().stopMMI(self.slotid)
                        self.closeMmi()
@@ -129,18 +123,22 @@ class CiMmi(Screen):
                        print "give cancel action to ci"        
 
        def keyConfigEntry(self, key):
+               self.timer.stop()
                try:
                        self["entries"].handleKey(key)
-               except AttributeError:
+               except:
                        pass
 
        def keyNumberGlobal(self, number):
+               self.timer.stop()
                self.keyConfigEntry(config.key[str(number)])
 
        def keyLeft(self):
+               self.timer.stop()
                self.keyConfigEntry(config.key["prevElement"])
 
        def keyRight(self):
+               self.timer.stop()
                self.keyConfigEntry(config.key["nextElement"])
 
        def updateList(self, list):
@@ -180,23 +178,30 @@ class CiMmi(Screen):
        
                list = [ ]
 
-               self.tag = screen[0][0]
-
-               for entry in screen:
-                       if entry[0] == "PIN":
-                               self.addEntry(list, entry)
+               self.timer.stop()
+               if len(screen) > 0 and screen[0][0] == "CLOSE":
+                       timeout = screen[0][1]
+                       if timeout > 0:
+                               self.timer.start(timeout*1000, True)
                        else:
-                               if entry[0] == "TITLE":
-                                       self["title"].setText(entry[1])
-                               elif entry[0] == "SUBTITLE":
-                                       self["subtitle"].setText(entry[1])
-                               elif entry[0] == "BOTTOM":
-                                       self["bottom"].setText(entry[1])
-                               elif entry[0] == "TEXT":
+                               self.keyCancel()
+               else:
+                       self.tag = screen[0][0]
+                       for entry in screen:
+                               if entry[0] == "PIN":
                                        self.addEntry(list, entry)
-               self.updateList(list)
-
-       def TimerCheck(self):
+                               else:
+                                       if entry[0] == "TITLE":
+                                               self["title"].setText(entry[1])
+                                       elif entry[0] == "SUBTITLE":
+                                               self["subtitle"].setText(entry[1])
+                                       elif entry[0] == "BOTTOM":
+                                               self["bottom"].setText(entry[1])
+                                       elif entry[0] == "TEXT":
+                                               self.addEntry(list, entry)
+                       self.updateList(list)
+
+       def ciStateChanged(self):
                if self.action == 0:                    #reset
                        self.closeMmi()
                if self.action == 1:                    #init
@@ -210,73 +215,117 @@ class CiMmi(Screen):
                if eDVBCI_UI.getInstance().getMMIState(self.slotid) != 1:
                        self.closeMmi()
 
-               if eDVBCI_UI.getInstance().availableMMI(self.slotid) == 1:
+               if self.action > 1 and eDVBCI_UI.getInstance().availableMMI(self.slotid) == 1:
                        self.showScreen()
 
                #FIXME: check for mmi-session closed    
 
-class CiSelection(Screen):
-       def createMenu(self):
-               self.list = [ ]
-               self.list.append( (_("Reset"), 0) )
-               self.list.append( (_("Init"), 1) )
-               
-               self.state = eDVBCI_UI.getInstance().getState(0)
-               if self.state == 0:                     #no module
-                       self.list.append( (_("no module found"), 2) )
-               elif self.state == 1:           #module in init
-                       self.list.append( (_("init module"), 2) )
-               elif self.state == 2:           #module ready
-                       #get appname            
-                       appname = eDVBCI_UI.getInstance().getAppName(0)
-                       self.list.append( (appname, 2) )
+class CiMessageHandler:
+       def __init__(self):
+               self.session = None
+               self.ci = { }
+               self.dlgs = { }
+               eDVBCI_UI.getInstance().ciStateChanged.get().append(self.ciStateChanged)
 
-               self["entries"].list = self.list
-               self["entries"].l.setList(self.list)
+       def setSession(self, session):
+               self.session = session
 
-       def TimerCheck(self):
-               state = eDVBCI_UI.getInstance().getState(0)
-               if self.state != state:
-                       #print "something happens"
-                       self.state = state
-                       self.createMenu()
-       
-       def okbuttonClick(self):
-               self.slot = 0
-       
-               if self.state == 2:
-                       self.session.open(CiMmi, 0, self["entries"].getCurrent()[1])
+       def ciStateChanged(self, slot):
+               if slot in self.ci:
+                       self.ci[slot](slot)
+               else:
+                       if slot in self.dlgs:
+                               self.dlgs[slot].ciStateChanged()
+                       elif eDVBCI_UI.getInstance().availableMMI(slot) == 1:
+                               if self.session:
+                                       self.dlgs[slot] = self.session.openWithCallback(self.dlgClosed, CiMmi, slot, 3)
+                               else:
+                                       print "no session"
 
-               #generate menu / list
-               #list = [ ]
-               #list.append( ("TEXT", "CA-Info") )
-               #list.append( ("TEXT", "Card Status") )
-               #list.append( ("PIN", 6, "Card Pin", 1) )
-               #self.session.open(CiMmi, 0, 0, "Wichtiges CI", "Mainmenu", "Footer", list)
+       def dlgClosed(self, slot):
+               del self.dlgs[slot]
 
-       def cancel(self):
-               self.Timer.stop()
-               self.close()
+       def registerCIMessageHandler(self, slot, func):
+               self.unregisterCIMessageHandler(slot)
+               self.ci[slot] = func
 
-       def mmiAvail(self, slot):
-               print "mmi avail slot", slot
+       def unregisterCIMessageHandler(self, slot):
+               if slot in self.ci:
+                       del self.ci[slot]
 
+CiHandler = CiMessageHandler()
+
+class CiSelection(Screen):
        def __init__(self, session):
-               #FIXME support for one ci only
                Screen.__init__(self, session)
-               
-               self["actions"] = ActionMap(["OkCancelActions"], 
+
+               self["actions"] = ActionMap(["OkCancelActions"],
                        {
                                "ok": self.okbuttonClick,
                                "cancel": self.cancel
                        })
 
+               self.dlg = None
+               self.state = { }
                self.list = [ ]
                self["entries"] = MenuList(list)
-               self.createMenu()
+               self.clearMenu()
+               self.createMenu(0) # FIXME more than one CI
+               CiHandler.registerCIMessageHandler(0, self.ciStateChanged)
+
+       def clearMenu(self):
+               self.list = [ ]
+
+       def createMenu(self, slot):
+               self.list.append( (_("Reset"), 0, slot) )
+               self.list.append( (_("Init"), 1, slot) )
+
+               self.state[slot] = eDVBCI_UI.getInstance().getState(slot)
+               if self.state[slot] == 0:                       #no module
+                       self.list.append( (_("no module found"), 2, slot) )
+               elif self.state[slot] == 1:             #module in init
+                       self.list.append( (_("init module"), 2, slot) )
+               elif self.state[slot] == 2:             #module ready
+                       #get appname
+                       appname = eDVBCI_UI.getInstance().getAppName(slot)
+                       self.list.append( (appname, 2, slot) )
+
+               self["entries"].list = self.list
+               self["entries"].l.setList(self.list)
+
+       def ciStateChanged(self, slot):
+               if self.dlg:
+                       self.dlg.ciStateChanged()
+               else:
+                       state = eDVBCI_UI.getInstance().getState(slot)
+                       if self.state[slot] != state:
+                               #print "something happens"
+                               self.state[slot] = state
+                               self.clearMenu()
+                               self.createMenu(slot)
 
-               self.Timer = eTimer()
-               self.Timer.timeout.get().append(self.TimerCheck)
-               self.Timer.start(1000)
+       def dlgClosed(self, slot):
+               self.dlg = None
 
-               eDVBCI_UI.getInstance().mmiAvail.get().append(self.mmiAvail)
+       def okbuttonClick(self):
+               cur = self["entries"].getCurrent()
+               if cur:
+                       action = cur[1]
+                       slot = cur[2]
+                       if action == 0:         #reset
+                               eDVBCI_UI.getInstance().setReset(slot)
+                       elif action == 1:               #init
+                               eDVBCI_UI.getInstance().setInit(slot)
+                       elif self.state[slot] == 2:
+                               self.dlg = self.session.openWithCallback(self.dlgClosed, CiMmi, slot, action)
+
+               #generate menu / list
+               #list = [ ]
+               #list.append( ("TEXT", "CA-Info") )
+               #list.append( ("TEXT", "Card Status") )
+               #list.append( ("PIN", 6, "Card Pin", 1) )
+               #self.session.open(CiMmi, 0, 0, "Wichtiges CI", "Mainmenu", "Footer", list)
+
+       def cancel(self):
+               CiHandler.unregisterCIMessageHandler(0)
+               self.close()