Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
from enigma import eServiceReference, eServiceCenter, iServiceInformation, eTimer, iRecordableService, eDVBServicePMTHandler, eEPGCache, iPlayableService
from Plugins.Plugin import PluginDescriptor
from Screens.ChannelSelection import BouquetSelector, ChannelSelection
from Screens.MessageBox import MessageBox
from Components.config import config, ConfigSubsection, ConfigIP, ConfigInteger, ConfigText, getConfigListEntry, ConfigSelection, ConfigOnOff, NoSave
from Components.ConfigList import ConfigListScreen
from Components.ActionMap import ActionMap
from Screens.Screen import Screen
from Components.Sources.StaticText import StaticText
from Components.Label import Label
from time import localtime

import json
from collections import OrderedDict
from Tools.Directories import pathExists, resolveFilename, SCOPE_CONFIG

try:
	from Plugins.Extensions.WebInterface.WebScreens import streamingScreens, streamingEvents, StreamingWebScreen
except:
	streamingScreens = []
	streamingEvents = []

from datetime import datetime
def writelog(text=''):
	print text
	with open('/tmp/streamrelay.log', "a") as fp:
		fp.write('{0} {1}\n'.format(datetime.today().strftime("%d.%m.%Y %H:%M:%S"),text))

def writeerror():
	from traceback import print_exc
	with open('/tmp/streamrelayerror.log', "a") as fp:
		print_exc(file=fp)

icamref = OrderedDict()
icamrefchanged = False
streamrelayconf = {}
streamrelayconf['icamref'] = False
#streamrelayconf['referencefix'] = False
streamrelayconf['streamhost'] = '127.0.0.1'
streamrelayconf['streamport'] = 17999
streamrelayconf['nameadd'] = ''
streamrelayconf['noresources'] = False
streamrelayconf['recordstate'] = False
streamrelayconf['requestfilter'] = False
streamrelayconf['eventupdateonshow'] = False
streamrelayconf['switchrecording'] = False

icamident = {}#{'compare':'','value':''}
icamident['compare'] = ''
icamident['servicestr'] = ''

mainstreamptr = []

ICAMREFDIR = resolveFilename(SCOPE_CONFIG, "icamref.json")
ICAMIDENTDIR = resolveFilename(SCOPE_CONFIG, "icamident.json")
STREAMRELAYCONFDIR = resolveFilename(SCOPE_CONFIG, "streamrelayconf.json")

class srvariabel(object):
	recslen = 0

def writestreamrelayconf():
	if streamrelayconf:
		tmp = {}
		if streamrelayconf['icamref'] != False:
			tmp['icamref'] = streamrelayconf['icamref']
		if streamrelayconf['noresources'] != False:
			tmp['noresources'] = streamrelayconf['noresources']
		#if streamrelayconf['referencefix'] != False:
		#	tmp['referencefix'] = streamrelayconf['referencefix']
		if streamrelayconf['recordstate'] != False:
			tmp['recordstate'] = streamrelayconf['recordstate']
		if streamrelayconf['requestfilter'] != False:
			tmp['requestfilter'] = streamrelayconf['requestfilter']
		if streamrelayconf['eventupdateonshow'] != False:
			tmp['eventupdateonshow'] = streamrelayconf['eventupdateonshow']
		if streamrelayconf['switchrecording'] != False:
			tmp['switchrecording'] = streamrelayconf['switchrecording']
		if streamrelayconf['streamhost'] != '127.0.0.1':
			tmp['streamhost'] = streamrelayconf['streamhost']
		if streamrelayconf['streamport'] != 17999:
			tmp['streamport'] = streamrelayconf['streamport']
		if streamrelayconf['nameadd'] != '':
			tmp['nameadd'] = streamrelayconf['nameadd']
		
		with open(STREAMRELAYCONFDIR, 'w') as fp:
			json.dump(OrderedDict(sorted(tmp.items(), key=lambda x: x[1])), fp, encoding='utf-8', indent=2, sort_keys=False, ensure_ascii=True)

def readstreamrelayconf():
	if pathExists(STREAMRELAYCONFDIR):
		with open(STREAMRELAYCONFDIR) as data_file:
			data = json.load(data_file, encoding='utf-8', object_pairs_hook=OrderedDict)
			if data.get('icamref'):
				streamrelayconf['icamref'] = data['icamref']
			if data.get('noresources'):
				streamrelayconf['noresources'] = data['noresources']
			#if data.get('referencefix'):
			#	streamrelayconf['referencefix'] = data['referencefix']
			if data.get('recordstate'):
				streamrelayconf['recordstate'] = data['recordstate']
			if data.get('requestfilter'):
				streamrelayconf['requestfilter'] = data['requestfilter']
			if data.get('eventupdateonshow'):
				streamrelayconf['eventupdateonshow'] = data['eventupdateonshow']
			if data.get('switchrecording'):
				streamrelayconf['switchrecording'] = data['switchrecording']
			if data.get('streamhost'):
				streamrelayconf['streamhost'] = data['streamhost'].encode('utf-8')
			if data.get('streamport'):
				streamrelayconf['streamport'] = data['streamport']
			if 'nameadd' in data:
				streamrelayconf['nameadd'] = data['nameadd'].encode('utf-8')

def __writeicamref__():
	if icamref and icamrefchanged:
		with open(ICAMREFDIR, 'w') as fp:
			json.dump(OrderedDict(sorted(icamref.items(), key=lambda x: x[1])), fp, encoding='utf-8', indent=2, sort_keys=False, ensure_ascii=True)
	
	try:
		from os import remove as os_remove
		if icamident and icamident['compare']:
			service = None
			from Screens.InfoBar import InfoBar
			if InfoBar.instance:
				service = InfoBar.instance.session.nav.getCurrentlyPlayingServiceReference()
			if service and service.toCompareString() == icamident['compare']:
				with open(ICAMIDENTDIR, 'w') as fp:
					json.dump(OrderedDict(sorted(icamident.items(), key=lambda x: x[1])), fp, encoding='utf-8', indent=2, sort_keys=False, ensure_ascii=True)
			elif pathExists(ICAMIDENTDIR):
				os_remove(ICAMIDENTDIR)
		elif pathExists(ICAMIDENTDIR):
			os_remove(ICAMIDENTDIR)
	except:
		writeerror()
		
def readicamref():
	if pathExists(ICAMREFDIR):
		with open(ICAMREFDIR) as data_file:
			data = json.load(data_file, encoding='utf-8', object_pairs_hook=OrderedDict)
			for key, value in data.items():
				icamref[key] = value
	if pathExists(ICAMIDENTDIR):
		with open(ICAMIDENTDIR) as data_file:
			data = json.load(data_file, encoding='utf-8', object_pairs_hook=OrderedDict)
			if data.get('compare'):
				icamident['compare'] = data['compare'].encode('utf-8')
			if data.get('servicestr'):
				icamident['servicestr'] = data['servicestr'].encode('utf-8')
		from os import remove as os_remove
		os_remove(ICAMIDENTDIR)
		
#ptrdict = dict()
#ptrlist = []
'''
def checkstreaming_ok(stoprecord = False, toremove = False):
	ptrlist = []
	try:
		if streamingScreens:
			for streaming in streamingScreens:
				if streaming.has_key("StreamService"):
					service = streaming["StreamService"].getService()
					if service:
						ptr = service.getPtrString()
						if ptr not in ptrlist:
							#ptrlist.insert(0, ptr)
							ptrlist.append(ptr)
						if stoprecord:
							streaming["StreamService"].navcore.stopRecordService(service)
							streamingScreens.remove(streaming)
				else:
					if toremove:
						streamingScreens.remove(streaming)
	except:
		pass
	return ptrlist[:]
'''

def checkstreaming(stoprecord = False, toremove = False):
	ptrlist = []
	try:
		if streamingScreens:
			for streaming in streamingScreens:
				stream = streaming.get("StreamService")
				if stream:
					service = stream.getService()
					if service:
						ptr = service.getPtrString()
						if ptr not in ptrlist:
							ptrlist.append(ptr)
						if stoprecord:
							if stream.recordEvent in stream.navcore.record_event:
								stream.navcore.record_event.remove(stream.recordEvent)
							if stream._StreamService__service is not None:
								stream.navcore.stopRecordService(stream._StreamService__service)
								stream._StreamService__service = None
							if streaming in streamingScreens:
								streamingScreens.remove(streaming)
				else:
					if toremove:
						streamingScreens.remove(streaming)
	except:
		writeerror()
	return ptrlist[:]
	
def MycheckRecordings(session):
	try:
		recslen = 0
		recslist = session.nav.getRecordings()
		if recslist:
			for recs in recslist:
				if recs.getPtrString() not in mainstreamptr:
					recslen += 1
		return recslen
	except:
		writeerror()
	return len(session.nav.getRecordings())

'''
class repeatzap(Screen):
	skin = """<screen backgroundColor="transparent" name="repeatzap" position="center,center" size="600,500" title="repeatzap" flags="wfNoBorder">
		<eLabel backgroundColor="background" cornerRadius="30" position="0,0" size="600,500" zPosition="-1"/>
		<widget backgroundColor="background" font="Regular;30" name="text" position="50,50" size="500,400" transparent="1" />
	</screen>
	"""
	def __init__(self, session):
		self.skinName = 'repeatzap'
		Screen.__init__(self, session)
		
		self.lastservice = self.session.nav.getCurrentlyPlayingServiceReference()
		self.lastservicestr = self.lastservice.toString()
		self.lastservicestr = self.lastservicestr[:self.lastservicestr.find('http')]
		
		from ServiceReference import ServiceReference
		serviceref = ServiceReference(self.lastservice)
		self.servicerefname = serviceref.getServiceName()
		self.session.nav.stopService()

		text = '{0}\n{1}\n{2}\n{3} {4}'.format(_("stop service"), self.servicerefname, self.lastservicestr, 'streamingScreens len', len(streamingScreens))
		if mainstreamptr:
			text += '\nstreamptr {0}'.format(', '.join(mainstreamptr))
		self["text"] = Label(text)

		self.timer = eTimer()
		self.timer_conn = self.timer.timeout.connect(self.rezapstop)
		self.timer.start(250,True)
		self.timerstate = 0
	
	def rezapstop(self):
		if self.timerstate == 0:
			ptrlistval = checkstreaming()
			#del mainstreamptr[:]
			#del streamingScreens[:]
			#writelog('mainstreamptr {0} '.format(mainstreamptr))
			self["text"].text += '\n{0} {1} {2}'.format(_('Cleanup'), len(ptrlistval), _('Services'))
			service = self.lastservice
			if service and service.getUnsignedData(4) == 33:
				path = service.getPath()
				if path:
					service = eServiceReference('1:0:19:2888:40F:1:C00000:0:0:0:')
					service.setName('{0}'.format('Repeatzap'))
					self.session.nav.playService(service, forceRestart = True)
			self.timerstate += 1
			self.timer.start(500,True)
		elif self.timerstate == 1:
			from Screens.InfoBar import InfoBar
			historylen = len(InfoBar.instance.servicelist.history)
			## mainstreamptr
			del InfoBar.instance.servicelist.history[:]
			InfoBar.instance.servicelist.history_pos = 0
			self["text"].text += '\n{0} {1} {2} {3}'.format(_('Removing'), _('History'), _('Entries'), historylen)
			self.timerstate += 1
			self.timer.start(250,True)
		elif self.timerstate == 2:
			self["text"].text += '\n{0}\n{1}\n{2}'.format(_('Play last movie starting'), self.servicerefname, self.lastservicestr)
			from Screens.InfoBar import InfoBar
			InfoBar.instance.servicelist.zap(self.lastservice)
			self.timerstate += 1
			self.timer.start(250,True)
		else:
			self.timer.stop()
			self.timer_conn = None
			self.close()

'''

'''
class StreamRelayInfo(Screen):
	stream_running = False
	toggleshow = None
	skin___ = """<screen backgroundColor="transparent" name="StreamRelayInfo" position="1600,845" size="200,40" title="StreamRelayInfo" flags="wfNoBorder">
		<eLabel backgroundColor="background" cornerRadius="30" position="0,0" size="200,40" zPosition="-1"/>
		<eLabel backgroundColor="background" font="Regular;24" position="0,0" size="200,40" text="Streaming" valign="center" halign="center" transparent="1"/>
	</screen>
	"""
	skin = """<screen backgroundColor="transparent" name="StreamRelayInfo" position="1540,830" size="140,50" flags="wfNoBorder">
		<eLabel backgroundColor="background" cornerRadius="30" position="0,0" size="140,50" zPosition="-1"/>
		<ePixmap pixmap="/usr/lib/enigma2/python/Plugins/Extensions/StreamRelay/streamingwhite.png" position="20,5" size="100,40" scale="stretch" />
	</screen>
	"""
	
	def __init__(self, session):
		self.skinName = 'StreamRelayInfo'
		Screen.__init__(self, session)
		StreamRelayInfo.toggleshow = self.toggleShow
		
	def toggleShow(self):
		from Screens.InfoBar import InfoBar
		if self.stream_running and InfoBar.instance._InfoBarShowHide__state == InfoBar.instance.STATE_SHOWN:
			self.show()
		else:
			self.hide()
'''

class StreamRelaySetup(Screen, ConfigListScreen):
	skin = """
		<screen name="StreamRelaySetup" position="center,170" size="1200,820" title="Setup">
		<layout name="Button_Small"/>
		<layout name="Button_Small_source"/>
		<widget enableWrapAround="1" name="config" position="10,90" scrollbarMode="showOnDemand" size="1180,720"/>
		</screen>"""
	
	def __init__(self, session):
		
		Screen.__init__(self, session)
		self.skinName = "StreamRelaySetup"
		ConfigListScreen.__init__(self, [], session=session)

		self["key_red"] = StaticText(_("Cancel"))
		self["key_green"] = StaticText(_("Save"))
		self["key_blue"] = StaticText(_("Reset"))
		self["key_yellow"] = StaticText(_("Repeatzap"))
		
		self["actions"] = ActionMap(["SetupActions", "ColorActions", "InfobarActions", "ChannelSelectEPGActions"],
			{
				"cancel": self.keyCancel,
				"red": self.keyCancel,
				"blue": self.keyblue,
				"yellow": self.keyyellow,
				"save": self.keySave,
				"showMovies": self.keykey_1,
				"showTv": self.keykey_2,
				"showRadio": self.keykey_3,
				"showEPGList": self.StreamrelayInfo,
			})
			
		self.settings = ConfigSubsection()
		self.settings.icamref = NoSave(ConfigOnOff(default = streamrelayconf['icamref']))
		self.settings.noresources = NoSave(ConfigOnOff(default = streamrelayconf['noresources']))
		#self.settings.referencefix = NoSave(ConfigOnOff(default = streamrelayconf['referencefix']))
		self.settings.recordstate = NoSave(ConfigOnOff(default = streamrelayconf['recordstate']))
		self.settings.requestfilter = NoSave(ConfigOnOff(default = streamrelayconf['requestfilter']))
		self.settings.eventupdateonshow = NoSave(ConfigOnOff(default = streamrelayconf['eventupdateonshow']))
		self.settings.switchrecording = NoSave(ConfigOnOff(default = streamrelayconf['switchrecording']))
		#self.settings.streamhost = NoSave(ConfigIP(default = streamrelayconf['streamhost'].split('.'), auto_jump=True))
		self.settings.streamhost = NoSave(ConfigText(default = streamrelayconf['streamhost'], fixed_size=False))
		self.settings.streamport = NoSave(NoSave(ConfigInteger(default=streamrelayconf['streamport'], limits=(1, 65555))))
		self.settings.nameadd = NoSave(ConfigText(default = streamrelayconf['nameadd'], fixed_size=False))
		
		self.changeicamref = streamrelayconf['icamref']
		self.changenoresources = streamrelayconf['noresources']
		self.changerecordstate = streamrelayconf['recordstate']
		self.changerequestfilter = streamrelayconf['requestfilter']
		self.changeeventupdateonshow = streamrelayconf['eventupdateonshow']
		self.onLayoutFinish.append(self.firststart)
		self.helpwin = None
		self._createSetup()
	
	def KeyText(self):
		curr = self["config"].getCurrent()
		if curr and isinstance(curr[1], ConfigText):
			ConfigListScreen.KeyText(self)
			
	'''def keyLeft(self):
		ConfigListScreen.keyLeft(self)
		curr = self["config"].getCurrent()
		if curr and curr[1] == self.settings.referencefix:
			self._createSetup()
	
	def keyRight(self):
		ConfigListScreen.keyRight(self)
		curr = self["config"].getCurrent()
		if curr and curr[1] == self.settings.referencefix:
			self._createSetup()'''
		
	def firststart(self):
		self.setTitle("Stream Relay " + _("Setup"))
		
	def _createSetup(self):
		entries = []
		entries.append(getConfigListEntry('Stream Host ' + _('Default') + ' (127.0.0.1)', self.settings.streamhost))
		entries.append(getConfigListEntry('Stream Port ' + _('Default') + ' (17999)', self.settings.streamport))
		entries.append(getConfigListEntry('Name ' + _('advanced'), self.settings.nameadd))
		entries.append(getConfigListEntry(_('No free tuner!') + ' ' + ' / ' + _('Channel Selection') + ' ' + _('Color') + ' ' + _("disable"), self.settings.noresources))
		entries.append(getConfigListEntry(_('Record') + ' ' + _('blinking') + ' ' + _("disable"), self.settings.recordstate))
		entries.append(getConfigListEntry(_('request pmt error filter') + ' ' + _("enable"), self.settings.requestfilter))
		entries.append(getConfigListEntry(_('Event update Infobar onshow and EPG filter') + ' ' + _("enable"), self.settings.eventupdateonshow))
		entries.append(getConfigListEntry(_('Automatically switch recording if necessary') + '. ' + _('no support timer plausibility check') + ' ' + _("enable"), self.settings.switchrecording))
		#entries.append(getConfigListEntry('Auto Convert icamref / ' + _('Namespace') + ' (ID=33 / 0x21)', self.settings.icamref))
		entries.append(getConfigListEntry('Auto Convert icamref' + ' ' + _('enable'), self.settings.icamref))
		'''if self.settings.referencefix.value:
			#entries.append(getConfigListEntry(_('Service') + ' ' + _('Type') + '=1 ' + _('Transponder') + ' (ID=11 / 0xB) ' + _('Network') + ' (ID=22 / 0x16)', self.settings.referencefix))
			entries.append(getConfigListEntry(_('Service reference') + ' 1:0:1:xxxx:B:16:21:0:0:0:' , self.settings.referencefix))
		else:
			entries.append(getConfigListEntry(_('Service reference') + ' 1:0:x:xxxx:x:xx:21:0:0:0:' , self.settings.referencefix))'''
		self["config"].list = entries
		
	def keySave(self):
		if self["config"].isChanged():
			streamrelayconf['icamref'] = self.settings.icamref.value
			streamrelayconf['noresources'] = self.settings.noresources.value
			streamrelayconf['recordstate'] = self.settings.recordstate.value
			streamrelayconf['requestfilter'] = self.settings.requestfilter.value
			streamrelayconf['eventupdateonshow'] = self.settings.eventupdateonshow.value
			streamrelayconf['switchrecording'] = self.settings.switchrecording.value
			streamrelayconf['streamhost'] = self.settings.streamhost.getText()
			streamrelayconf['streamport'] = self.settings.streamport.value
			streamrelayconf['nameadd'] = self.settings.nameadd.getText()
			#if self.settings.icamref.value:
			#streamrelayconf['referencefix'] = self.settings.referencefix.value
			#else:
			#	streamrelayconf['referencefix'] = False
			
			writestreamrelayconf()
			#if (self.changeicamref != streamrelayconf['icamref']) or (self.changenoresources != streamrelayconf['noresources']) \
			#or (self.changerecordstate != streamrelayconf['recordstate']) or (self.changerequestfilter != streamrelayconf['requestfilter']) \
			#or (self.changeeventupdateonshow != streamrelayconf['eventupdateonshow']):
			restartbox = self.session.openWithCallback(self.restartGUI, MessageBox,_("GUI needs a restart to apply the new settings.\nDo you want to Restart the GUI now?"), MessageBox.TYPE_YESNO)
			restartbox.setTitle(_("Restart GUI now?"))
			#else:
			#	self.close(True)
		else:
			self.close(False)
	
	def keyblue(self):
		self.settings.streamhost.value = '127.0.0.1'
		self.settings.streamport.value = 17999
		self.settings.noresources.value = False
		self.settings.requestfilter.value = False
		self.settings.eventupdateonshow.value = False
		self.settings.recordstate.value = False
		self.settings.switchrecording.value = False
		self.settings.icamref.value = False
		self.settings.nameadd.value = ''
		self._createSetup()
	
	def keyyellow(self):
		#curr = self["config"].getCurrent()
		#if curr and getattr(curr[1], 'help_window', None):
		#	helpwin = self._getHelpWindow()
		#	if helpwin:
		#		helpwin.hide()
		#self.session.open(repeatzap)
		service = self.session.nav.getCurrentlyPlayingServiceReference()
		if service:
			self.session.nav.playService(service, forceRestart = True)
		self.close(True)
		
	def keykey_1(self):
		self.settings.streamhost.value = '127.0.0.1'
		self._createSetup()
		
	def keykey_2(self):
		self.settings.streamhost.value = '192.168.2.124'
		self._createSetup()
		
	def keykey_3(self):
		self.settings.streamhost.value = '192.168.2.129'
		self._createSetup()
		
	def restartGUI(self, answer):
		if answer:
			from Screens.Standby import TryQuitMainloop
			self.session.open(TryQuitMainloop, 3)
			#from twisted.internet import reactor
			#reactor.callLater(1, self.session.open, TryQuitMainloop, 3)
		self.close(True)

	def StreamrelayInfo(self):
		self.helpwin = None
		curr = self["config"].getCurrent()
		if curr and getattr(curr[1], 'help_window', None):
			self.helpwin = self._getHelpWindow()
			if self.helpwin:
				self.helpwin.hide()
		
		#service = self.session.nav.getCurrentlyPlayingServiceReference()
		#info = eServiceCenter.getInstance().info(service)
		service = self.session.nav.getCurrentService()
		info = service and service.info()
		name = info and info.getName().replace('\xc2\x86', '').replace('\xc2\x87', '')
		sserviceref = info and info.getInfoString(iServiceInformation.sServiceref)
	
		text = '{0}\n{1}\n'.format(name, sserviceref.replace('%3a',':'))
		#text = '{0}\n{1}\n'.format(name, service.toString().replace('%3a',':'))
		#if mainstreamptr:
		text += 'mainstreamptr len ({0}) ptr {1}\n'.format(len(mainstreamptr),', '.join(mainstreamptr))
		ptrlistval = checkstreaming()
		text += 'checkstreaming len ({0}) ptr {1}\n'.format(len(ptrlistval), ', '.join(ptrlistval))
		text += 'streamingScreens len ({0})\n'.format(len(streamingScreens))
		text += 'streamingEvents len ({0})\n'.format(len(streamingEvents))
		text += 'MycheckRecordings ({0})\n'.format(MycheckRecordings(self.session))
		recslist = self.session.nav.getRecordings()
		recsptr = []
		for recs in recslist:
			if recs:
				recsptr.append(recs.getPtrString())
		text += 'getRecordings len ({0}) ptr {1}\n'.format(len(recslist), ', '.join(recsptr))
		import NavigationInstance
		if NavigationInstance.instance:
			recslistpnav = NavigationInstance.instance.pnav and NavigationInstance.instance.pnav.getRecordings(False)
			recsptrpnav = []
			for recs in recslistpnav:
				if recs:
					recsptrpnav.append(recs.getPtrString())
			text += 'pnav.getRecordings len ({0}) ptr {1}\n'.format(len(recslistpnav), ', '.join(recsptrpnav))
		#writelog('{0}{1}'.format(text, '#'*50))
		recservice = getRecordableServicePtr()
		if recservice:
			streaming = recservice.stream()
			#frontendinfo = recservice.frontendInfo().getFrontendData()
		else:
			streaming = service.stream()
			#frontendinfo = service.frontendInfo().getFrontendData()
		streamingdata = streaming and streaming.getStreamingData()
		#pids = s and s.get("pids", [] )
		#demux = s and s.get("demux", None)
		#pidsstr = ','.join(["%x:%s" % (x[0], x[1]) for x in pids])
		if streamingdata:
			pids = streamingdata and streamingdata.get("pids", [] )
			demux = streamingdata and streamingdata.get("demux", None)
			text += 'demuxer ({})  pids len ({})\npids {}\n'.format(demux, len(pids), pids)
		
		#frontendinfo = service.frontendInfo().getAll(True)
		#if frontendinfo:
		#	text += 'FrontendData\n{}\n'.format(frontendinfo)
		#writelog('\n{0}\n{1}\n{2}'.format('#'*80, text, '#'*80))
		self.session.openWithCallback(self.MessageBoxCallback, MessageBox, text, MessageBox.TYPE_INFO, title='Streamrelay' + ' ' + _('Information'))
		#if helpwin:
		#	helpwin.show()
	def MessageBoxCallback(self,res=None):
		if self.helpwin:
			self.helpwin.show()
def addicambouquet(session, service, csel, **kwargs):
	if service and csel:
		def bouquetCallback(bouquet):
			_result_ = getattr(csel, '_addicambouquetresult_', None)
			if _result_:
				name = _result_[0]
				servicestr = _result_[1]
				delattr(csel, '_addicambouquetresult_')
				
				if streamrelayconf['nameadd']:
					name += ' ' + streamrelayconf['nameadd']
				
				'''service.type = 1
				if streamrelayconf['referencefix']:
					service.setUnsignedData(0, 1)
					service.setUnsignedData(2, 11)
					service.setUnsignedData(3, 22)'''
			
				service.setUnsignedData(4, 33)
				service.setName('{0}'.format(name))
				service.setPath('http://{0}:{1}/{2}'.format(streamrelayconf['streamhost'], streamrelayconf['streamport'], servicestr))
				if isinstance(service, eServiceReference):
					csel.addServiceToBouquet(bouquet, service=service)
					from ServiceReference import ServiceReference
					serviceref = ServiceReference(bouquet)
					def messCallback(val=None):
						bouquetSel.close()

					servicestr = service.toString()
					servicestr = servicestr[:servicestr.find('http')]
					text = '{0}\n\n{1} {2}\n{3} {4}\n{5} {6}'.format(_("Added: "), _('Bouquet'), serviceref.getServiceName(), _('Channel'), name, _('Service reference'), servicestr)
					session.openWithCallback(messCallback, MessageBox, text, MessageBox.TYPE_INFO, timeout=3)
			
		bouquets = csel.getBouquetList()
		bouquetSel = session.open(BouquetSelector, bouquets, bouquetCallback, enableWrapAround=True)

def addicambouquethelperfnc(csel):
	if csel and csel.movemode == False:
		try:
			service = csel.getCurrentSelection()
			if service:
				serviceHandler = eServiceCenter.getInstance()
				info = serviceHandler.info(service)
				if info and info.getInfo(service, iServiceInformation.sIsCrypted) == 1:
					name = (info.getName(service) or "<n/a>").replace('\xc2\x86', '').replace('\xc2\x87', '')
					servicestr = service.toString()
					if servicestr:
						setattr(csel, '_addicambouquetresult_', (name, servicestr))
						return True
		except:
			return False
	return False
	
def addicamrefhelperfnc(csel):
	if csel and csel.movemode == False and streamrelayconf['icamref']:
		try:
			service = csel.getCurrentSelection()
			if service:
				serviceHandler = eServiceCenter.getInstance()
				info = serviceHandler.info(service)
				if info and info.getInfo(service, iServiceInformation.sIsCrypted) == 1:
					name = (info.getName(service) or "<n/a>").replace('\xc2\x86', '').replace('\xc2\x87', '')
					servicestr = service.toString()
					if servicestr:
						setattr(csel, '_icamresult_', {servicestr:name})
						return True
		except:
			return False
	return False
	
def addicamref(session, service, csel, **kwargs):
	if service and csel:
		_icamresult_ = getattr(csel, '_icamresult_', None)
		if _icamresult_:
			global icamrefchanged
			icamrefchanged = True
			
			name = _icamresult_.values()[0]
			servicestr = _icamresult_.keys()[0]
			
			if servicestr and servicestr in icamref:
				del icamref[servicestr]
				textvalu = _('Removed successfully.')
			else:
				icamref.update(_icamresult_)
				textvalu = _('Added: ')
			delattr(csel, '_icamresult_')
			text = '{0}\n\n{1} {2}\n{3} {4}'.format(textvalu, _('Channel'), name, _('Service reference'), servicestr)
			session.open(MessageBox, text, MessageBox.TYPE_INFO, timeout=3)
	
def infobarstart(session, **kwargs):
	
	from Screens.InfoBar import InfoBar
	'''if InfoBar.instance and streamrelayconf['recordstate']:
		StreamRelayInfoinstantiateDialog = session.instantiateDialog(StreamRelayInfo, zPosition=-1)
		StreamRelayInfoinstantiateDialog.neverAnimate()
		InfoBar.instance.onShow.append(StreamRelayInfoinstantiateDialog.toggleShow)
		InfoBar.instance.onHide.append(StreamRelayInfoinstantiateDialog.hide)'''
	if InfoBar.instance and streamrelayconf['eventupdateonshow']:
		InfoBar._eventupdateonshow_ = _eventupdateonshow_
		InfoBar.instance.onShow.append(InfoBar.instance._eventupdateonshow_)
	
	if InfoBar.instance and streamrelayconf['noresources']:
		InfoBar._my_doReconnect_ = _my_doReconnect_
		InfoBar._my_reconnTimer = eTimer()
		InfoBar._my_reconnTimer_conn = InfoBar._my_reconnTimer.timeout.connect(InfoBar.instance._my_doReconnect_)
	
	if InfoBar.instance and streamrelayconf['icamref']:
		InfoBar.instance.onClose.append(__writeicamref__)
		orizap = ChannelSelection.zap
		#orizap = InfoBar.instance.servicelist.zap
		serviceHandler = eServiceCenter.getInstance()
	
		def convertref(nref, name, servicestr):
			if streamrelayconf['nameadd']:
				name += ' ' + streamrelayconf['nameadd']
			'''nref.type = 1
			if streamrelayconf['referencefix']:
				nref.setUnsignedData(0, 1)
				nref.setUnsignedData(2, 11)
				nref.setUnsignedData(3, 22)'''
			
			nref.setUnsignedData(4, 33)
			nref.setName('{0}'.format(name))
			nref.setPath('http://{0}:{1}/{2}'.format(streamrelayconf['streamhost'], streamrelayconf['streamport'], servicestr))
			
			icamident['compare'] = nref.toCompareString()
			icamident['servicestr'] = servicestr
			
		def zap(self, nref=None, root=None):
		#def zap(nref=None, root=None):
			if not nref:
				nref = self.getCurrentSelection()
				#nref = InfoBar.instance.servicelist.getCurrentSelection()
				if nref:
					info = serviceHandler.info(nref)
					if info:
						#if streamingScreens:
						#	checkstreaming()
						if info.getInfo(nref, iServiceInformation.sIsCrypted) == 1:
							servicestr = nref.toString()
							if servicestr and icamref and servicestr in icamref:
								#name = (icamref[servicestr] and icamref[servicestr].encode('utf-8')) or (info.getName(nref) or "<n/a>").replace('\xc2\x86', '').replace('\xc2\x87', '') or '<n/a>'
								name = (info.getName(nref) or "").replace('\xc2\x86', '').replace('\xc2\x87', '') or (icamref[servicestr] and icamref[servicestr].encode('utf-8')) or '<n/a>'
								#self.setCurrentSelection(eServiceReference(servicestr))
								convertref(nref, name, servicestr)
								#self.setCurrentSelection(nref)
								#writelog('zap {0} {1}'.format(name, servicestr))
								#InfoBar.instance.session.nav.stopService()
							else:
								icamident.clear()
			orizap(self, nref, root)
			#orizap(nref, root)
		
		readicamref()
		ChannelSelection.zap = zap
		#InfoBar.instance.servicelist.zap = zap

def setup(session, **kwargs):
	session.open(StreamRelaySetup)

def openrepeatzap(session, **kwargs):
	service = session.nav.getCurrentlyPlayingServiceReference()
	if service:
		session.nav.playService(service, forceRestart = True)
	#session.open(repeatzap)
	
def Plugins(path, **kwargs):
	return [
		PluginDescriptor(
			name="Stream Relay " + _("Repeatzap"),
			description="Stream Relay " + _("Repeatzap"),
			where = PluginDescriptor.WHERE_EXTENSIONSMENU,
			fnc=openrepeatzap,
			icon="plugin.png"),
		PluginDescriptor(
			name=_("add service to bouquet") + ' (ICAM)',
			description=_("add service to bouquet") + ' (ICAM)',
			where = PluginDescriptor.WHERE_CHANNEL_CONTEXT_MENU,
			fnc=addicambouquet,
			helperfnc=addicambouquethelperfnc,
			weight=24),
		PluginDescriptor(
			name=_('Add') + ' / ' + _("Remove") + ' (ICAMREF)',
			description=_('Add') + ' / ' + _("Remove") + ' (ICAMREF)',
			where = PluginDescriptor.WHERE_CHANNEL_CONTEXT_MENU,
			fnc=addicamref,
			helperfnc=addicamrefhelperfnc,
			weight=25),
		PluginDescriptor(
			name="Stream Relay " + _("Setup"),
			description="Stream Relay " + _("Setup"),
			where = PluginDescriptor.WHERE_PLUGINMENU,
			fnc=setup,
			icon="plugin.png"),
		PluginDescriptor(
			where = PluginDescriptor.WHERE_INFOBAR,
			fnc=infobarstart,
			needsRestart = True,
			weight=1000)
		]
		
#########################################################
readstreamrelayconf()

'''
def serviceEvent_ok(event, self):
	try:
		if event == 1:
			if self.has_key("StreamService"):
				eventservice = self.getRecordServiceRef()
				if eventservice:
					eventservice = self.getRecordServiceRef().toCompareString()
					for streaming in streamingScreens:
						if streaming.has_key("StreamService"):
							streamingservice = self.getRecordServiceRef()
							if streamingservice:
								streamingservice = self.getRecordServiceRef().toCompareString()
								if eventservice == streamingservice:
									streamingScreens.remove(streaming)
	except:
		writeerror()
'''

def serviceEvent(event, self):
	try:
		if event == 1:
			eventstream = self.get("StreamService")
			if eventstream and eventstream.ref:
				eventstreamcompare = eventstream.ref.toCompareString()
				if eventstreamcompare:
					for streaming in streamingScreens:
						stream = streaming.get("StreamService")
						if stream and stream.ref:
							if eventstreamcompare == stream.ref.toCompareString():
								streamingScreens.remove(streaming)
			try:
				if not self.request._disconnected:
					writelog('self.request._disconnected {0}'.format(self.request._disconnected))
					self.request.write(b"<html><body>Sorry to keep you waiting.</body></html>")
					self.request.finish()
			except:
				writeerror()
	except:
		writeerror()

#if streamrelayconf.get('icamref', None) or streamrelayconf.get('recordstate', None):
#	if serviceEvent not in streamingEvents:
#		streamingEvents.append(serviceEvent)

'''
def gotRecordEvent_timer_list(self, service, event):
	try:
		prev_records = self.records_running
		if event in [iRecordableService.evNewEventInfo, iRecordableService.evEnd, None]:
			recordres = 0
			if service:
				recslist = self.session.nav.getRecordings()
				if recslist:
					for timer in self.session.nav.RecordTimer.timer_list:
						if timer.state == TimerEntry.StateRunning and not timer.justplay and hasattr(timer, "Filename"):
							recordres += 1
						
			self.records_running = recordres
			if self.records_running != prev_records:
				self.changed((self.CHANGED_ALL,))
	except:
		writeerror()
			
def gotRecordEvent_streamingptr(self, service, event):
	try:
		prev_records = self.records_running
		if event in [iRecordableService.evNewEventInfo, iRecordableService.evEnd, None]:
			recslen = 0
			if service:
				recslist = self.session.nav.getRecordings()
				if recslist:
					streamingptr = checkstreaming()
					#recslistptr = []
					for x in recslist:
						recsptr = x.getPtrString()
						#recslistptr.append(recsptr)
						if recsptr not in streamingptr:
							recslen += 1
						
			self.records_running = recslen
			if self.records_running != prev_records:
				self.changed((self.CHANGED_ALL,))
	except:
		writeerror()

def getstreamingdata(serviceptr, event=0):
	try:
		for webscreen in streamingScreens:
			stream = webscreen.get("StreamService")
			if stream:
				#writelog('event {0} {1}'.format('0', stream))
				#writelog('stream {0}'.format(dir(stream)))
				#writelog('stream.getService {0}'.format(dir(stream.getService())))
				
				#writelog('stream.getService.stream() {0}'.format(stream.getService().stream().getStreamingData()))
				service = stream.getService()
				retval = ''
				if service is None:
					retval = "-NO SERVICE\n"
				
				elif service:
					if serviceptr == service.getPtrString():
					#if serviceptr == 'huhu':
						#writelog('event {0} ptr {1}'.format(event, service.getPtrString()))
						streaming = service.stream()
						#s = stream.getService().stream().getStreamingData()
						s = streaming and streaming.getStreamingData()
						pids = s and s.get("pids", [] )
						demux = s and s.get("demux", None)
					
						if not s or not pids or demux is None:
							err = service.getError()
							if err:
								retval = "-SERVICE ERROR:%d\n" % err
							else:
								retval = "=NO STREAM\n"
						else:
						#if retval == '':
							pids = ','.join(["%x:%s" % (x[0], x[1]) for x in pids])
							retval = "+%d:%s\n" % (demux, pids)
				
				if retval:
					webscreen.request.write(retval)
					writelog('event {0} retval {1}'.format(event, retval))
				
						#writelog('webscreen {0}'.format(dir(webscreen)))
						#writelog('webscreen.request {0}'.format(dir(webscreen.request)))
						#writelog('webscreen.request.args {0}'.format(webscreen.request.args))
	except:
		writeerror()
'''

def gotRecordEvent(self, service, event):
	try:
		#writelog('event {0} mainstreamptr {1} getRecordings {2} MycheckRecordings {3}'.format(event, mainstreamptr, len(self.session.nav.getRecordings()), MycheckRecordings(self.session)))
		prev_records = self.records_running
		if event in [iRecordableService.evNewEventInfo, iRecordableService.evEnd, None]:
			recslen = 0
			if service:
				#if event == iRecordableService.evNewEventInfo and streamingScreens:
				#	getstreamingdata(service.getPtrString(), event)
				recslen = MycheckRecordings(self.session)
				#recslist = self.session.nav.getRecordings()
				#if recslist:
				#	for x in recslist:
				#		if x.getPtrString() not in mainstreamptr:
				#			recslen += 1
						
			self.records_running = recslen
			if self.records_running != prev_records:
				self.changed((self.CHANGED_ALL,))
	except:
		writeerror()

def getRecordings(self, simulate=False):
	try:
		streamingptr = checkstreaming()
		#writelog('streamingptr {0}'.format(streamingptr))
		if streamingptr:
			recslist = self.pnav and self.pnav.getRecordings(simulate)
			if recslist:
				recsres = []
				for recs in recslist:
					#recsptr = recs.getPtrString()
					if recs.getPtrString() not in streamingptr:
						recsres.append(recs)
				#writelog('getRecordings {0}'.format(recsres))
				return recsres
				
		#else:
		#return self.pnav and self.pnav.getRecordings(simulate)
	except:
		writeerror()
	
	return self.pnav and self.pnav.getRecordings(simulate)
	
def execBegin(self):
	try:
		ori_execBegin(self)
		#writelog('execBegin {0} {1}'.format(mainstreamptr, self.request))
		_service_ = self.getService()
		if _service_:
			#self.request.write(getstreamingdata__(_service_))
			mainstreamptr.append(_service_.getPtrString())
			#writelog('execBegin {0} {1}'.format(mainstreamptr, self.ref.toString()))
	except:
		writeerror()


def execEnd(self):
	try:
		_service_ = self.getService()
		if _service_:
			ptr = _service_.getPtrString()
			#writelog('execEnd start mainstreamptr {0} ptr {1}  {2}'.format(mainstreamptr, ptr, self.ref.toString()))
			if ptr in mainstreamptr:
				mainstreamptr.remove(ptr)
			#writelog('execEnd stop mainstreamptr {0} ptr {1}  {2}'.format(mainstreamptr, ptr, self.ref.toString()))
		ori_execEnd(self)
	except:
		writeerror()
		
if streamrelayconf.get('recordstate', None):

	#ori_execBegin = getattr(StreamService, 'execBegin', None)
	#delattr(StreamService, 'execBegin')
	#setattr(StreamService, 'execBegin', execBegin)
	#if serviceEvent not in streamingEvents:
	#	streamingEvents.append(serviceEvent)
	
	#############################
	from Components.Sources.StreamService import StreamService
	from Components.Sources.RecordState import RecordState
	ori_execBegin = StreamService.execBegin
	StreamService.execBegin = execBegin
	
	ori_execEnd = StreamService.execEnd
	StreamService.execEnd = execEnd
	RecordState.gotRecordEvent = gotRecordEvent
	#############################
	try:
		from Components.FrontPanelLed import FrontPanelLed
		def checkRecordings(self, service=None, event=iRecordableService.evNewEventInfo):
			if not self._session:
				return
			if event in [iRecordableService.evNewEventInfo, iRecordableService.evEnd]:
				recordings = MycheckRecordings(self._session)
				if recordings:
					FrontPanelLed.recording()
					#writelog('event {0} MycheckRecordings FrontPanelLed.recording()'.format(event))
				else:
					FrontPanelLed.stopRecording()
					#writelog('event {0} MycheckRecordings FrontPanelLed.stopRecording()'.format(event))
		FrontPanelLed.checkRecordings = checkRecordings
		##from API import api
		##api.setSession(session)
		#from API import session
		#from Components.FrontPanelLed import frontPanelLed
		#frontPanelLed.init(session)
	except:
		pass
		#writeerror()
	#############################
	#from Navigation import Navigation
	#ori_getRecordings = Navigation.getRecordings
	#Navigation.getRecordings = getRecordings
	#############################

def setCurrentSelection(self, service):
	try:
		if icamident and service and service.getUnsignedData(4) == 33:
			if 'compare' in icamident and icamident['compare'] == service.toCompareString():
				service = eServiceReference(icamident['servicestr'])
	except:
		writeerror()
	
	self.servicelist.setCurrent(service)

def MyStreamingWebScreenexecBegin(self):
	try:
		writelog('MyStreamingWebScreenexecBegin {0}'.format(self["StreamService"]))
		StreamingWebScreenexecBegin(self)
		#writelog('MyStreamingWebScreenexecBegin {0}'.format(dir(self)))
		writelog('MyStreamingWebScreenexecBegin {0}'.format(self["StreamService"]))
	except:
		writeerror()

def MyStreamingWebScreenexecEnd(self):
	try:
		StreamingWebScreenexecEnd(self)
		if self in streamingScreens:
			#writelog('streamingScreens.remove {0}'.format('True'))
			streamingScreens.remove(self)
		#else:
		#	writelog('streamingScreens.remove {0}'.format('False'))
	except:
		writeerror()
		
if streamrelayconf.get('icamref', None):
	#if serviceEvent not in streamingEvents:
	#	streamingEvents.append(serviceEvent)
	from Screens.ChannelSelection import ChannelSelectionBase
	ChannelSelectionBase.setCurrentSelection = setCurrentSelection

if streamrelayconf.get('icamref', None) or streamrelayconf.get('recordstate', None):
	StreamingWebScreenexecEnd = StreamingWebScreen.execEnd
	StreamingWebScreen.execEnd = MyStreamingWebScreenexecEnd
	#StreamingWebScreenexecBegin = StreamingWebScreen.execBegin
	#StreamingWebScreen.execBegin = MyStreamingWebScreenexecBegin
	
@staticmethod
def getPngName(ref, nameCache, findPicon):
	try:
		if ref and 'B:16:21' in ref:
			refstr = ref[ref.rfind('/')+1:ref.rfind(':')]
			ref = refstr.replace('%3a',':')
	except:
		writeerror()
	return ori_getPngName(ref, nameCache, findPicon)

'''
if streamrelayconf.get('referencefix', None):
	from Tools.PiconResolver import PiconResolver
	ori_getPngName = PiconResolver.getPngName
	PiconResolver.getPngName = getPngName'''

def _my_doReconnect_(self):
	try:
		if self._currentRef:
			#writelog('_my_doReconnect_ {0}'.format(self._currentRef.toString()))
			self.session.nav.playService(self._currentRef, forceRestart=True)
	except:
		writeerror()
		
def __tuneFailed(self):
	try:
		service = self.session.nav.getCurrentService()
		info = service and service.info()
		error = info and info.getInfo(iServiceInformation.sDVBState)
		namespace = info and info.getInfo(iServiceInformation.sNamespace)
		#name = (info.getName() or "<n/a>").replace('\xc2\x86', '').replace('\xc2\x87', '')
		#writelog('error {0} service {1}'.format(error, name))
		
		if error == self.last_error:
			error = None
		else:
			self.last_error = error
		#if error in [eDVBServicePMTHandler.eventNoResources, eDVBServicePMTHandler.eventTuneFailed, eDVBServicePMTHandler.eventNoPAT]:
		if (self._isReconnect == False and error == eDVBServicePMTHandler.eventNoResources and namespace != 33) or \
		   (self._isReconnect == False and error in [eDVBServicePMTHandler.eventNoPATEntry, eDVBServicePMTHandler.eventNoPAT] and namespace == 33):
		
		#if self._isReconnect == False and (error in [eDVBServicePMTHandler.eventNoResources]) and namespace != 33:
			#if streamingScreens:
			#	checkstreaming()
			#self._isReconnect = True
			#self._reconnTimer.startLongTimer(1)
			#name = (info.getName() or "<n/a>").replace('\xc2\x86', '').replace('\xc2\x87', '')
			#self.setPlaybackState(self.MESSAGE_WAIT, name + ' ' +  _('Rezap'))
			restarttime = 1000
			if namespace == 33:
				if error != eDVBServicePMTHandler.eventNoPAT:
					restarttime = 2500
				
				self.setPlaybackState(self.STATE_RECONNECTING, self.MESSAGE_WAIT)
			self._my_reconnTimer.start(restarttime, True)
			#writelog('_reconnTimer.start {0}'.format(restarttime))
		else:
			self.last_error = None
			ori__tuneFailed(self)
	except:
		writeerror()

def setPlayableIgnoreService(self, ref):
	try:
		if ref and ref.getUnsignedData(4) == 33:
			path = ref.getPath()
			if path:
				pos = path.rfind('/')
				if pos != -1:
					refstr = path[pos+1:]
					ref = eServiceReference(refstr)
	except:
		writeerror()
		
	self.is_playable_ignore = ref

def handleCommand(self, cmd):
	try:
		print "StreamService handle command", cmd
		mycmd = eServiceReference(cmd)
		mycmd.setSuburi(cmd)
		sid = mycmd.getUnsignedData(1)
		tsid = mycmd.getUnsignedData(2)
		mycmd.setUnsignedData(5, sid)
		mycmd.setUnsignedData(6, tsid)
		
		self.ref = mycmd
	
	except:
		writeerror()

			
if streamrelayconf.get('noresources', None):
	#from Screens.InfoBar import InfoBar
	#InfoBar._my_doReconnect_ = _my_doReconnect_
	#InfoBar._my_reconnTimer = eTimer()
	#InfoBar._my_reconnTimer_conn = InfoBar._my_reconnTimer.timeout.connect(InfoBar._my_doReconnect_)
	#InfoBar.instance._my_reconnTimer.start(1000, True)
	#from Components.Sources.StreamService import StreamService
	#StreamService.handleCommand = handleCommand
		
	from Screens.InfoBarGenerics import InfoBarServiceErrorPopupSupport
	from Components.ServiceList import ServiceList
	ori__tuneFailed = InfoBarServiceErrorPopupSupport._InfoBarServiceErrorPopupSupport__tuneFailed
	InfoBarServiceErrorPopupSupport._InfoBarServiceErrorPopupSupport__tuneFailed = __tuneFailed
	ServiceList.setPlayableIgnoreService = setPlayableIgnoreService

def _eventupdateonshow_(self):
	try:
		if self.execing and self.shown:
			if self.session.screen.has_key('Event_Now'):
				self.session.screen['Event_Now'].gotEvent(iPlayableService.evUpdatedEventInfo)
			if self.session.screen.has_key('Event_Next'):
				self.session.screen['Event_Next'].gotEvent(iPlayableService.evUpdatedEventInfo)
	except:
		writeerror()
		
def getSimilarEvents(self):
	try:
		refstr = str(self.currentService)
		id = self.event.getEventId()
		epgcache = eEPGCache.getInstance()
		ret = epgcache.search(('NBIR', 100, eEPGCache.SIMILAR_BROADCASTINGS_SEARCH, refstr, id))
		if ret is not None:
			ret1 = []
			for x in ret:
				if "-1:0:0" not in x[3]:
					ret1.append(x[:2])
			#if ret1:
			ret = ret1
			if ret:
				descr = self["epg_description"]
				text = descr.getText()
				text += '\n\n' + _('Similar broadcasts:')
				
				ret.sort(self.sort_func)
				for x in ret:
					t = localtime(x[1])
					text += '\n%d.%d.%d, %02d:%02d  -  %s'%(t[2], t[1], t[0], t[3], t[4], x[0])
				descr.setText(text)
				self["key_red"].setText(_("Similar"))
	except:
		writeerror()

def fillSimilarList(self, refstr, event_id):
	try:
		if event_id is None:
			return
		self.list = self.epgcache.search(('RIBDN', 1024, eEPGCache.SIMILAR_BROADCASTINGS_SEARCH, refstr, event_id))
		ret1 = []
		
		for x in self.list:
			if "-1:0:0" not in x[0]:
				ret1.append(x)

			#if ret1:
		self.list = ret1
		
		if self.list and len(self.list):
			self.list.sort(key=lambda x: x[2])
		self.l.setList(self.list)
		self.selectionChanged()
		
	except:
		writeerror()
		
if streamrelayconf.get('eventupdateonshow', None):

	from Screens.EventView import EventViewBase
	EventViewBase.getSimilarEvents = getSimilarEvents
	
	from Components.EpgList import EPGList
	EPGList.fillSimilarList = fillSimilarList



def havepmt(service):
	pmt = False
	streaming = service.stream()
	s = streaming and streaming.getStreamingData()
	pids = s and s.get("pids", [] )
	if pids:
		for value, key in pids:
			if key == "pmt":
				return True
	return pmt
	
def sr_recordEvent(self, service, event):
	try:
		#writelog('event {0} service {1}'.format(event, service and True or False))
		if service is self._StreamService__service:
			#writelog('event {0} service is self.__service {1}'.format(event, service is self._StreamService__service))
			return
		print "RECORD event for us:", service
		if event in [iRecordableService.evStart]:
			return
			#self.changed((self.CHANGED_DEFAULT, ))
		elif event in [iRecordableService.evEnd, iRecordableService.evRecordStopped]:
			self.changed((self.CHANGED_CLEAR, ))
		elif event in [iRecordableService.evRecordRunning, iRecordableService.evNewProgramInfo, iRecordableService.evNewEventInfo]:
			#writelog('event {0} service {1}'.format(event, ''))
			#if havepmt(service):
			self.changed((self.CHANGED_ALL, ))
	except:
		writeerror()
		self.recordEvent_srori()

def MyrecordEvent_hp(self, service, event):
	try:
		writelog('event {0} self.havepids {1}'.format(event, self.havepids))
		if service is self._StreamService__service:
			#writelog('event {0} service is self.__service {1}'.format(event, service is self._StreamService__service))
			return
		print "RECORD event for us:", service
		if event in [iRecordableService.evStart]:
			self.havepids = False
		elif self.havepids == False and event in [iRecordableService.evRecordRunning, iRecordableService.evNewProgramInfo, iRecordableService.evNewEventInfo]:
			self.changed((self.CHANGED_ALL, ))
			#self.havepids = True
	except:
		writeerror()
		self.recordEvent_srori()

if streamrelayconf.get('requestfilter', None):
	from Components.Sources.StreamService import StreamService
	StreamService.recordEvent_srori = StreamService.recordEvent
	#ori_recordEvent = StreamService.recordEvent
	#StreamService.havepids = False
	StreamService.recordEvent = sr_recordEvent
	
	#Components.Sources.StreamService.StreamService = StreamServicePineas

	from Components.Converter.Streaming import Streaming
	from Plugins.Extensions.StreamRelay.Streaming import Streaming as SR_Streaming

	Streaming.getText = SR_Streaming.getText
	Streaming.text = SR_Streaming.text


def __eventInfoChanged(self):
	try:
		#writelog('__eventInfoChanged {0}'.format('__eventInfoChanged'))
		if self.execing:
			service = self.session.nav.getCurrentService()
			old_begin_time = self.current_begin_time
			info = service and service.info()
			ptr = info and info.getEvent(0)
			if ptr is None:
				ref = self.session.nav.getCurrentlyPlayingServiceReference()
				if ref and ref.getUnsignedData(4) == 33:
					path = ref.getPath()
					if path:
						pos = path.rfind('/')
						if pos != -1:
							refstr = path[pos+1:]
							ref = eServiceReference(refstr)
							#serviceHandler = eServiceCenter.getInstance()
							#info = serviceHandler.play(ref)
							epg = eEPGCache.getInstance()
							ptr = epg.lookupEventTime(ref, -1, 0)
							if ptr:
								writelog('ptr {0}'.format(ptr.getBeginTime()))
							
			self.current_begin_time = ptr and ptr.getBeginTime() or 0
			#writelog('self.current_begin_time {0}'.format(self.current_begin_time))
			if config.usage.show_infobar_on_event_change.value:
				if old_begin_time and old_begin_time != self.current_begin_time:
					self.doShow()
	except:
		writeerror()
		
#from Screens.InfoBar import InfoBar
#InfoBar._InfoBar__eventInfoChanged = __eventInfoChanged

def stream_ref_to_es_ref(ref=None, tostring=None):
	try:
		#if ref and ref.getUnsignedData(4) == 33:
		if ref:
			path = ref.getPath()
			if path:
				pos = path.rfind('/')
				if pos != -1:
					refstr = path[pos+1:]
					if tostring:
						return refstr
					ref = eServiceReference(refstr)
		return ref
	except:
		writeerror()
		return ref
		
def getRecordableServicePtr():
	try:
		refres = None
		if streamingScreens:
			import NavigationInstance
			ref = NavigationInstance.instance.getCurrentlyPlayingServiceReference()
			if ref and ref.getUnsignedData(4) == 33:
				for streaming in streamingScreens:
					stream = streaming.get("StreamService")
					if stream and stream.ref:
						if stream.ref.toCompareString() in (ref.getPath() or ''):
							refres = stream.getService()
		return refres
	except:
		writeerror()

def sr_activate(self):
	try:
		if self.state == self.StateWaiting and self.first_try_prepare:
			sr_ref = self.service_ref and self.service_ref.ref
			if sr_ref and sr_ref.getUnsignedData(4) == 33:
				ref = stream_ref_to_es_ref(sr_ref)
				if ref:
					service_center = eServiceCenter.getInstance()
					service_info = service_center.info(ref)
					isPlayable = service_info.isPlayable(ref, eServiceReference())
					#writelog('{} isPlayable {}'.format(sr_ref.getName(), isPlayable))
					if isPlayable == 0:
						self.first_try_prepare = False
						Notifications.AddNotification(MessageBox, _("In order to record a timer, the TV was switched to the recording service!\n"), type=MessageBox.TYPE_INFO, timeout=20,windowTitle='Streamrelay', domain="RecordTimer")
						self.failureCB(True)
						
		return self.activate_srori()
	except:
		writeerror()
		return self.activate_srori()
		
if streamrelayconf.get('switchrecording', True):
	try:
		from Tools import Notifications
		from RecordTimer import RecordTimerEntry

		RecordTimerEntry.activate_srori = RecordTimerEntry.activate
		RecordTimerEntry.activate = sr_activate
	except:
		writeerror()