[PolpoTV] new channel for kod

This commit is contained in:
Whiplash
2019-10-19 00:08:48 +02:00
parent 6beebe2d1b
commit aa19c3ec09
2 changed files with 147 additions and 0 deletions

22
channels/polpotv.json Normal file
View File

@@ -0,0 +1,22 @@
{
"id": "polpotv",
"name": "PolpoTV",
"language": ["it"],
"active": true,
"adult": false,
"thumbnail": "https://polpo.tv/build/assets/apple-touch-icon-152x152.png",
"banner": "https://polpo.tv/build/assets/apple-touch-icon-152x152.png",
"categories": [
"movie"
],
"settings": [
{
"id": "include_in_global_search",
"type": "bool",
"label": "Includi ricerca globale",
"default": false,
"enabled": false,
"visible": true
}
]
}

125
channels/polpotv.py Normal file
View File

@@ -0,0 +1,125 @@
# -*- coding: utf-8 -*-
# ------------------------------------------------------------
# kod - XBMC Plugin
# Canale polpotv
# ------------------------------------------------------------
from platformcode import logger
from core import scrapertools, httptools
from core.item import Item
from platformcode import config
import json
from core import jsontools
host = "https://polpo.tv"
headers = [['Accept', 'application/ld+json']]
def mainlist(item):
logger.info("kod.polpotv mainlist")
itemlist = [Item(channel=item.channel,
title="[COLOR azure]Ultimi Film Aggiunti[/COLOR]",
action="peliculas",
url="%s/api/movies?order[lastReleaseAt]=desc" %host,
thumbnail="http://orig03.deviantart.net/6889/f/2014/079/7/b/movies_and_popcorn_folder_icon_by_matheusgrilo-d7ay4tw.png",
extra="movie"),
Item(channel=item.channel,
action="search",
title="[COLOR yellow]Cerca...[/COLOR]",
extra="movie",
thumbnail="http://orig03.deviantart.net/6889/f/2014/079/7/b/movies_and_popcorn_folder_icon_by_matheusgrilo-d7ay4tw.png"),
]
return itemlist
def peliculas(item):
logger.error("kod.polpotv peliculas")
logger.error(item.url)
itemlist = []
data = httptools.downloadpage(item.url, headers=headers).data
json_object = jsontools.load(data)
for movie in json_object['hydra:member']:
itemlist.extend(get_itemlist_movie(movie,item))
if json_object['hydra:view']['hydra:next'] is not None:
itemlist.append(
Item(channel=item.channel,
action="peliculas",
title="[COLOR lightgreen]" + config.get_localized_string(30992) + "[/COLOR]",
url="%s"%host +json_object['hydra:view']['hydra:next'],
extra=item.extra,
thumbnail="http://badwolfrepo.altervista.org/themes/successivo2.png"))
return itemlist
def search(item, texto):
logger.info("kod.polpotv " + item.url + " search " + texto)
itemlist=[]
try:
item.url = host + "/api/movies?originalTitle="+texto+"&translations.name=" +texto
data = httptools.downloadpage(item.url, headers=headers).data
json_object = jsontools.load(data)
for movie in json_object['hydra:member']:
itemlist.extend(get_itemlist_movie(movie,item))
return itemlist
# Continua la ricerca in caso di errore
except:
import sys
for line in sys.exc_info():
logger.error("%s" % line)
return []
def findvideos(item):
logger.info("kod.polpotv peliculas")
itemlist = []
data = httptools.downloadpage(item.url, headers=headers).data
json_object = jsontools.load(data)
for video in json_object['hydra:member'][0]['playlist']['videos']:
data = httptools.downloadpage(video['src'], headers={'Origin': host},follow_redirects=None).data
patron = 'href="([^"]+)"'
video_link = scrapertools.find_single_match(data, patron)
itemlist.append(
Item(
channel=item.channel,
action="play",
thumbnail=item.thumbnail,
title=item.title +' [COLOR orange][' +str(video['size'])+ 'p][/COLOR]',
url=video_link,
folder=False))
if config.get_videolibrary_support() and len(itemlist) > 0 and item.extra != 'findvideos':
itemlist.append(
Item(channel=item.channel, title="[COLOR yellow]%s[/COLOR]" % config.get_localized_string(30161), url=item.url,
action="add_pelicula_to_library", extra="findvideos", contentTitle=item.contentTitle))
return itemlist
def get_itemlist_movie(movie,item):
itemlist=[]
try:
if movie['originalLanguage']['id']=='it':
scrapedtitle=movie['originalTitle']
else:
scrapedtitle=movie['translations'][1]['name']
if scrapedtitle=='':
scrapedtitle=movie['originalTitle']
except:
scrapedtitle=movie['originalTitle']
try:
scrapedplot=movie['translations'][1]['overview']
except:
scrapedplot = ""
scrapedthumbnail = ""
itemlist.append(
Item(channel=item.channel,
action="findvideos",
title="[COLOR azure]" + scrapedtitle + "[/COLOR]",
fulltitle=scrapedtitle,
show=scrapedtitle,
plot=scrapedplot,
thumbnail=scrapedthumbnail,
contentType='movie',
contentTitle=scrapedtitle,
url="%s%s/releases" %(host,movie['@id'] ),
extra=item.extra))
return itemlist