+#
+# Power Save Plugin by gutemine
+# Rewritten by Morty (morty@gmx.net)
+#
+# Deep standby will be called sleep. Normal standby will be named standby!
+# All calculations are in the local timezone, or in the relative Timezone.
+# In the relative timezone the day starts at "nextday". If it is before nextday the last day will be used.
+#
+#
+
+
+#from enigma import *
+
+
+from Screens.InfoBarGenerics import *
+# from RecordTimer import *
+
+
+import calendar
+#################
+
+# Plugin
+from Plugins.Plugin import PluginDescriptor
+
+# GUI (Screens)
+from Screens.Screen import Screen
+from Components.ConfigList import ConfigListScreen
+from Screens.MessageBox import MessageBox
+from Screens.Console import Console
+from Screens import Standby
+
+# GUI (Summary)
+# from Screens.Setup import SetupSummary
+
+# GUI (Components)
+from Components.ActionMap import ActionMap
+from Components.Button import Button
+
+# Configuration
+from Components.config import getConfigListEntry, ConfigEnableDisable, \
+ ConfigYesNo, ConfigText, ConfigClock, ConfigNumber, ConfigSelection, \
+ config, ConfigSubsection, ConfigSubList, ConfigSubDict
+
+# Startup/shutdown notification
+from Tools import Notifications
+
+import os
+# Timer, etc
+
+#import time
+from time import localtime, asctime, time, gmtime
+# import datetime
+# import codecs
+
+
+# Enigma system functions
+from enigma import quitMainloop, eTimer
+
+
+# import Wakeup?!
+from Tools.DreamboxHardware import getFPWasTimerWakeup
+
+
+
+# from Tools import Directories
+import gettext
+from Tools.Directories import resolveFilename, SCOPE_PLUGINS
+try:
+ _ = gettext.translation('elektro', resolveFilename(SCOPE_PLUGINS, "Extensions/Elektro/locale"), [config.osd.language.getText()]).gettext
+except IOError:
+ print "[Elektro] Locale not found!"
+ pass
+
+#############
+
+# Globals
+session = None
+ElektroWakeUpTime = -1
+elektro_pluginversion = "3.3.1"
+elektro_readme = "/usr/lib/enigma2/python/Plugins/Extensions/Elektro/readme.txt"
+elektrostarttime = 60
+elektrosleeptime = 5
+elektroShutdownThreshold = 60 * 20
+
+
+#Configuration
+config.plugins.elektro = ConfigSubsection()
+config.plugins.elektro.nextday = ConfigClock(default = ((6 * 60 + 0) * 60) )
+
+config.plugins.elektro.sleep = ConfigSubDict()
+for i in range(7):
+ config.plugins.elektro.sleep[i] = ConfigClock(default = ((1 * 60 + 0) * 60) )
+
+config.plugins.elektro.wakeup = ConfigSubDict()
+for i in range(7):
+ config.plugins.elektro.wakeup[i] = ConfigClock(default = ((9 * 60 + 0) * 60) )
+
+config.plugins.elektro.standbyOnBoot = ConfigEnableDisable(default = False)
+config.plugins.elektro.standbyOnManualBoot = ConfigEnableDisable(default = True)
+config.plugins.elektro.standbyOnBootTimeout = ConfigNumber(default = 60)
+config.plugins.elektro.enable = ConfigEnableDisable(default = False)
+config.plugins.elektro.nextwakeup = ConfigNumber(default = 0)
+config.plugins.elektro.force = ConfigEnableDisable(default = False)
+config.plugins.elektro.dontwakeup = ConfigEnableDisable(default = False)
+config.plugins.elektro.holiday = ConfigEnableDisable(default = False)
+
+
+
+weekdays = [
+ _("Monday"),
+ _("Tuesday"),
+ _("Wednesday"),
+ _("Thursday"),
+ _("Friday"),
+ _("Saturday"),
+ _("Sunday"),
+]
+
+
+#global ElektroWakeUpTime
+ElektroWakeUpTime = -1
+
+def autostart(reason, **kwargs):
+ global session
+ if reason == 0 and kwargs.has_key("session"):
+ session = kwargs["session"]
+ session.open(DoElektro)
+
+def getNextWakeup():
+ global ElektroWakeUpTime
+
+ #it might happen, that session does not exist. I don't know why. :-(
+ if session is None:
+ return ElektroWakeUpTime;
+
+ nextTimer = session.nav.RecordTimer.getNextRecordingTime()
+ print "[Elektro] Now: " + strftime("%a:%H:%M:%S", gmtime(time()))
+ if (nextTimer < 1) or (nextTimer > ElektroWakeUpTime):
+ print "[Elektro] will wake up " + strftime("%a:%H:%M:%S", gmtime(ElektroWakeUpTime))
+ return ElektroWakeUpTime
+
+ #We have to make sure, that the Box will wake up because of us
+ # and not because of the timer
+ print "[Elektro] will wake up due to the next timer" + strftime("%a:%H:%M:%S", gmtime(nextTimer))
+ return nextTimer - 1
+
+
+
+
+def Plugins(**kwargs):
+ return [
+ PluginDescriptor(
+ name="Elektro",
+ description="Elektro Power Save Plugin Ver. " + elektro_pluginversion,
+ where = [
+ PluginDescriptor.WHERE_SESSIONSTART,
+ PluginDescriptor.WHERE_AUTOSTART
+ ],
+ fnc = autostart,
+ wakeupfnc=getNextWakeup
+ ),
+ PluginDescriptor(
+ name="Elektro",
+ description="Elektro Power Save Plugin Ver. " + elektro_pluginversion,
+ where = PluginDescriptor.WHERE_PLUGINMENU,
+ icon="elektro.png",
+ fnc=main
+ )
+ ]
+
+
+def main(session,**kwargs):
+ try:
+ session.open(Elektro)
+ except:
+ print "[Elektro] Pluginexecution failed"
+
+class Elektro(ConfigListScreen,Screen):
+ skin = """
+ <screen position="100,100" size="550,400" title="Elektro Power Save Ver. """ + elektro_pluginversion + """" >
+ <widget name="config" position="0,0" size="550,360" scrollbarMode="showOnDemand" />
+
+ <widget name="key_red" position="0,360" size="140,40" valign="center" halign="center" zPosition="4" foregroundColor="white" font="Regular;18" transparent="1"/>
+ <widget name="key_green" position="140,360" size="140,40" valign="center" halign="center" zPosition="4" foregroundColor="white" font="Regular;18" transparent="1"/>
+ <widget name="key_yellow" position="280,360" size="140,40" valign="center" halign="center" zPosition="4" foregroundColor="white" font="Regular;18" transparent="1"/>
+
+ <ePixmap name="red" position="0,360" zPosition="2" size="140,40" pixmap="skin_default/buttons/red.png" transparent="1" alphatest="on" />
+ <ePixmap name="green" position="140,360" zPosition="2" size="140,40" pixmap="skin_default/buttons/green.png" transparent="1" alphatest="on" />
+ <ePixmap name="yellow" position="280,360" zPosition="2" size="140,40" pixmap="skin_default/buttons/yellow.png" transparent="1" alphatest="on" />
+ </screen>"""
+
+ def __init__(self, session, args = 0):
+ self.session = session
+ Screen.__init__(self, session)
+
+
+ self.list = []
+
+
+ self.list.append(getConfigListEntry(_("Enable Elektro Power Save"),config.plugins.elektro.enable))
+ self.list.append(getConfigListEntry(_("Standby on boot"), config.plugins.elektro.standbyOnBoot ))
+ self.list.append(getConfigListEntry(_("Standby on manual boot"), config.plugins.elektro.standbyOnManualBoot ))
+ self.list.append(getConfigListEntry(_("Standby on boot screen timeout"), config.plugins.elektro.standbyOnBootTimeout))
+ self.list.append(getConfigListEntry(_("Force sleep (even when not in standby)"), config.plugins.elektro.force ))
+ self.list.append(getConfigListEntry(_("Dont wake up"), config.plugins.elektro.dontwakeup ))
+ self.list.append(getConfigListEntry(_("Holiday mode (experimental)"), config.plugins.elektro.holiday ))
+
+ self.list.append(getConfigListEntry(_("Next day starts at"), config.plugins.elektro.nextday))
+
+ for i in range(7):
+ self.list.append(getConfigListEntry(weekdays[i] + ": " + _("Wakeup"), config.plugins.elektro.wakeup[i]))
+ self.list.append(getConfigListEntry(weekdays[i] + ": " + _("Sleep"), config.plugins.elektro.sleep[i]))
+
+ ConfigListScreen.__init__(self, self.list)
+
+ self["key_red"] = Button(_("Cancel"))
+ self["key_green"] = Button(_("Ok"))
+ self["key_yellow"] = Button(_("Help"))
+ self["setupActions"] = ActionMap(["SetupActions", "ColorActions"],
+ {
+ "red": self.cancel,
+ "green": self.save,
+ "yellow": self.help,
+ "save": self.save,
+ "cancel": self.cancel,
+ "ok": self.save,
+ }, -2)
+
+ def save(self):
+ #print "saving"
+ for x in self["config"].list:
+ x[1].save()
+ self.close(True,self.session)
+
+ def cancel(self):
+ #print "cancel"
+ for x in self["config"].list:
+ x[1].cancel()
+ self.close(False,self.session)
+
+ def help(self):
+ self.session.open(Console,_("Showing Elektro readme.txt"),["cat %s" % elektro_readme])
+
+
+class DoElektro(Screen):
+ skin = """ <screen position="100,100" size="300,300" title="Elektro Plugin Menu" > </screen>"""
+
+ def __init__(self,session):
+ Screen.__init__(self,session)
+
+ print "[Elektro] Starting up Version " + elektro_pluginversion
+
+ self.session = session
+
+ # Make sure wakeup time is set.
+ self.setNextWakeuptime()
+
+ # If we didn't wake up by a timer we don't want to go to sleep any more.
+ # Unforturnately it is not possible to use getFPWasTimerWakeup()
+ # Therfore we're checking wheter there is a recording starting within
+ # the next five min
+ self.dontsleep = False
+
+ #Let's assume we got woken up manually
+ timerWakeup = False
+
+ #Is a recording already runniong ->woken up by a timer
+ if self.session.nav.RecordTimer.isRecording():
+ timerWakeup = True
+ # Is the next timer within 5 min -> woken up by a timer
+ if abs(self.session.nav.RecordTimer.getNextRecordingTime() - time()) <= 360:
+ timerWakeup = True
+
+ # Did we wake up by Elektro?
+ # Let's hope this get's run early enaugh, and this get's run
+ # before the requested wakeup-time (should be the case)
+ #
+ if abs(ElektroWakeUpTime - time()) <= 360:
+ timerWakeup = True
+
+ # If the was a manual wakeup: Don't go to sleep
+ if timerWakeup == False:
+ self.dontsleep = True
+
+
+ #Check whether we should try to sleep:
+ trysleep = config.plugins.elektro.standbyOnBoot.value
+
+ #Don't go to sleep when this was a manual wakeup and the box shouldn't go to standby
+ if timerWakeup == False and config.plugins.elektro.standbyOnManualBoot.value == False:
+ trysleep = False
+
+
+ #if waken up by timer and configured ask whether to go to sleep.
+ if trysleep:
+ self.TimerStandby = eTimer()
+ self.TimerStandby.callback.append(self.CheckStandby)
+ self.TimerStandby.startLongTimer(elektrosleeptime)
+ print "[Elektro] Set up standby timer"
+
+ self.TimerSleep = eTimer()
+ self.TimerSleep.callback.append(self.CheckElektro)
+ self.TimerSleep.startLongTimer(elektrostarttime)
+ print "[Elektro] Set up sleep timer"
+ print "[Elektro] Translation test: " + _("Standby on boot")
+
+ def clkToTime(self, clock):
+ return ( (clock.value[0]) * 60 + (int)(clock.value[1]) ) * 60
+
+ def getTime(self):
+ ltime = localtime();
+ return ( (int)(ltime.tm_hour) * 60 + (int)(ltime.tm_min) ) * 60
+
+ def getPrintTime(self, secs):
+ return strftime("%H:%M:%S", gmtime(secs))
+
+
+ # This function converts the time into the relative Timezone where the day starts at "nextday"
+ # This is done by substracting nextday from the current time. Negative times are corrected using the mod-operator
+ def getReltime(self, time):
+ nextday = self.clkToTime(config.plugins.elektro.nextday)
+ return (time - nextday) % (24 * 60 * 60)
+
+
+ def CheckStandby(self):
+ print "[Elektro] Showing Standby Sceen "
+ try:
+ self.session.openWithCallback(self.DoElektroStandby,MessageBox,_("Go to Standby now?"),type = MessageBox.TYPE_YESNO,
+ timeout = config.plugins.elektro.standbyOnBootTimeout.value)
+ except:
+ # Couldn't be shown. Restart timer.
+ print "[Elektro] Failed Showing Standby Sceen "
+ self.TimerStandby.startLongTimer(elektrostarttime)
+
+
+ def DoElektroStandby(self,retval):
+ if (retval):
+ #Yes, go to sleep
+ Notifications.AddNotification(Standby.Standby)
+
+
+
+ def setNextWakeuptime(self):
+ # Do not set a wakeup time if
+ # - Elektro isn't enabled
+ # - Elektro shouldn't wake up
+ # - Holiday mode is turned on
+ if ((config.plugins.elektro.enable.value == False)
+ or (config.plugins.elektro.dontwakeup.value == True)
+ or config.plugins.elektro.holiday.value == True):
+ global ElektroWakeUpTime
+ ElektroWakeUpTime = -1
+ return
+
+ time_s = self.getTime()
+ ltime = localtime()
+
+ #print "Nextday:" + time.ctime(self.clkToTime(config.plugins.elektro.nextday))
+ # If it isn't past next-day time we need yesterdays settings
+ if time_s < self.clkToTime(config.plugins.elektro.nextday):
+ day = (ltime.tm_wday - 1) % 7
+ else:
+ day = ltime.tm_wday
+
+ #Check whether we wake up today or tomorrow
+ # Relative Time is needed for this
+ time_s = self.getReltime(time_s)
+ wakeuptime = self.getReltime(self.clkToTime(config.plugins.elektro.wakeup[day]))
+
+ # Lets see if we already woke up today
+ if wakeuptime < time_s:
+ #yes we did -> Next wakeup is tomorrow
+ #print "Elektro: Wakeup tomorrow"
+ day = (day + 1) % 7
+ wakeuptime = self.getReltime(self.clkToTime(config.plugins.elektro.wakeup[day]))
+
+ # Tomorrow we'll wake up erly-> Add a full day.
+ if wakeuptime < time_s:
+ wakeuptime = wakeuptime + 24 * 60 * 60
+
+ # The next wakeup will be in wakupin seconds
+ wakeupin = wakeuptime - time_s
+
+ # Now add this to the current time to get the wakeuptime
+ wakeuptime = (int)(time()) + wakeupin
+
+ #Write everything to the global variable
+ ElektroWakeUpTime = wakeuptime
+
+
+ def CheckElektro(self):
+ # first set the next wakeuptime - it would be much better to call that function on sleep. This will be a todo!
+ self.setNextWakeuptime()
+
+ #convert to seconds
+ time_s = self.getTime()
+ ltime = localtime()
+
+ print "[Elektro] Testtime; " + self.getPrintTime(2 * 60 * 60)
+
+ #Which day is it? The next day starts at nextday
+ print "[Elektro] wday 1: " + str(ltime.tm_wday)
+ if time_s < self.clkToTime(config.plugins.elektro.nextday):
+ day = (ltime.tm_wday - 1) % 7
+ else:
+ day = ltime.tm_wday
+
+ print "[Elektro] wday 2: " + str(day)
+
+ #Let's get the day
+ wakeuptime = self.clkToTime(config.plugins.elektro.wakeup[day])
+ sleeptime = self.clkToTime(config.plugins.elektro.sleep[day])
+ print "[Elektro] Current time: " + self.getPrintTime(time_s)
+ print "[Elektro] Wakeup time: " + self.getPrintTime(wakeuptime)
+ print "[Elektro] Sleep time: " + self.getPrintTime(sleeptime)
+
+ #convert into relative Times
+ time_s = self.getReltime(time_s)
+ wakeuptime = self.getReltime(wakeuptime)
+ sleeptime = self.getReltime(sleeptime)
+
+ print "[Elektro] Current Rel-time: " + self.getPrintTime(time_s)
+ print "[Elektro] Wakeup Rel-time: " + self.getPrintTime(wakeuptime)
+ print "[Elektro] Sleep Rel-time: " + self.getPrintTime(sleeptime)
+
+
+ #let's see if we should be sleeping
+ trysleep = False
+ if time_s < (wakeuptime - elektroShutdownThreshold): # Wakeup is in the future -> sleep!
+ trysleep = True
+ print "[Elektro] Wakeup!" + str(time_s) + " < " + str(wakeuptime)
+ if sleeptime < time_s : #Sleep is in the past -> sleep!
+ trysleep = True
+ print "[Elektro] Sleep: " + str(sleeptime) + " < " + str(time_s)
+
+ #We are not tying to go to sleep anymore -> maybe go to sleep again the next time
+ if trysleep == False:
+ self.dontsleep = False
+
+ #The User aborted to got to sleep -> Don't go to sleep.
+ if self.dontsleep:
+ trysleep = False
+
+ # If we are in holydaymode we should try to got to sleep anyway
+ # This should be set after self.dontsleep has been handled
+ if config.plugins.elektro.holiday.value:
+ trysleep = True
+
+ # We are not enabled -> Dont go to sleep (This could have been catched earlier!)
+ if config.plugins.elektro.enable.value == False:
+ trysleep = False
+
+ # Only go to sleep if we are in standby or sleep is forced by settings
+ if not ((Standby.inStandby) or (config.plugins.elektro.force.value == True) ):
+ trysleep = False
+
+ # No Sleep while recording
+ if self.session.nav.RecordTimer.isRecording():
+ trysleep = False
+
+ # Will there be a recording in a short while?
+ nextRecTime = self.session.nav.RecordTimer.getNextRecordingTime()
+ if (nextRecTime > 0) and (nextRecTime - (int)(time()) < elektroShutdownThreshold):
+ trysleep = False
+
+ # Looks like there really is a reason to go to sleep -> Lets try it!
+ if trysleep:
+ #self.();
+ try:
+ self.session.openWithCallback(self.DoElektroSleep, MessageBox, _("Go to sleep now?"),type = MessageBox.TYPE_YESNO,timeout = 60)
+ except:
+ #reset the timer and try again
+ self.TimerSleep.startLongTimer(elektrostarttime)
+
+ #set Timer, which calls this function again.
+ self.TimerSleep.startLongTimer(elektrostarttime)
+
+
+
+
+ def DoElektroSleep(self,retval):
+ if (retval):
+ # os.system("wall 'Powermanagent does Deepsleep now'")
+ # Notifications.AddNotification(TryQuitMainloop,1)
+ # 1 = Deep Standby -> enigma2:/doc/RETURNCODES
+
+ global inTryQuitMainloop
+ if Standby.inTryQuitMainloop == False:
+ self.session.open(Standby.TryQuitMainloop, 1) # <- This might not work reliably
+ #quitMainloop(1)
+ else:
+ # Dont try to sleep until next wakeup
+ self.dontsleep = True
+ #Start the timer again
+ self.TimerSleep.startLongTimer(elektrostarttime)
+