diff --git a/bridges/Arte7Bridge.php b/bridges/Arte7Bridge.php
index 3d7ae9d..42b5afc 100644
--- a/bridges/Arte7Bridge.php
+++ b/bridges/Arte7Bridge.php
@@ -3,24 +3,28 @@ class Arte7Bridge extends BridgeAbstract {
const MAINTAINER = 'mitsukarenai';
const NAME = 'Arte +7';
- const URI = 'http://www.arte.tv/';
+ const URI = 'https://www.arte.tv/';
const CACHE_TIMEOUT = 1800; // 30min
const DESCRIPTION = 'Returns newest videos from ARTE +7';
+
+ const API_TOKEN = 'Nzc1Yjc1ZjJkYjk1NWFhN2I2MWEwMmRlMzAzNjI5NmU3NWU3ODg4ODJjOWMxNTMxYzEzZGRjYjg2ZGE4MmIwOA';
+
const PARAMETERS = array(
'Catégorie (Français)' => array(
'catfr' => array(
'type' => 'list',
'name' => 'Catégorie',
'values' => array(
- 'Toutes les vidéos (français)' => 'toutes-les-videos',
- 'Actu & société' => 'actu-société',
- 'Séries & fiction' => 'séries-fiction',
- 'Cinéma' => 'cinéma',
- 'Arts & spectacles classiques' => 'arts-spectacles-classiques',
- 'Culture pop' => 'culture-pop',
- 'Découverte' => 'découverte',
- 'Histoire' => 'histoire',
- 'Junior' => 'junior'
+ 'Toutes les vidéos (français)' => null,
+ 'Actu & société' => 'ACT',
+ 'Séries & fiction' => 'SER',
+ 'Cinéma' => 'CIN',
+ 'Arts & spectacles classiques' => 'ARS',
+ 'Culture pop' => 'CPO',
+ 'Découverte' => 'DEC',
+ 'Histoire' => 'HIST',
+ 'Science' => 'SCI',
+ 'Autre' => 'AUT'
)
)
),
@@ -29,15 +33,16 @@ class Arte7Bridge extends BridgeAbstract {
'type' => 'list',
'name' => 'Catégorie',
'values' => array(
- 'Alle Videos (deutsch)' => 'alle-videos',
- 'Aktuelles & Gesellschaft' => 'aktuelles-gesellschaft',
- 'Fernsehfilme & Serien' => 'fernsehfilme-serien',
- 'Kino' => 'kino',
- 'Kunst & Kultur' => 'kunst-kultur',
- 'Popkultur & Alternativ' => 'popkultur-alternativ',
- 'Entdeckung' => 'entdeckung',
- 'Geschichte' => 'geschichte',
- 'Junior' => 'junior'
+ 'Alle Videos (deutsch)' => null,
+ 'Aktuelles & Gesellschaft' => 'ACT',
+ 'Fernsehfilme & Serien' => 'SER',
+ 'Kino' => 'CIN',
+ 'Kunst & Kultur' => 'ARS',
+ 'Popkultur & Alternativ' => 'CPO',
+ 'Entdeckung' => 'DEC',
+ 'Geschichte' => 'HIST',
+ 'Wissenschaft' => 'SCI',
+ 'Sonstiges' => 'AUT'
)
)
)
@@ -55,44 +60,39 @@ class Arte7Bridge extends BridgeAbstract {
break;
}
- $url = self::URI . 'guide/' . $lang . '/plus7/' . $category;
- $input = getContents($url) or die('Could not request ARTE.');
+ $url = 'https://api.arte.tv/api/opa/v3/videos?sort=broadcastBegin&limit=10&language='
+ . $lang
+ . ($category != null ? '&category.code=' . $category : '');
- if(strpos($input, 'categoryVideoSet') !== false) {
- $input = explode('categoryVideoSet="', $input);
- $input = explode('}}', $input[1]);
- $input = $input[0] . '}}';
- } else {
- $input = explode('videoSet="', $input);
- $input = explode('}]}', $input[1]);
- $input = $input[0] . '}]}';
- }
+ $context = array(
+ 'http' => array(
+ 'header' => 'Authorization: Bearer '. self::API_TOKEN
+ )
+ );
- $input_json = json_decode(html_entity_decode($input, ENT_QUOTES), true);
+ $input = getContents($url, false, stream_context_create($context)) or die('Could not request ARTE.');
+ $input_json = json_decode($input, true);
foreach($input_json['videos'] as $element) {
+
$item = array();
- $item['uri'] = str_replace("autoplay=1", "", $element['url']);
+ $item['uri'] = $element['url'];
$item['id'] = $element['id'];
- $hack_broadcast_time = $element['rights_end'];
- $hack_broadcast_time = strtok($hack_broadcast_time, 'T');
- $hack_broadcast_time = strtok('T');
-
- $item['timestamp'] = strtotime($element['scheduled_on'] . 'T' . $hack_broadcast_time);
+ $item['timestamp'] = strtotime($element['videoRightsBegin']);
$item['title'] = $element['title'];
if(!empty($element['subtitle']))
$item['title'] = $element['title'] . ' | ' . $element['subtitle'];
- $item['duration'] = round((int)$element['duration'] / 60);
- $item['content'] = $element['teaser']
+ $item['duration'] = round((int)$element['durationSeconds'] / 60);
+ $item['content'] = $element['teaserText']
. '
'
. $item['duration']
. 'min
';
$this->items[] = $item;