def getLastTvShow(self, streamItem=False): """ Method to get all last tv show @return a list of StreamItem """ href = '/' # ___ Initialize the list to return elementList = [] # ___ Get the response response = self.openPage(href) if response and response.getcode() == 200: content = response.read() linksPattern = re.compile( '(.*)(window\.__NUXT__=)(.*?)(;</script>)(.*)', re.DOTALL) match = linksPattern.match(content) if match is not None: jsonEl = json.loads(match.group(3)) for movie in jsonEl['data'][0]['nouveaux']['series']: title = movie['name'] href = '/series/' + strUtil.remove_special_char( title).replace(' ', '-').lower() + '-' + str( movie['customID']) + '.html' year = movie['releaseYear'] quality = movie['quality'] langClass = movie['language'] lang = None subtitle = None if langClass == 'vf': lang = 'FR' else: lang = 'VO' subtitle = 'FR' title = strUtil.cleanTitle(title) title = strUtil.deleteAccent(title) self.__LOGGER__.log("Clean title: " + str(title), xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setYear(year) element.setQuality(quality) element.setLang(lang) if subtitle is not None: element.setSubTitle(subtitle) element.setSourceId(self.ID) element.setId(str(movie['customID'])) element.setIconImage(movie['poster']) element.setTvShowName(title) element.setType(StreamItem.TYPE_TVSHOW) element.setAction(StreamItem.ACTION_DISPLAY_SEASONS) elementList.append(element) return elementList
def getMoviesFromContent(self,content): """ Method to get movies from content @param: the html content @return the elementList """ elementList = [] soup = BeautifulSoup(content) movies = soup.findAll('div',{'class':'movie'}) for movie in movies: title = movie.find('div',{'class':'infos'}).find('a',{'class':'title'}).find('span').text.encode('UTF-8') title = strUtil.unescapeHtml(str(title)) self.__LOGGER__.log("Finded title: "+title,xbmc.LOGDEBUG) href = movie.find('div',{'class':'infos'}).find('a',{'class':'title'})['href'] quality = movie.find('div',{'class':'pic'}).find('span',{'class':'qualitos'}).text.encode('UTF-8') title = strUtil.cleanTitle(title) self.__LOGGER__.log("Clean title: "+str(title),xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setQuality(quality) element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) element.setSourceId(self.ID) element.setIconImage(movie.find('div',{'class':'pic'}).find('img')['src']) element.setId(movie.find('div',{'class':'infos'}).find('a',{'data-type':'movie'})['data-id']) # ___ Get metadatas metadatas = movie.find('div',{'class':'infos'}) if metadatas is not None: genres = metadatas.findAll('p',{'class':'nop genre meta an'})[0].find('a').text.encode('UTF-8') element.setMetadataGenre(genres) year = metadatas.findAll('p',{'class':'nop genre meta an'})[1].find('a').text.encode('UTF-8') element.setMetadataYear(year) lang = strUtil.getLangFromTitle(metadatas.findAll('p',{'class':'nop genre meta an'})[2].find('img')['alt']) element.setLang(lang) overview = metadatas.find('p',{'class':'nop synopsis meta an'}) if overview is not None: element.setMetadataOverview(overview.text.encode('UTF-8')) # __ Add the element to the list elementList.append(element) return elementList
def getTopWeekMovie(self,streamItem=False): """ Method to get top week movie @return a list of StreamItem """ # ___ Initialize the list to return elementList = [] href = '/' # ___ Get the soup response = self.openPage(href) if response and response.getcode() == 200: content = response.read() soup = BeautifulSoup(content) movies = soup.find('div',{'class':'coco owl-carousel'}).findAll('a',{'class':'item movie_single'}) for movie in movies: title = movie.find('h4').text.encode('UTF-8') title = strUtil.unescapeHtml(str(title)) self.__LOGGER__.log("Finded title: "+title,xbmc.LOGDEBUG) href = movie['href'] title = strUtil.cleanTitle(title) self.__LOGGER__.log("Clean title: "+str(title),xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) element.setSourceId(self.ID) element.setIconImage(self.buildHref(movie.find('img')['src'])) idPattern = re.compile('(http://streamay.ws/)(\d{1,6}?)(-.*)(\.html)') match = idPattern.match(href) if match is not None: element.setId(match.group(2)) # __ Add the element to the list elementList.append(element) return elementList
def getMovieList(self, streamItem=False): """ Method to get a list of movie @return a list of StreamItem """ href = '/categories/films/page/1' page = 1 if streamItem and streamItem.isPage(): page = streamItem.getPage() href = streamItem.getHref() # ___ Initialize the list to return elementList = [] # ___ Get the response response = self.openPage(href) if response and response.getcode() == 200: content = response.read() linksPattern = re.compile( '(.*)(window\.__NUXT__=)(.*?)(;</script>)(.*)', re.DOTALL) match = linksPattern.match(content) if match is not None: jsonEl = json.loads(match.group(3)) for movie in jsonEl['data'][0]['elements']: href = '/films/' + strUtil.remove_special_char( movie['name']).replace(' ', '-').lower() + '-' + str( movie['customID']) + '.html' year = movie['releaseYear'] quality = movie['quality'] langClass = movie['language'] lang = None subtitle = None if langClass == 'vf': lang = 'FR' else: lang = 'VO' subtitle = 'FR' title = strUtil.cleanTitle(movie['name']) title = strUtil.deleteAccent(title) self.__LOGGER__.log("Clean title: " + str(title), xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setYear(year) element.setQuality(quality) element.setLang(lang) if subtitle is not None: element.setSubTitle(subtitle) element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) element.setSourceId(self.ID) element.setId(str(movie['customID'])) element.setIconImage(movie['poster']) elementList.append(element) if streamItem: element = streamItem.copy() page = page + 1 element.setType(StreamItem.TYPE_PAGE) element.setPage(page) element.setTitle('Page ' + str(element.getPage())) element.setHref('/categories/films/page/' + str(page)) elementList.append(element) else: page = page + 1 element = StreamItem('Page ' + str(element.getPage())) element.setType(StreamItem.TYPE_PAGE) element.setPage(page) element.setTitle('Page ' + str(element.getPage())) element.setAction(StreamItem.ACTION_DISPLAY_TYPE_LIST) element.setSubType(StreamItem.SUBTYPE_LIST) element.setHref('/categories/films/page/' + str(page)) elementList.append(element) return elementList
def getMoviesItemFromContent(self, content, filter=False): """ Method to get movie list @param content: the html content @return the StreamItem list """ elementList = [] itemsPattern = re.compile( '(.*)(window\.__NUXT__=)(.*?)(;</script>)(.*)', re.DOTALL) match = itemsPattern.match(content) if match is not None: jsonEl = json.loads(match.group(3)) if not filter or filter == StreamItem.TYPE_MOVIE: for item in jsonEl['data'][0]['films']: title = item['name'] href = '/films/' + strUtil.remove_special_char( title).replace(' ', '-').lower() + '-' + str( item['customID']) + '.html' year = item['releaseYear'] quality = item['quality'] langClass = item['language'] lang = None subtitle = None if langClass == 'vf': lang = 'FR' else: lang = 'VO' subtitle = 'FR' title = strUtil.cleanTitle(title) self.__LOGGER__.log("Clean title: " + str(title), xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setYear(year) element.setQuality(quality) element.setLang(lang) element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) element.setSourceId(self.ID) element.setId(str(item['customID'])) element.setIconImage(item['poster']) type = StreamItem.TYPE_MOVIE elementList.append(element) elif filter == StreamItem.TYPE_TVSHOW: for item in jsonEl['data'][0]['series']: title = item['name'] href = '/series/' + strUtil.remove_special_char( title).replace(' ', '-').lower() + '-' + str( item['customID']) + '.html' year = item['releaseYear'] quality = item['quality'] langClass = item['language'] lang = None subtitle = None if langClass == 'vf': lang = 'FR' else: lang = 'VO' subtitle = 'FR' title = strUtil.cleanTitle(title) self.__LOGGER__.log("Clean title: " + str(title), xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setYear(year) element.setQuality(quality) element.setLang(lang) element.setSourceId(self.ID) element.setId(str(item['customID'])) element.setIconImage(item['poster']) element.setTvShowName(title) element.setType(StreamItem.TYPE_TVSHOW) element.setAction(StreamItem.ACTION_DISPLAY_SEASONS) type = StreamItem.TYPE_TVSHOW elementList.append(element) # For every post, get title and topicLink """ movies = soup.findAll('div',{ 'class':'column is-one-quarter-desktop is-half-mobile'}) for index in range(0,len(movies)): movie = movies[index] title = movie.find('img',{'class':'image-fix'})['alt'].encode('UTF-8') title = strUtil.unescapeHtml(str(title)) self.__LOGGER__.log("Finded title: "+title,xbmc.LOGDEBUG) href = movie.find('a')['href'] year = strUtil.getYearFromTitle(title) quality = movie.find('div',{'class':re.compile('(media-content)(.*)')}).text.encode('UTF-8') langClass = movie.find('img',{'class':'language-image'})['src'] lang = None subtitle = None if langClass == '/vf.png': lang = 'FR' else: lang = 'VO' subtitle = 'FR' title = strUtil.cleanTitle(title) self.__LOGGER__.log("Clean title: "+str(title),xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) element.setYear(year) element.setQuality(quality) element.setLang(lang) element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) element.setSourceId(self.ID) element.setIconImage(movie.find('img')['src']) type = StreamItem.TYPE_MOVIE tvshowPattern = re.compile("(/series/)(.*)") print href match = tvshowPattern.match(href) if match is not None: element.setTvShowName(title) element.setType(StreamItem.TYPE_TVSHOW) element.setAction(StreamItem.ACTION_DISPLAY_SEASONS) type = StreamItem.TYPE_TVSHOW # __ Add the element to the list if not filter: elementList.append(element) elif type == int(filter): elementList.append(element) """ return elementList
def getItemsFromContent(self,content,type): """ Method to get movie list @param content: the html content @param type: the type to extract @return the StreamItem list """ elementList = [] typeEl = None results = json.loads(content) if results is not None and len(results)>0: for result in results: detail = result['result'] title =detail['title'].encode('UTF-8') title = strUtil.unescapeHtml(str(title)) self.__LOGGER__.log("Finded title: "+title,xbmc.LOGDEBUG) href = detail['url'] year=None quality=None lang=None if 'anneeProduction' in detail: year = detail['anneeProduction'] if 'qualite' in detail: quality = detail['qualite'] if 'langue' in detail: lang = strUtil.getLangFromTitle(detail['langue']) self.__LOGGER__.log("Clean title: "+str(title),xbmc.LOGDEBUG) # __ Create the element element = StreamItem(title) element.setHref(href) if year is not None: element.setYear(year) if quality is not None: element.setQuality(quality) if lang is not None: element.setLang(lang) element.setId(detail['id']) element.setSourceId(self.ID) # __ Get the type if result['type'] == 'Film': typeEl = StreamItem.TYPE_MOVIE element.setAction(StreamItem.ACTION_DISPLAY_LINKS) element.setType(StreamItem.TYPE_MOVIE) elif strUtil.deleteAccent(result['type']) == 'Serie': typeEl = StreamItem.TYPE_TVSHOW element.setAction(StreamItem.ACTION_DISPLAY_SEASONS) element.setType(StreamItem.TYPE_TVSHOW) element.setTvShowName(title) elif result['type'] == 'Manga': typeEl = StreamItem.TYPE_ANIME element.setAction(StreamItem.ACTION_DISPLAY_EPISODES) element.setType(StreamItem.TYPE_ANIME) element.setTvShowName(title) if typeEl is not None and typeEl == int(type): # __ Get the poster element.setIconImage(self.buildHref('/cdn/img/'+detail['img'])) # __ Set the genre if 'genre' in detail: element.setMetadataGenre(detail['genre']) # __ Add the element to the list elementList.append(element) return elementList