# Copyright (C) 2017 Lunatixz # # # This file is part of Cheddar # # Cheddar 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. # # Cheddar 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 Cheddar. If not, see . # -*- coding: utf-8 -*- import os, sys, datetime, re, traceback, urllib, urllib2, socket import xbmc, xbmcvfs, xbmcgui, xbmcplugin, xbmcaddon from simplecache import SimpleCache from bs4 import BeautifulSoup # Plugin Info ADDON_ID = 'plugin.video.cheddar' 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 ## GLOBALS ## TIMEOUT = 30 BASEURL = 'http://cheddar.com/' DEBUG = REAL_SETTINGS.getSetting('Enable_Debugging') == 'true' CONTENT_TYPE = 'files' Cheddar_MENU = [("Latest" , 'collections/latest', 1), ("Browse" , 'collections' , 1)] 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 Cheddar(): def __init__(self): log('__init__') self.cache = SimpleCache() 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('User-Agent','Mozilla/5.0 (Windows; U; MSIE 9.0; Windows NT 9.0; en-US)') response = urllib2.urlopen(request, timeout=TIMEOUT) results = response.read() response.close() self.cache.set(ADDON_NAME + '.openURL, url = %s'%url, results, expiration=datetime.timedelta(hours=12)) return self.cache.get(ADDON_NAME + '.openURL, url = %s'%url) except urllib2.URLError as e: log("openURL Failed! " + str(e), xbmc.LOGERROR) except socket.timeout as e: log("openURL Failed! " + str(e), xbmc.LOGERROR) except: xbmcgui.Dialog().notification(ADDON_NAME, LANGUAGE(30001), ICON, 4000) def mainMenu(self): log('mainMenu') self.addLink('Live', '', 0) for item in Cheddar_MENU: self.addDir(*item) def browseLive(self): log('browseLive') soup = BeautifulSoup(self.openURL(BASEURL), "html.parser") liveLink = 'http:' + soup('div', {'class': 'hero_video'})[0].find('source').get('src') self.playVideo('Live', liveLink) def browse(self, link): log('browse') soup = BeautifulSoup(self.openURL(BASEURL+link), "html.parser") latestLink = (soup('div', {'class': 'video_thumb'})) for item in latestLink: try: uriLink = item('a', {'class': 'cf'})[0] uri = BASEURL + uriLink['href'] thumb = uriLink('div', {'class': 'vid_img'})[0].find_all('img')[0].get('src') airdate, title = uriLink.text.strip().replace('\r','').replace('\t','').split('\n') plot = 'Aired: %s'%airdate label = title.strip() airdate = datetime.datetime.strptime(airdate, "%B %d, %Y") infoList = {"mediatype":'video',"label":label,"title":label,"plot":plot,'genre':'News',"studio":"cheddar","aired":airdate.strftime('%Y-%m-%d'),"date":airdate.strftime('%d/%m/%Y')} infoArt = {"thumb":thumb,"poster":thumb,"fanart":FANART} self.addLink(label, uri, 9, infoList, infoArt) except: xbmc.executebuiltin("Container.Refresh") def playVideo(self, name, uri): log('playVideo, uri = ' + uri) try: metaLink = BeautifulSoup(self.openURL(uri), "html.parser") meta = metaLink('div', {'class': 'wrap video_details'})[0]('div', {'class': 'video_details_content'})[0] title = meta.find('h4').text plot = meta.find('article').text airdate = meta.find('p').text plotout = 'Aired: %s'%airdate airdate = datetime.datetime.strptime(airdate, "%B %d, %Y") url = metaLink('div', {'class': 'hero_video'})[0].find('source').get('src')+'.mp4' thumb = metaLink('div', {'class': 'hero_video'})[0].find('video').get('poster') infoList = {"mediatype":'video',"label":title,"title":title,"plot":plot,'genre':'News',"plotoutline":plotout,"studio":"cheddar","aired":airdate.strftime('%Y-%m-%d')} infoArt = {"thumb":thumb,"poster":thumb,"fanart":FANART} liz = xbmcgui.ListItem(title, path=url) liz.setInfo(type="Video", infoLabels=infoList) liz.setArt(infoArt) except: liz = xbmcgui.ListItem(name, path=uri) xbmcplugin.setResolvedUrl(int(sys.argv[1]), True, liz) 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: Cheddar().mainMenu() elif mode == 0: Cheddar().browseLive() elif mode == 1: Cheddar().browse(url) elif mode == 9: Cheddar().playVideo(name, url) xbmcplugin.setContent(int(sys.argv[1]) , CONTENT_TYPE) xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_UNSORTED) xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_NONE) xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_LABEL) xbmcplugin.addSortMethod(int(sys.argv[1]) , xbmcplugin.SORT_METHOD_TITLE) xbmcplugin.endOfDirectory(int(sys.argv[1]), cacheToDisc=True)