1
0
Fork 0
mirror of https://github.com/ytdl-org/youtube-dl.git synced 2024-11-28 21:22:13 +00:00

[cnnturk] Add new extractor

This commit is contained in:
Eren Dogan 2023-12-22 01:34:31 -08:00
parent be008e657d
commit f6368b642a
2 changed files with 133 additions and 0 deletions

View file

@ -0,0 +1,132 @@
# coding: utf-8
from __future__ import unicode_literals
from .common import InfoExtractor
class CNNTurkIE(InfoExtractor):
_VALID_URL = r'''(?x)
https?://
(?:www\.)?cnnturk\.com/
(?:
tv-cnn-turk/programlar/|
video/|
turkiye/|
dunya/|
ekonomi/
)
(?:[^/]+/)*
(?P<id>[^/?#&]+)
'''
_TESTS = [
{
'url': 'https://www.cnnturk.com/tv-cnn-turk/programlar/'
'dort-bir-taraf/dort-bir-taraf-43',
'md5': 'ea49375a769545afdb8d63d4efb46f8b',
'info_dict': {
'id': 'dort-bir-taraf-43',
'ext': 'mp4',
'title': 'Dört Bir Taraf',
'description': 'Altan Öymen, Nazlı Ilıcak, Enver Aysever ve '
'Nagehan Alçı ülke gündemini dört farklı '
'ıdan değerlendiriyor. Sezaryen ve kürtaj '
'polemiğinde gerçekler ve yanıl...',
'thumbnail': 'https://image.cnnturk.com/i/cnnturk/75/1200x675/'
'542174c1cecfbe19c07cacea.jpg',
'upload_date': '20120601',
}
},
{
'url': 'https://www.cnnturk.com/tv-cnn-turk/programlar/'
'tarafsiz-bolge/mahalle-baskisi-anayasa-tartismasi',
'md5': 'c3999fbe0fb3366b36cb2ea56d692697',
'info_dict': {
'id': 'mahalle-baskisi-anayasa-tartismasi',
'ext': 'mp4',
'title': 'MAHALLE BASKISI - ANAYASA TARTIŞMASI',
'description': 'MAHALLE BASKISI , ANAYASA TARTIŞMASI ,'
'ŞAHİN MENGÜ , YAVUZ ATAR , FARUK BAL , '
'NURAY MERT , TOKTAMIŞ ATEŞ , EMRE AKÖZ , '
'AYŞE BÖHÜRLER...',
'thumbnail': 'https://image.cnnturk.com/i/cnnturk/75/1200x675/'
'63530cb4bf773b1104bb482d.jpg',
'upload_date': '20120330',
}
},
{
'url': 'https://www.cnnturk.com/tv-cnn-turk/programlar/'
'edip-akbayram-enver-aysever-in-sorularini-yanitladi-'
'aykiri-sorular-09-07-2012',
'md5': '36814483fe64d450f35c985d5a2d2d18',
'info_dict': {
'id': 'edip-akbayram-enver-aysever-in-sorularini-yanitladi-'
'aykiri-sorular-09-07-2012',
'ext': 'mp4',
'title': 'Edip Akbayram, Enver Ayseverin sorularını yanıtladı'
' - Aykırı Sorular (09.07.2012)',
'description': 'Anadolu Pop Müziğinin önde gelen isimlerinden '
'Edip Akbayram 9 Temmuz 2012 tarihli '
'Aykırı Sorular programında Enver Ayseverin '
'konuğu oldu....',
'thumbnail': 'https://image.cnnturk.com/i/cnnturk/75/1200x675/'
'54353b6dcecfbe1578205c80.jpg',
'upload_date': '20120710',
}
},
{
'url': 'https://www.cnnturk.com/tv-cnn-turk/programlar/'
'aykiri-sorular/ilber-ortayli-enver-ayseverin-sorularini-'
'yanitladi-aykiri-sorular-16-06-2014',
'md5': '36814483fe64d450f35c985d5a2d2d18',
'info_dict': {
'id': 'ilber-ortayli-enver-ayseverin-sorularini-yanitladi-'
'aykiri-sorular-16-06-2014',
'ext': 'm3u8',
'title': 'İlber Ortaylı Enver Aysever\'in sorularını yanıtladı:'
' Aykırı Sorular - 16.06.2014',
'description': 'Aykırı Sorular, Tarihçi '
'Prof. Dr. İlber Ortaylıyı konuk etti. '
'Cumhurbaşkanı seçimi Türkiye açısından ne '
'ifade ediyor? Çatı adayı muhalefeti '
'birleştirebilece...',
'thumbnail': 'https://image.cnnturk.com/i/cnnturk/75/1200x675/'
'54353e78cecfbe15782068ae.jpg',
'upload_date': '20140617',
},
'params': {
# m3u8 download
'skip_download': True,
}
}
]
def _real_extract(self, url):
video_id = self._match_id(url)
webpage = self._download_webpage(url, video_id)
# Video info is a JSON object inside a script tag
video_info = self._parse_json(
self._search_regex(
r'({"Ancestors":.+?\);)', webpage, 'stream')[:-2],
video_id)
video_url = video_info['MediaFiles'][0]['Path']
if not video_url.startswith("http"):
video_url = 'https://cnnvod.duhnet.tv/' + video_url
extension = 'mp4' if video_url.endswith('mp4') else 'm3u8'
formats = [{
'url': video_url,
'ext': extension,
'language': 'tr',
}]
return {
'id': video_id,
'title': self._og_search_title(webpage),
'description': self._og_search_description(webpage),
'thumbnail': self._og_search_thumbnail(webpage),
'release_date': video_info['published_date'],
'upload_date': video_info['created_date'],
'formats': formats,
}

View file

@ -246,6 +246,7 @@ from .cnn import (
CNNBlogsIE,
CNNArticleIE,
)
from .cnnturk import CNNTurkIE
from .coub import CoubIE
from .comedycentral import (
ComedyCentralIE,