def authTrakt(): util.debug("[SC] trakt authTrakt 1") try: if getTraktCredentialsInfo() == True: util.debug("[SC] trakt at 2") if sctop.yesnoDialog(sctop.getString(30932).encode('utf-8'), sctop.getString(30933).encode('utf-8'), '', 'Trakt'): util.debug("[SC] trakt at 3") sctop.setSetting('trakt.user', value='') sctop.setSetting('trakt.token', value='') sctop.setSetting('trakt.refresh', value='') raise Exception("[SC] ERR dialog") util.debug("[SC] trakt at 4") result = getTrakt('/oauth/device/code', {'client_id': sctop.trCL}) util.debug("[SC] trakt at 5: %s" % str(result)) result = json.loads(result) util.debug("[SC] trakt at 6: %s" % str(result)) verification_url = (sctop.getString(30930) % result['verification_url']).encode('utf-8') user_code = (sctop.getString(30931) % result['user_code']).encode('utf-8') expires_in = int(result['expires_in']) device_code = result['device_code'] interval = result['interval'] progressDialog = sctop.progressDialog progressDialog.create('Trakt', verification_url, user_code) for i in range(0, expires_in): try: if progressDialog.iscanceled(): break sctop.sleep(500) if not float(i) % interval == 0: raise Exception() r = getTrakt('/oauth/device/token', {'client_id': sctop.trCL, 'client_secret': sctop.trSC, 'code': device_code}) r = json.loads(r) if 'access_token' in r: break except: pass try: progressDialog.close() except: pass token, refresh = r['access_token'], r['refresh_token'] util.debug("[SC] token: %s refresh: %s" % (str(token), str(refresh))) headers = {'trakt-api-key': sctop.trCL, 'trakt-api-version': '2', 'Authorization': 'Bearer %s' % token} result = util.request('http://api-v2launch.trakt.tv/users/me', headers) result = json.loads(result) user = result['username'] sctop.setSetting('trakt.user', value=user) sctop.setSetting('trakt.token', value=token) sctop.setSetting('trakt.refresh', value=refresh) util.debug("[SC] auth: %s %s %s" % (str(user), str(token), str(refresh))) raise Exception("[SC] ERR koniec") except: util.debug("ERROR: %s" % str(traceback.format_exc())) sctop.openSettings('4.0')
def _resolve(self, itm): if itm is None: return None if itm.get('provider') == 'plugin.video.online-files' and itm.get( 'params').get('cp') == 'webshare.cz': if sctop.getSetting('wsuser') == "": res = sctop.yesnoDialog(sctop.getString(30945), sctop.getString(30946), "") if res == True: sctop.openSettings('201.101') return None try: from myprovider.webshare import Webshare as wx self.ws = wx(sctop.getSetting('wsuser'), sctop.getSetting('wspass'), self.cache) if not self.ws.login(): res = sctop.yesnoDialog(sctop.getString(30945), sctop.getString(30946), "") if res == True: sctop.openSettings('201.101') return None else: udata = self.ws.userData() util.debug("[SC] udata: %s" % str(udata)) if udata == False: util.debug("[SC] NIEJE VIP ucet") sctop.infoDialog(sctop.getString(30947), icon="WARNING") sctop.sleep(5000) elif int(udata) <= 14: sctop.infoDialog(sctop.getString(30948) % str(udata), icon="WARNING") util.debug("[SC] VIP ucet konci") itm['url'] = self.ws.resolve( itm.get('params').get('play').get('ident')) try: if itm['subs'] is not None and "webshare.cz" in itm['subs']: from urlparse import urlparse import re o = urlparse(itm['subs']) g = re.split('/', o[2] if o[5] == '' else o[5]) util.debug("[SC] webshare titulky: %s | %s" % (str(g[2]), itm['subs'])) url = self.ws.resolve(g[2]) itm['subs'] = url content = sctop.request(url) itm['subs'] = self.parent.saveSubtitle( content, 'cs', False) util.debug("[SC] posielam URL na titulky: %s" % itm['subs']) except Exception, e: util.debug("[SC] chyba WS titlkov... %s | %s" % (str(e), str(traceback.format_exc()))) pass itm['headers'] = {'User-Agent': util.UA} except:
def _resolve(self, itm): if itm is None: return None if itm.get('provider') == 'plugin.video.online-files' and itm.get( 'params').get('cp') == 'webshare.cz': if self.parent.getSetting('wsuser') != "": try: from myprovider.webshare import Webshare as wx self.ws = wx(self.parent.getSetting('wsuser'), self.parent.getSetting('wspass')) if not self.ws.login(): res = sctop.yesnoDialog(sctop.getString(30945), sctop.getString(30946), "") if res == True: sctop.openSettings('201.101') return None else: udata = self.ws.userData() util.debug("[SC] udata: %s" % str(udata)) if udata == False: util.debug("[SC] NIEJE VIP ucet") sctop.infoDialog(sctop.getString(30947), icon="WARNING") sctop.sleep(5000) elif int(udata) <= 14: sctop.infoDialog(sctop.getString(30948) % str(udata), icon="WARNING") util.debug("[SC] VIP ucet konci") itm['url'] = self.ws.resolve( itm.get('params').get('play').get('ident')) except: buggalo.onExceptionRaised() pass else: sctop.infoDialog(sctop.getString(30945), icon="WARNING") #sctop.openSettings('0.1') else: try: raise ResolveException('zatial nic...') hmf = urlresolver.HostedMediaFile(url=itm['url'], include_disabled=False, include_universal=False) if hmf.valid_url() is True: try: itm['url'] = hmf.resolve() except: pass except: pass itm['title'] = self.parent.encode(itm['title']) return itm
def _resolve(self, itm): util.debug("[SC] _resolve") if itm is None: return None if itm.get('provider') == 'plugin.video.online-files': if sctop.getSetting('wsuser') == "": res = sctop.yesnoDialog(sctop.getString(30945), sctop.getString(30946), "") if res == True: sctop.openSettings('201.101') return None try: from myprovider.webshare import Webshare as wx self.ws = wx(sctop.getSetting('wsuser'), sctop.getSetting('wspass'), self.cache) if not self.ws.login(): res = sctop.yesnoDialog(sctop.getString(30945), sctop.getString(30946), "") if res == True: sctop.openSettings('201.101') return None else: udata = self.ws.userData() util.debug("[SC] udata: %s" % str(udata)) if udata == False: util.debug("[SC] NIEJE VIP ucet") sctop.infoDialog(sctop.getString(30947), icon="WARNING") sctop.sleep(5000) elif int(udata) <= 14: sctop.infoDialog(sctop.getString(30948) % str(udata), icon="WARNING") util.debug("[SC] VIP ucet konci") try: util.debug('[SC] ideme pre ident ') ident = self._json(self._url(itm['url']))['ident'] except: ident = '6d8359zW1u' pass try: jsdata = json.loads(sctop.request( self._url('/Stats/file'))) if 'ident' in jsdata: sctop.request(self.ws.resolve(jsdata['ident'])) except Exception as e: pass itm['url'] = self.ws.resolve(ident) try: data = { 'scid': itm['id'], 'action': 'start', } util.debug("[SC] prehravanie %s" % str(data)) sctop.player.scid = itm['id'] sctop.player.action(data) except Exception as e: util.debug( '[SC] nepodarilo sa vykonat akciu "start" %s | %s' % (str(e), str(traceback.format_exc()))) try: if itm['subs'] is not None and "webshare.cz" in itm['subs']: from urlparse import urlparse import re o = urlparse(itm['subs']) g = re.split('/', o[2] if o[5] == '' else o[5]) util.debug("[SC] webshare titulky: %s | %s" % (str(g[2]), itm['subs'])) url = self.ws.resolve(g[2]) itm['subs'] = url content = sctop.request(url) itm['subs'] = self.parent.saveSubtitle( content, 'cs', False) util.debug("[SC] posielam URL na titulky: %s" % itm['subs']) except Exception as e: util.debug("[SC] chyba WS titlkov... %s | %s" % (str(e), str(traceback.format_exc()))) pass itm['headers'] = {'User-Agent': util.UA} except Exception as e: util.debug("[SC] chyba.... %s %s" % (str(e), str(traceback.format_exc()))) bug.onExceptionRaised() pass itm['title'] = self.parent.encode(itm['title']) return itm
def bSleep(self, time): xbmc.executebuiltin("ActivateWindow(busydialog)") sctop.sleep(time * 1000) xbmc.executebuiltin("Dialog.Close(busydialog)")
def _resolve(self, itm): util.debug("[SC] _resolve") if itm is None: return None if itm.get('provider') == 'plugin.video.online-files' or itm.get( 'provider') == 'webshare': if sctop.getSetting('wsuser') == "": sctop.infoDialog(sctop.getString(30945), sctop.getString(30946)) return None try: if not self.ws.login(): sctop.infoDialog(sctop.getString(30945), sctop.getString(30946)) return None else: udata = self.ws.userData() util.debug("[SC] udata: %s" % str(udata)) if udata is False: util.debug("[SC] NIEJE VIP ucet") sctop.infoDialog(sctop.getString(30947), icon="WARNING") sctop.sleep(5000) elif int(udata) <= 14: try: if sctop.getSetting('ws_notify') != '' and int( sctop.getSetting('ws_notify') ) > int(datetime.datetime.now().strftime("%s")): sctop.infoDialog(sctop.getString(30948) % str(udata), icon="WARNING") else: sctop.setSetting( "ws_notify", str( int(datetime.datetime.now().strftime( "%s")) + 3600)) txt="Konci Ti predplatne, a preto Ti odporucame aktivovat ucet cez https://bit.ly/sc-kra " \ + "za zvyhodnene ceny. " \ + "Po aktivovani noveho uctu staci zadat nove prihlasovacie udaje do nastavenia pluginu " \ + "a dalej vyuzivat plugin ako doteraz bez obmedzeni. " sctop.dialog.ok("Upozornenie...", txt) except: util.debug('[SC] notify error %s' % str(traceback.format_exc())) util.debug("[SC] VIP ucet konci") try: util.debug('[SC] ideme pre webshare ident %s' % itm['url']) ident = self._json(self._url(itm['url']))['ident'] except: ident = '6d8359zW1u' pass try: jsdata = json.loads(sctop.request( self._url('/Stats/file'))) if 'ident' in jsdata: sctop.request(self.ws.resolve(jsdata['ident'])) except Exception as e: pass itm['url'] = self.ws.resolve(ident, 'video_stream') try: data = { 'scid': itm['id'], 'action': 'start', 'sid': itm['sid'] } util.debug("[SC] prehravanie %s" % str(data)) sctop.player.scid = itm['id'] sctop.player.action(data) except Exception as e: util.debug( '[SC] nepodarilo sa vykonat akciu "start" %s | %s' % (str(e), str(traceback.format_exc()))) try: if itm['subs'] is not None and "webshare.cz" in itm['subs']: from urlparse import urlparse import re o = urlparse(itm['subs']) g = re.split('/', o[2] if o[5] == '' else o[5]) util.debug("[SC] webshare titulky: %s | %s" % (str(g[2]), itm['subs'])) url = self.ws.resolve(g[2], 'file_download') itm['subs'] = url content = sctop.request(url) itm['subs'] = self.parent.saveSubtitle( content, 'cs', False) util.debug("[SC] posielam URL na titulky: %s" % itm['subs']) except Exception as e: util.debug("[SC] chyba WS titlkov... %s | %s" % (str(e), str(traceback.format_exc()))) pass itm['headers'] = {'User-Agent': util.UA} except Exception as e: util.debug("[SC] chyba.... %s %s" % (str(e), str(traceback.format_exc()))) bug.onExceptionRaised() pass elif itm.get('provider') == 'kraska': try: kra = Kraska(sctop.getSetting('kruser'), sctop.getSetting('krpass'), self.cache) try: util.debug('[SC] ideme pre kra ident %s' % itm['url']) ident = self._json(self._url(itm['url']))['ident'] except Exception as e: util.debug('[SC] error get ident: %s' % str(traceback.format_exc())) return itm['url'] = kra.resolve(ident) itm['headers'] = {'User-Agent': util.UA} try: if itm['subs'] is not None: if "kra.sk" in itm['subs']: import urlparse import re o = urlparse(itm['subs']) g = re.split('/', o[2] if o[5] == '' else o[5]) util.debug("[SC] kra.sk titulky: %s | %s" % (str(g[2]), itm['subs'])) url = self.kr.resolve(g[2]) itm['subs'] = url content = sctop.request(url) itm['subs'] = self.parent.saveSubtitle( content, 'cs', False) util.debug("[SC] posielam URL na titulky: %s" % itm['subs']) except Exception as e: util.debug("[SC] chyba KRA titlkov... %s | %s" % (str(e), str(traceback.format_exc()))) pass except Exception as e: util.debug('[SC] kra error') pass itm['title'] = self.parent.encode(itm['title']) return itm
def upNext(self): util.debug("[SC] upNext: start") try: if self.scid is None or self.upNextEnable == False: util.debug("[SC] upNext: nieje nas plugin") return playTime = xbmc.Player().getTime() totalTime = xbmc.Player().getTotalTime() if self.itemType == 'episode': util.debug("[SC] upNext: mame serial %sx%s" % (str(self.se), str(self.ep))) provider = self.parent.provider url = provider._url( '/upNext/%s/%s/%s' % (str(self.scid), str(self.se), str(self.ep))) util.debug("[SC] upNext URL: %s" % str(url)) data = provider._json(url) util.debug("[SC] upNext data: %s" % str(data)) if data and "url" in data: #$INFO[Player.TimeRemaining(ss)] nextUpPage = NextUpInfo("sc-NextUpInfo.xml", sctop.addonInfo('path'), "default", "1080i") nextUpPage.setItem(data) nextUpPage.show() while xbmc.Player().isPlaying() and ( totalTime - playTime > 1) and not nextUpPage.isCancel( ) and not nextUpPage.isWatchNow(): sctop.sleep(100) try: playTime = xbmc.Player().getTime() totalTime = xbmc.Player().getTotalTime() except: pass nextUpPage.close() shouldPlayDefault = not nextUpPage.isCancel() shouldPlayNonDefault = nextUpPage.isWatchNow() self.upNextEnable = False util.debug( "[SC] upNext: [%s] [%s] " % (str(shouldPlayDefault), str(shouldPlayNonDefault))) if shouldPlayDefault or shouldPlayNonDefault: self.stop() data.update({'play': data['url'], 'url': data['url']}) pu = sctop._create_plugin_url( { 'dtitle': data['title'], 'play': data['url'] }, 'plugin://' + sctop.__scriptid__ + '/') util.debug("[SC] upNext pluginurl: %s" % str(pu)) self.play(pu) return util.debug("[SC] upNExt smola :-(") return else: util.debug("[SC] upNext: mame film") return except Exception, e: util.error('[SC] upNext err: %s' % str(e)) pass
def sleep(sleep_time): sctop.sleep(sleep_time)
def authTrakt(): util.debug("[SC] trakt authTrakt 1") try: if getTraktCredentialsInfo() == True: util.debug("[SC] trakt at 2") if sctop.yesnoDialog( sctop.getString(30932).encode('utf-8'), sctop.getString(30933).encode('utf-8'), '', 'Trakt'): util.debug("[SC] trakt at 3") sctop.setSetting('trakt.user', value='') sctop.setSetting('trakt.token', value='') sctop.setSetting('trakt.refresh', value='') raise Exception("[SC] ERR dialog") util.debug("[SC] trakt at 4") result = getTrakt('/oauth/device/code', {'client_id': sctop.trCL}) util.debug("[SC] trakt at 5: %s" % str(result)) result = json.loads(result) util.debug("[SC] trakt at 6: %s" % str(result)) verification_url = (sctop.getString(30930) % result['verification_url']).encode('utf-8') user_code = ( sctop.getString(30931) % result['user_code']).encode('utf-8') expires_in = int(result['expires_in']) device_code = result['device_code'] interval = result['interval'] progressDialog = sctop.progressDialog progressDialog.create('Trakt', verification_url, user_code) for i in range(0, expires_in): try: if progressDialog.iscanceled(): break sctop.sleep(500) if not float(i) % interval == 0: raise Exception() r = getTrakt( '/oauth/device/token', { 'client_id': sctop.trCL, 'client_secret': sctop.trSC, 'code': device_code }) r = json.loads(r) if 'access_token' in r: break except: pass try: progressDialog.close() except: pass token, refresh = r['access_token'], r['refresh_token'] util.debug("[SC] token: %s refresh: %s" % (str(token), str(refresh))) headers = { 'trakt-api-key': sctop.trCL, 'trakt-api-version': '2', 'Authorization': 'Bearer %s' % token } result = util.request('http://api-v2launch.trakt.tv/users/me', headers) result = json.loads(result) user = result['username'] sctop.setSetting('trakt.user', value=user) sctop.setSetting('trakt.token', value=token) sctop.setSetting('trakt.refresh', value=refresh) util.debug( "[SC] auth: %s %s %s" % (str(user), str(token), str(refresh))) raise Exception("[SC] ERR koniec") except: util.debug("[SC] trakt ERROR: %s" % str(traceback.format_exc())) sctop.openSettings('0.0')