diff options
author | Lunatixz <Lunatixz@users.noreply.github.com> | 2017-09-01 09:12:34 -0400 |
---|---|---|
committer | enen92 <enen92@users.noreply.github.com> | 2017-09-01 14:12:34 +0100 |
commit | 16143b1eed2b3e60d8bd1ce86f79966c09ae9059 (patch) | |
tree | bac24c73195216939cf77f28b588678fd5134100 /plugin.video.newson/resources/lib | |
parent | 89c72fc264899e6d36a4e4378ab2d8540d095554 (diff) |
[plugin.video.newson] 1.0.3 (#1388)
Diffstat (limited to 'plugin.video.newson/resources/lib')
-rw-r--r-- | plugin.video.newson/resources/lib/__init__.py | 0 | ||||
-rw-r--r-- | plugin.video.newson/resources/lib/newson.py | 271 |
2 files changed, 271 insertions, 0 deletions
diff --git a/plugin.video.newson/resources/lib/__init__.py b/plugin.video.newson/resources/lib/__init__.py new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/plugin.video.newson/resources/lib/__init__.py diff --git a/plugin.video.newson/resources/lib/newson.py b/plugin.video.newson/resources/lib/newson.py new file mode 100644 index 0000000..5999d4a --- /dev/null +++ b/plugin.video.newson/resources/lib/newson.py @@ -0,0 +1,271 @@ +# Copyright (C) 2017 Lunatixz +# +# +# This file is part of NewsOn. +# +# NewsOn is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# NewsOn is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with NewsOn. If not, see <http://www.gnu.org/licenses/>. + +# -*- coding: utf-8 -*- +import os, sys, time, datetime, re, traceback, feedparser, random +import urllib, urllib2, socket, json, collections, gzip +import xbmc, xbmcgui, xbmcplugin, xbmcvfs, xbmcaddon + +from StringIO import StringIO +from simplecache import SimpleCache +# Plugin Info +ADDON_ID = 'plugin.video.newson' +REAL_SETTINGS = xbmcaddon.Addon(id=ADDON_ID) +ADDON_NAME = REAL_SETTINGS.getAddonInfo('name') +SETTINGS_LOC = REAL_SETTINGS.getAddonInfo('profile') +ADDON_PATH = REAL_SETTINGS.getAddonInfo('path').decode('utf-8') +ADDON_VERSION = REAL_SETTINGS.getAddonInfo('version') +ICON = REAL_SETTINGS.getAddonInfo('icon') +FANART = REAL_SETTINGS.getAddonInfo('fanart') +LANGUAGE = REAL_SETTINGS.getLocalizedString +NEWSART = os.path.join(ADDON_PATH,'resources','images','newscast.jpg') +CLIPART = os.path.join(ADDON_PATH,'resources','images','videoclips.jpg') + +## GLOBALS ## +TIMEOUT = 30 +DEBUG = REAL_SETTINGS.getSetting('Enable_Debugging') == 'true' +BASE_API = 'http://watchnewson.com/api/linear/channels' +MENU = [("Newscasts" , '0', 0, False, {"thumb":NEWSART,"poster":NEWSART,"fanart":FANART,"icon":ICON,"logo":ICON}), + ("Video Clips", '2', 2, False, {"thumb":CLIPART,"poster":CLIPART,"fanart":FANART,"icon":ICON,"logo":ICON})] + +def log(msg, level=xbmc.LOGDEBUG): + if DEBUG == True: + if level == xbmc.LOGERROR: + msg += ' ,' + traceback.format_exc() + xbmc.log(ADDON_ID + '-' + ADDON_VERSION + '-' + (msg), level) + +def getParams(): + param=[] + if len(sys.argv[2])>=2: + params=sys.argv[2] + cleanedparams=params.replace('?','') + if (params[len(params)-1]=='/'): + params=params[0:len(params)-2] + pairsofparams=cleanedparams.split('&') + param={} + for i in range(len(pairsofparams)): + splitparams={} + splitparams=pairsofparams[i].split('=') + if (len(splitparams))==2: + param[splitparams[0]]=splitparams[1] + return param + +socket.setdefaulttimeout(TIMEOUT) +class NewsOn(object): + def __init__(self): + log('__init__') + self.cache = SimpleCache() + self.stateMenu = self.getStates() + + + def openURL(self, url): + try: + cacheResponce = self.cache.get(ADDON_NAME + '.openURL, url = %s'%url) + if not cacheResponce: + request = urllib2.Request(url) + request.add_header('Accept-encoding', 'gzip') + request.add_header('User-Agent','Mozilla/5.0 (Windows; U; MSIE 9.0; Windows NT 9.0; en-US)') + responce = urllib2.urlopen(request, timeout = TIMEOUT) + log(responce.headers['content-type']) + log(responce.headers['content-encoding']) + if responce.info().get('content-encoding') == 'gzip': + buf = StringIO(responce.read()) + f = gzip.GzipFile(fileobj=buf) + results = json.loads(f.read()) + else: + results = json.load(responce) + responce.close() + self.cache.set(ADDON_NAME + '.openURL, url = %s'%url, results, expiration=datetime.timedelta(hours=1)) + return self.cache.get(ADDON_NAME + '.openURL, url = %s'%url) + except urllib2.URLError, e: + log("openURL Failed! " + str(e), xbmc.LOGERROR) + except socket.timeout, e: + log("openURL Failed! " + str(e), xbmc.LOGERROR) + except: + xbmcgui.Dialog().notification(ADDON_NAME, LANGUAGE(30001), ICON, 4000) + + + def mainMenu(self): + log('mainMenu') + for item in MENU: + self.addDir(*item) + + + def browseMenu(self, id=1): + log('browseMenu, id = ' + str(id)) + self.stateMenu = [tuple(s.format(id) for s in tup) for tup in self.stateMenu] + for item in self.stateMenu: + self.addDir(*item) + + + def getStates(self): + log('getStates') + state = [] + stateLST = [] + data = self.openURL(BASE_API) + if data: + for channel in data: + state.append(channel['config']['state']) + states = collections.Counter(state) + for key, value in sorted(states.iteritems()): + stateLST.append(("%s"%(key), key , '{}')) + return stateLST + + + def newsCasts(self, state): + log('newsCasts, state = ' + state) + urls = [] + data = self.openURL(BASE_API) + if data: + for channel in data: + if state in channel['config']['state']: + chid = channel['identifier'] + title = channel['title'] + icon = (channel['icon'] or ICON) + for idx, stream in enumerate(channel['streams']): + streamType = stream['StreamType'] + if streamType == 'website':#random.choice(['website','roku']): + continue + #multiple urls, only add unique. + url = stream['Url'] + offset = stream['OffsetFromNow'] + delay = url+'&delay=%d' + #todo do something with delay option? + if url not in urls: + urls.append(url) + chid = chid+'.%d'%idx if idx > 0 else chid + label = "%s - %s" % (chid, title) + infoLabels ={"mediatype":"video","label":label ,"title":label} + infoArt ={"thumb":icon,"poster":icon,"fanart":FANART,"icon":icon,"logo":icon} + self.addLink(title, url, 9, infoLabels, infoArt) + + + def videoclips(self, state): + log('videoclips, state = ' + state) + data = self.openURL(BASE_API) + if data: + for channel in data: + if state in channel['config']['state']: + chid = channel['identifier'] + title = channel['title'] + icon = (channel['icon'] or ICON) + vidURL = channel['config']['localvodfeed'] + if vidURL: + label = "%s - %s" % (chid, title) + infoLabels ={"mediatype":"video","label":label,"title":label} + infoArt ={"thumb":icon,"poster":icon,"fanart":FANART,"icon":ICON,"logo":ICON} + self.addDir(label, vidURL, 4, infoLabels, infoArt) + + + def parseclips(self, url): + log('parseclips, url = ' + url) + feed = feedparser.parse(url) + for item in feed['entries']: + if item and 'summary_detail' in item: + for vids in item['media_content']: + title = item['title'] + url = vids['url'] + plot = item['summary'] + try: + aired = (datetime.datetime.strptime(item.get('published',''), '%a, %d %b %Y %H:%M:%S UTC')) + except: + aired = datetime.datetime.now() + aired = aired.strftime("%Y-%m-%d") + thumb = item['media_thumbnail'][0]['url'] + tagLST = [] + if 'tags' in item: + for tag in item['tags']: + print tag + tagLST.append(((tag['term']).split('/')[0]).title()) + if len(tagLST) > 0: + genre = (tagLST[0] or '') + infoLabels ={"mediatype":"video","label":title,"title":title,"plot":plot,"aired":aired,'genre':genre,'tags':tagLST} + infoArt ={"thumb":thumb,"poster":thumb,"fanart":FANART,"icon":ICON,"logo":ICON} + self.addLink(title, url, 9, infoLabels, infoArt) + + + def playVideo(self, name, url, list=None): + log('playVideo') + if not list: + list = xbmcgui.ListItem(name, path=url) + xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, list) + + + def addLink(self, name, u, mode, infoList=False, infoArt=False, total=0): + name = name.encode("utf-8") + log('addLink, name = ' + name) + liz=xbmcgui.ListItem(name) + liz.setProperty('IsPlayable', 'true') + if infoList == False: + liz.setInfo( type="Video", infoLabels={"mediatype":"video","label":name,"title":name}) + else: + liz.setInfo(type="Video", infoLabels=infoList) + + if infoArt == False: + liz.setArt({'thumb':ICON,'fanart':FANART}) + else: + liz.setArt(infoArt) + u=sys.argv[0]+"?url="+urllib.quote_plus(u)+"&mode="+str(mode)+"&name="+urllib.quote_plus(name) + xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,totalItems=total) + + + def addDir(self, name, u, mode, infoList=False, infoArt=False): + name = name.encode("utf-8") + log('addDir, name = ' + name) + liz=xbmcgui.ListItem(name) + liz.setProperty('IsPlayable', 'false') + if infoList == False: + liz.setInfo(type="Video", infoLabels={"mediatype":"video","label":name,"title":name}) + else: + liz.setInfo(type="Video", infoLabels=infoList) + if infoArt == False: + liz.setArt({'thumb':ICON,'fanart':FANART}) + else: + liz.setArt(infoArt) + u=sys.argv[0]+"?url="+urllib.quote_plus(u)+"&mode="+str(mode)+"&name="+urllib.quote_plus(name) + xbmcplugin.addDirectoryItem(handle=int(sys.argv[1]),url=u,listitem=liz,isFolder=True) + +params=getParams() +try: + url=urllib.unquote_plus(params["url"]) +except: + url=None +try: + name=urllib.unquote_plus(params["name"]) +except: + name=None +try: + mode=int(params["mode"]) +except: + mode=None + +log("Mode: "+str(mode)) +log("URL : "+str(url)) +log("Name: "+str(name)) + +if mode==None: NewsOn().mainMenu() +elif mode == 0: NewsOn().browseMenu(1) +elif mode == 1: NewsOn().newsCasts(url) +elif mode == 2: NewsOn().browseMenu(3) +elif mode == 3: NewsOn().videoclips(url) +elif mode == 4: NewsOn().parseclips(url) +elif mode == 9: NewsOn().playVideo(name, url) + +xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_NONE ) +xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_LABEL ) +xbmcplugin.endOfDirectory(int(sys.argv[1]),cacheToDisc=True)
\ No newline at end of file |