Browse Source

Add support for https for all extractors as preventive and future-proof measure

Sergey M․ 9 năm trước cách đây
mục cha
commit
5886b38d73
100 tập tin đã thay đổi với 126 bổ sung126 xóa
  1. 1 1
      youtube_dl/extractor/abc.py
  2. 1 1
      youtube_dl/extractor/addanime.py
  3. 1 1
      youtube_dl/extractor/aftonbladet.py
  4. 1 1
      youtube_dl/extractor/aljazeera.py
  5. 2 2
      youtube_dl/extractor/aol.py
  6. 1 1
      youtube_dl/extractor/arte.py
  7. 1 1
      youtube_dl/extractor/azubu.py
  8. 1 1
      youtube_dl/extractor/baidu.py
  9. 1 1
      youtube_dl/extractor/bbc.py
  10. 1 1
      youtube_dl/extractor/behindkink.py
  11. 1 1
      youtube_dl/extractor/bilibili.py
  12. 1 1
      youtube_dl/extractor/bokecc.py
  13. 1 1
      youtube_dl/extractor/bpb.py
  14. 1 1
      youtube_dl/extractor/breakcom.py
  15. 2 2
      youtube_dl/extractor/camdemy.py
  16. 2 2
      youtube_dl/extractor/cbsnews.py
  17. 1 1
      youtube_dl/extractor/cbssports.py
  18. 1 1
      youtube_dl/extractor/cliphunter.py
  19. 1 1
      youtube_dl/extractor/clipsyndicate.py
  20. 1 1
      youtube_dl/extractor/clubic.py
  21. 1 1
      youtube_dl/extractor/comcarcoff.py
  22. 1 1
      youtube_dl/extractor/condenast.py
  23. 1 1
      youtube_dl/extractor/cspan.py
  24. 1 1
      youtube_dl/extractor/ctsnews.py
  25. 1 1
      youtube_dl/extractor/dctp.py
  26. 1 1
      youtube_dl/extractor/defense.py
  27. 1 1
      youtube_dl/extractor/douyutv.py
  28. 1 1
      youtube_dl/extractor/dplay.py
  29. 1 1
      youtube_dl/extractor/dreisat.py
  30. 1 1
      youtube_dl/extractor/dvtv.py
  31. 1 1
      youtube_dl/extractor/echomsk.py
  32. 1 1
      youtube_dl/extractor/exfm.py
  33. 1 1
      youtube_dl/extractor/fc2.py
  34. 1 1
      youtube_dl/extractor/firstpost.py
  35. 1 1
      youtube_dl/extractor/firsttv.py
  36. 1 1
      youtube_dl/extractor/fktv.py
  37. 1 1
      youtube_dl/extractor/footyroom.py
  38. 1 1
      youtube_dl/extractor/foxgay.py
  39. 1 1
      youtube_dl/extractor/franceinter.py
  40. 1 1
      youtube_dl/extractor/freevideo.py
  41. 1 1
      youtube_dl/extractor/gamekings.py
  42. 1 1
      youtube_dl/extractor/gamespot.py
  43. 1 1
      youtube_dl/extractor/gamestar.py
  44. 1 1
      youtube_dl/extractor/gametrailers.py
  45. 1 1
      youtube_dl/extractor/hotnewhiphop.py
  46. 1 1
      youtube_dl/extractor/hypem.py
  47. 2 2
      youtube_dl/extractor/imdb.py
  48. 1 1
      youtube_dl/extractor/iqiyi.py
  49. 1 1
      youtube_dl/extractor/jadorecettepub.py
  50. 1 1
      youtube_dl/extractor/jeuxvideo.py
  51. 1 1
      youtube_dl/extractor/karaoketv.py
  52. 1 1
      youtube_dl/extractor/karrierevideos.py
  53. 1 1
      youtube_dl/extractor/kontrtube.py
  54. 1 1
      youtube_dl/extractor/ku6.py
  55. 1 1
      youtube_dl/extractor/kusi.py
  56. 6 6
      youtube_dl/extractor/kuwo.py
  57. 2 2
      youtube_dl/extractor/leeco.py
  58. 2 2
      youtube_dl/extractor/lifenews.py
  59. 3 3
      youtube_dl/extractor/limelight.py
  60. 1 1
      youtube_dl/extractor/m6.py
  61. 1 1
      youtube_dl/extractor/metacafe.py
  62. 1 1
      youtube_dl/extractor/mit.py
  63. 1 1
      youtube_dl/extractor/mitele.py
  64. 1 1
      youtube_dl/extractor/mooshare.py
  65. 1 1
      youtube_dl/extractor/motherless.py
  66. 1 1
      youtube_dl/extractor/motorsport.py
  67. 1 1
      youtube_dl/extractor/myspass.py
  68. 1 1
      youtube_dl/extractor/myvideo.py
  69. 1 1
      youtube_dl/extractor/myvidster.py
  70. 1 1
      youtube_dl/extractor/nationalgeographic.py
  71. 2 2
      youtube_dl/extractor/nbc.py
  72. 3 3
      youtube_dl/extractor/nextmedia.py
  73. 1 1
      youtube_dl/extractor/noco.py
  74. 1 1
      youtube_dl/extractor/normalboots.py
  75. 1 1
      youtube_dl/extractor/nova.py
  76. 1 1
      youtube_dl/extractor/npr.py
  77. 1 1
      youtube_dl/extractor/ntvru.py
  78. 3 3
      youtube_dl/extractor/orf.py
  79. 1 1
      youtube_dl/extractor/philharmoniedeparis.py
  80. 1 1
      youtube_dl/extractor/photobucket.py
  81. 1 1
      youtube_dl/extractor/pornhd.py
  82. 1 1
      youtube_dl/extractor/pornovoisines.py
  83. 1 1
      youtube_dl/extractor/pyvideo.py
  84. 5 5
      youtube_dl/extractor/qqmusic.py
  85. 2 2
      youtube_dl/extractor/rai.py
  86. 1 1
      youtube_dl/extractor/redtube.py
  87. 1 1
      youtube_dl/extractor/ringtv.py
  88. 2 2
      youtube_dl/extractor/rtve.py
  89. 1 1
      youtube_dl/extractor/ruhd.py
  90. 3 3
      youtube_dl/extractor/rutube.py
  91. 1 1
      youtube_dl/extractor/screenjunkies.py
  92. 1 1
      youtube_dl/extractor/senateisvp.py
  93. 1 1
      youtube_dl/extractor/shared.py
  94. 1 1
      youtube_dl/extractor/sport5.py
  95. 1 1
      youtube_dl/extractor/ssa.py
  96. 1 1
      youtube_dl/extractor/sztvhu.py
  97. 1 1
      youtube_dl/extractor/teamcoco.py
  98. 1 1
      youtube_dl/extractor/tele13.py
  99. 1 1
      youtube_dl/extractor/tf1.py
  100. 1 1
      youtube_dl/extractor/thvideo.py

+ 1 - 1
youtube_dl/extractor/abc.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 class ABCIE(InfoExtractor):
 class ABCIE(InfoExtractor):
     IE_NAME = 'abc.net.au'
     IE_NAME = 'abc.net.au'
-    _VALID_URL = r'http://www\.abc\.net\.au/news/(?:[^/]+/){1,2}(?P<id>\d+)'
+    _VALID_URL = r'https?://www\.abc\.net\.au/news/(?:[^/]+/){1,2}(?P<id>\d+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.abc.net.au/news/2014-11-05/australia-to-staff-ebola-treatment-centre-in-sierra-leone/5868334',
         'url': 'http://www.abc.net.au/news/2014-11-05/australia-to-staff-ebola-treatment-centre-in-sierra-leone/5868334',

+ 1 - 1
youtube_dl/extractor/addanime.py

@@ -16,7 +16,7 @@ from ..utils import (
 
 
 
 
 class AddAnimeIE(InfoExtractor):
 class AddAnimeIE(InfoExtractor):
-    _VALID_URL = r'http://(?:\w+\.)?add-anime\.net/(?:watch_video\.php\?(?:.*?)v=|video/)(?P<id>[\w_]+)'
+    _VALID_URL = r'https?://(?:\w+\.)?add-anime\.net/(?:watch_video\.php\?(?:.*?)v=|video/)(?P<id>[\w_]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.add-anime.net/watch_video.php?v=24MR3YO5SAS9',
         'url': 'http://www.add-anime.net/watch_video.php?v=24MR3YO5SAS9',
         'md5': '72954ea10bc979ab5e2eb288b21425a0',
         'md5': '72954ea10bc979ab5e2eb288b21425a0',

+ 1 - 1
youtube_dl/extractor/aftonbladet.py

@@ -6,7 +6,7 @@ from ..utils import int_or_none
 
 
 
 
 class AftonbladetIE(InfoExtractor):
 class AftonbladetIE(InfoExtractor):
-    _VALID_URL = r'http://tv\.aftonbladet\.se/abtv/articles/(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://tv\.aftonbladet\.se/abtv/articles/(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://tv.aftonbladet.se/abtv/articles/36015',
         'url': 'http://tv.aftonbladet.se/abtv/articles/36015',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/aljazeera.py

@@ -4,7 +4,7 @@ from .common import InfoExtractor
 
 
 
 
 class AlJazeeraIE(InfoExtractor):
 class AlJazeeraIE(InfoExtractor):
-    _VALID_URL = r'http://www\.aljazeera\.com/programmes/.*?/(?P<id>[^/]+)\.html'
+    _VALID_URL = r'https?://www\.aljazeera\.com/programmes/.*?/(?P<id>[^/]+)\.html'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.aljazeera.com/programmes/the-slum/2014/08/deliverance-201482883754237240.html',
         'url': 'http://www.aljazeera.com/programmes/the-slum/2014/08/deliverance-201482883754237240.html',

+ 2 - 2
youtube_dl/extractor/aol.py

@@ -5,7 +5,7 @@ from .common import InfoExtractor
 
 
 class AolIE(InfoExtractor):
 class AolIE(InfoExtractor):
     IE_NAME = 'on.aol.com'
     IE_NAME = 'on.aol.com'
-    _VALID_URL = r'(?:aol-video:|http://on\.aol\.com/video/.*-)(?P<id>[0-9]+)(?:$|\?)'
+    _VALID_URL = r'(?:aol-video:|https?://on\.aol\.com/video/.*-)(?P<id>[0-9]+)(?:$|\?)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://on.aol.com/video/u-s--official-warns-of-largest-ever-irs-phone-scam-518167793?icid=OnHomepageC2Wide_MustSee_Img',
         'url': 'http://on.aol.com/video/u-s--official-warns-of-largest-ever-irs-phone-scam-518167793?icid=OnHomepageC2Wide_MustSee_Img',
@@ -25,7 +25,7 @@ class AolIE(InfoExtractor):
 
 
 class AolFeaturesIE(InfoExtractor):
 class AolFeaturesIE(InfoExtractor):
     IE_NAME = 'features.aol.com'
     IE_NAME = 'features.aol.com'
-    _VALID_URL = r'http://features\.aol\.com/video/(?P<id>[^/?#]+)'
+    _VALID_URL = r'https?://features\.aol\.com/video/(?P<id>[^/?#]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://features.aol.com/video/behind-secret-second-careers-late-night-talk-show-hosts',
         'url': 'http://features.aol.com/video/behind-secret-second-careers-late-night-talk-show-hosts',

+ 1 - 1
youtube_dl/extractor/arte.py

@@ -23,7 +23,7 @@ from ..utils import (
 
 
 
 
 class ArteTvIE(InfoExtractor):
 class ArteTvIE(InfoExtractor):
-    _VALID_URL = r'http://videos\.arte\.tv/(?P<lang>fr|de|en|es)/.*-(?P<id>.*?)\.html'
+    _VALID_URL = r'https?://videos\.arte\.tv/(?P<lang>fr|de|en|es)/.*-(?P<id>.*?)\.html'
     IE_NAME = 'arte.tv'
     IE_NAME = 'arte.tv'
 
 
     def _real_extract(self, url):
     def _real_extract(self, url):

+ 1 - 1
youtube_dl/extractor/azubu.py

@@ -98,7 +98,7 @@ class AzubuIE(InfoExtractor):
 
 
 
 
 class AzubuLiveIE(InfoExtractor):
 class AzubuLiveIE(InfoExtractor):
-    _VALID_URL = r'http://www.azubu.tv/(?P<id>[^/]+)$'
+    _VALID_URL = r'https?://www.azubu.tv/(?P<id>[^/]+)$'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.azubu.tv/MarsTVMDLen',
         'url': 'http://www.azubu.tv/MarsTVMDLen',

+ 1 - 1
youtube_dl/extractor/baidu.py

@@ -9,7 +9,7 @@ from ..utils import unescapeHTML
 
 
 class BaiduVideoIE(InfoExtractor):
 class BaiduVideoIE(InfoExtractor):
     IE_DESC = '百度视频'
     IE_DESC = '百度视频'
-    _VALID_URL = r'http://v\.baidu\.com/(?P<type>[a-z]+)/(?P<id>\d+)\.htm'
+    _VALID_URL = r'https?://v\.baidu\.com/(?P<type>[a-z]+)/(?P<id>\d+)\.htm'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://v.baidu.com/comic/1069.htm?frp=bdbrand&q=%E4%B8%AD%E5%8D%8E%E5%B0%8F%E5%BD%93%E5%AE%B6',
         'url': 'http://v.baidu.com/comic/1069.htm?frp=bdbrand&q=%E4%B8%AD%E5%8D%8E%E5%B0%8F%E5%BD%93%E5%AE%B6',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/bbc.py

@@ -942,7 +942,7 @@ class BBCIE(BBCCoUkIE):
 
 
 
 
 class BBCCoUkArticleIE(InfoExtractor):
 class BBCCoUkArticleIE(InfoExtractor):
-    _VALID_URL = r'http://www.bbc.co.uk/programmes/articles/(?P<id>[a-zA-Z0-9]+)'
+    _VALID_URL = r'https?://www.bbc.co.uk/programmes/articles/(?P<id>[a-zA-Z0-9]+)'
     IE_NAME = 'bbc.co.uk:article'
     IE_NAME = 'bbc.co.uk:article'
     IE_DESC = 'BBC articles'
     IE_DESC = 'BBC articles'
 
 

+ 1 - 1
youtube_dl/extractor/behindkink.py

@@ -8,7 +8,7 @@ from ..utils import url_basename
 
 
 
 
 class BehindKinkIE(InfoExtractor):
 class BehindKinkIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?behindkink\.com/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/(?P<id>[^/#?_]+)'
+    _VALID_URL = r'https?://(?:www\.)?behindkink\.com/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<day>[0-9]{2})/(?P<id>[^/#?_]+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.behindkink.com/2014/12/05/what-are-you-passionate-about-marley-blaze/',
         'url': 'http://www.behindkink.com/2014/12/05/what-are-you-passionate-about-marley-blaze/',
         'md5': '507b57d8fdcd75a41a9a7bdb7989c762',
         'md5': '507b57d8fdcd75a41a9a7bdb7989c762',

+ 1 - 1
youtube_dl/extractor/bilibili.py

@@ -14,7 +14,7 @@ from ..utils import (
 
 
 
 
 class BiliBiliIE(InfoExtractor):
 class BiliBiliIE(InfoExtractor):
-    _VALID_URL = r'http://www\.bilibili\.(?:tv|com)/video/av(?P<id>\d+)(?:/index_(?P<page_num>\d+).html)?'
+    _VALID_URL = r'https?://www\.bilibili\.(?:tv|com)/video/av(?P<id>\d+)(?:/index_(?P<page_num>\d+).html)?'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.bilibili.tv/video/av1074402/',
         'url': 'http://www.bilibili.tv/video/av1074402/',

+ 1 - 1
youtube_dl/extractor/bokecc.py

@@ -33,7 +33,7 @@ class BokeCCBaseIE(InfoExtractor):
 
 
 class BokeCCIE(BokeCCBaseIE):
 class BokeCCIE(BokeCCBaseIE):
     _IE_DESC = 'CC视频'
     _IE_DESC = 'CC视频'
-    _VALID_URL = r'http://union\.bokecc\.com/playvideo\.bo\?(?P<query>.*)'
+    _VALID_URL = r'https?://union\.bokecc\.com/playvideo\.bo\?(?P<query>.*)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://union.bokecc.com/playvideo.bo?vid=E44D40C15E65EA30&uid=CD0C5D3C8614B28B',
         'url': 'http://union.bokecc.com/playvideo.bo?vid=E44D40C15E65EA30&uid=CD0C5D3C8614B28B',

+ 1 - 1
youtube_dl/extractor/bpb.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 class BpbIE(InfoExtractor):
 class BpbIE(InfoExtractor):
     IE_DESC = 'Bundeszentrale für politische Bildung'
     IE_DESC = 'Bundeszentrale für politische Bildung'
-    _VALID_URL = r'http://www\.bpb\.de/mediathek/(?P<id>[0-9]+)/'
+    _VALID_URL = r'https?://www\.bpb\.de/mediathek/(?P<id>[0-9]+)/'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.bpb.de/mediathek/297/joachim-gauck-zu-1989-und-die-erinnerung-an-die-ddr',
         'url': 'http://www.bpb.de/mediathek/297/joachim-gauck-zu-1989-und-die-erinnerung-an-die-ddr',

+ 1 - 1
youtube_dl/extractor/breakcom.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 
 
 class BreakIE(InfoExtractor):
 class BreakIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?break\.com/video/(?:[^/]+/)*.+-(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www\.)?break\.com/video/(?:[^/]+/)*.+-(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.break.com/video/when-girls-act-like-guys-2468056',
         'url': 'http://www.break.com/video/when-girls-act-like-guys-2468056',
         'info_dict': {
         'info_dict': {

+ 2 - 2
youtube_dl/extractor/camdemy.py

@@ -16,7 +16,7 @@ from ..utils import (
 
 
 
 
 class CamdemyIE(InfoExtractor):
 class CamdemyIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?camdemy\.com/media/(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www\.)?camdemy\.com/media/(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         # single file
         # single file
         'url': 'http://www.camdemy.com/media/5181/',
         'url': 'http://www.camdemy.com/media/5181/',
@@ -104,7 +104,7 @@ class CamdemyIE(InfoExtractor):
 
 
 
 
 class CamdemyFolderIE(InfoExtractor):
 class CamdemyFolderIE(InfoExtractor):
-    _VALID_URL = r'http://www.camdemy.com/folder/(?P<id>\d+)'
+    _VALID_URL = r'https?://www.camdemy.com/folder/(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         # links with trailing slash
         # links with trailing slash
         'url': 'http://www.camdemy.com/folder/450',
         'url': 'http://www.camdemy.com/folder/450',

+ 2 - 2
youtube_dl/extractor/cbsnews.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 class CBSNewsIE(ThePlatformIE):
 class CBSNewsIE(ThePlatformIE):
     IE_DESC = 'CBS News'
     IE_DESC = 'CBS News'
-    _VALID_URL = r'http://(?:www\.)?cbsnews\.com/(?:news|videos)/(?P<id>[\da-z_-]+)'
+    _VALID_URL = r'https?://(?:www\.)?cbsnews\.com/(?:news|videos)/(?P<id>[\da-z_-]+)'
 
 
     _TESTS = [
     _TESTS = [
         {
         {
@@ -96,7 +96,7 @@ class CBSNewsIE(ThePlatformIE):
 
 
 class CBSNewsLiveVideoIE(InfoExtractor):
 class CBSNewsLiveVideoIE(InfoExtractor):
     IE_DESC = 'CBS News Live Videos'
     IE_DESC = 'CBS News Live Videos'
-    _VALID_URL = r'http://(?:www\.)?cbsnews\.com/live/video/(?P<id>[\da-z_-]+)'
+    _VALID_URL = r'https?://(?:www\.)?cbsnews\.com/live/video/(?P<id>[\da-z_-]+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.cbsnews.com/live/video/clinton-sanders-prepare-to-face-off-in-nh/',
         'url': 'http://www.cbsnews.com/live/video/clinton-sanders-prepare-to-face-off-in-nh/',

+ 1 - 1
youtube_dl/extractor/cbssports.py

@@ -6,7 +6,7 @@ from .common import InfoExtractor
 
 
 
 
 class CBSSportsIE(InfoExtractor):
 class CBSSportsIE(InfoExtractor):
-    _VALID_URL = r'http://www\.cbssports\.com/video/player/(?P<section>[^/]+)/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://www\.cbssports\.com/video/player/(?P<section>[^/]+)/(?P<id>[^/]+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.cbssports.com/video/player/tennis/318462531970/0/us-open-flashbacks-1990s',
         'url': 'http://www.cbssports.com/video/player/tennis/318462531970/0/us-open-flashbacks-1990s',

+ 1 - 1
youtube_dl/extractor/cliphunter.py

@@ -19,7 +19,7 @@ def _decode(s):
 class CliphunterIE(InfoExtractor):
 class CliphunterIE(InfoExtractor):
     IE_NAME = 'cliphunter'
     IE_NAME = 'cliphunter'
 
 
-    _VALID_URL = r'''(?x)http://(?:www\.)?cliphunter\.com/w/
+    _VALID_URL = r'''(?x)https?://(?:www\.)?cliphunter\.com/w/
         (?P<id>[0-9]+)/
         (?P<id>[0-9]+)/
         (?P<seo>.+?)(?:$|[#\?])
         (?P<seo>.+?)(?:$|[#\?])
     '''
     '''

+ 1 - 1
youtube_dl/extractor/clipsyndicate.py

@@ -8,7 +8,7 @@ from ..utils import (
 
 
 
 
 class ClipsyndicateIE(InfoExtractor):
 class ClipsyndicateIE(InfoExtractor):
-    _VALID_URL = r'http://(?:chic|www)\.clipsyndicate\.com/video/play(list/\d+)?/(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:chic|www)\.clipsyndicate\.com/video/play(list/\d+)?/(?P<id>\d+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.clipsyndicate.com/video/play/4629301/brick_briscoe',
         'url': 'http://www.clipsyndicate.com/video/play/4629301/brick_briscoe',

+ 1 - 1
youtube_dl/extractor/clubic.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class ClubicIE(InfoExtractor):
 class ClubicIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?clubic\.com/video/(?:[^/]+/)*video.*-(?P<id>[0-9]+)\.html'
+    _VALID_URL = r'https?://(?:www\.)?clubic\.com/video/(?:[^/]+/)*video.*-(?P<id>[0-9]+)\.html'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.clubic.com/video/clubic-week/video-clubic-week-2-0-le-fbi-se-lance-dans-la-photo-d-identite-448474.html',
         'url': 'http://www.clubic.com/video/clubic-week/video-clubic-week-2-0-le-fbi-se-lance-dans-la-photo-d-identite-448474.html',

+ 1 - 1
youtube_dl/extractor/comcarcoff.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 
 
 class ComCarCoffIE(InfoExtractor):
 class ComCarCoffIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?comediansincarsgettingcoffee\.com/(?P<id>[a-z0-9\-]*)'
+    _VALID_URL = r'https?://(?:www\.)?comediansincarsgettingcoffee\.com/(?P<id>[a-z0-9\-]*)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://comediansincarsgettingcoffee.com/miranda-sings-happy-thanksgiving-miranda/',
         'url': 'http://comediansincarsgettingcoffee.com/miranda-sings-happy-thanksgiving-miranda/',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/condenast.py

@@ -45,7 +45,7 @@ class CondeNastIE(InfoExtractor):
         'wmagazine': 'W Magazine',
         'wmagazine': 'W Magazine',
     }
     }
 
 
-    _VALID_URL = r'http://(?:video|www|player)\.(?P<site>%s)\.com/(?P<type>watch|series|video|embed(?:js)?)/(?P<id>[^/?#]+)' % '|'.join(_SITES.keys())
+    _VALID_URL = r'https?://(?:video|www|player)\.(?P<site>%s)\.com/(?P<type>watch|series|video|embed(?:js)?)/(?P<id>[^/?#]+)' % '|'.join(_SITES.keys())
     IE_DESC = 'Condé Nast media group: %s' % ', '.join(sorted(_SITES.values()))
     IE_DESC = 'Condé Nast media group: %s' % ', '.join(sorted(_SITES.values()))
 
 
     EMBED_URL = r'(?:https?:)?//player\.(?P<site>%s)\.com/(?P<type>embed(?:js)?)/.+?' % '|'.join(_SITES.keys())
     EMBED_URL = r'(?:https?:)?//player\.(?P<site>%s)\.com/(?P<type>embed(?:js)?)/.+?' % '|'.join(_SITES.keys())

+ 1 - 1
youtube_dl/extractor/cspan.py

@@ -15,7 +15,7 @@ from .senateisvp import SenateISVPIE
 
 
 
 
 class CSpanIE(InfoExtractor):
 class CSpanIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?c-span\.org/video/\?(?P<id>[0-9a-f]+)'
+    _VALID_URL = r'https?://(?:www\.)?c-span\.org/video/\?(?P<id>[0-9a-f]+)'
     IE_DESC = 'C-SPAN'
     IE_DESC = 'C-SPAN'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.c-span.org/video/?313572-1/HolderonV',
         'url': 'http://www.c-span.org/video/?313572-1/HolderonV',

+ 1 - 1
youtube_dl/extractor/ctsnews.py

@@ -8,7 +8,7 @@ from ..utils import parse_iso8601, ExtractorError
 class CtsNewsIE(InfoExtractor):
 class CtsNewsIE(InfoExtractor):
     IE_DESC = '華視新聞'
     IE_DESC = '華視新聞'
     # https connection failed (Connection reset)
     # https connection failed (Connection reset)
-    _VALID_URL = r'http://news\.cts\.com\.tw/[a-z]+/[a-z]+/\d+/(?P<id>\d+)\.html'
+    _VALID_URL = r'https?://news\.cts\.com\.tw/[a-z]+/[a-z]+/\d+/(?P<id>\d+)\.html'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://news.cts.com.tw/cts/international/201501/201501291578109.html',
         'url': 'http://news.cts.com.tw/cts/international/201501/201501291578109.html',
         'md5': 'a9875cb790252b08431186d741beaabe',
         'md5': 'a9875cb790252b08431186d741beaabe',

+ 1 - 1
youtube_dl/extractor/dctp.py

@@ -6,7 +6,7 @@ from ..compat import compat_str
 
 
 
 
 class DctpTvIE(InfoExtractor):
 class DctpTvIE(InfoExtractor):
-    _VALID_URL = r'http://www.dctp.tv/(#/)?filme/(?P<id>.+?)/$'
+    _VALID_URL = r'https?://www.dctp.tv/(#/)?filme/(?P<id>.+?)/$'
     _TEST = {
     _TEST = {
         'url': 'http://www.dctp.tv/filme/videoinstallation-fuer-eine-kaufhausfassade/',
         'url': 'http://www.dctp.tv/filme/videoinstallation-fuer-eine-kaufhausfassade/',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/defense.py

@@ -5,7 +5,7 @@ from .common import InfoExtractor
 
 
 class DefenseGouvFrIE(InfoExtractor):
 class DefenseGouvFrIE(InfoExtractor):
     IE_NAME = 'defense.gouv.fr'
     IE_NAME = 'defense.gouv.fr'
-    _VALID_URL = r'http://.*?\.defense\.gouv\.fr/layout/set/ligthboxvideo/base-de-medias/webtv/(?P<id>[^/?#]*)'
+    _VALID_URL = r'https?://.*?\.defense\.gouv\.fr/layout/set/ligthboxvideo/base-de-medias/webtv/(?P<id>[^/?#]*)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.defense.gouv.fr/layout/set/ligthboxvideo/base-de-medias/webtv/attaque-chimique-syrienne-du-21-aout-2013-1',
         'url': 'http://www.defense.gouv.fr/layout/set/ligthboxvideo/base-de-medias/webtv/attaque-chimique-syrienne-du-21-aout-2013-1',

+ 1 - 1
youtube_dl/extractor/douyutv.py

@@ -10,7 +10,7 @@ from ..compat import (compat_str, compat_basestring)
 
 
 class DouyuTVIE(InfoExtractor):
 class DouyuTVIE(InfoExtractor):
     IE_DESC = '斗鱼'
     IE_DESC = '斗鱼'
-    _VALID_URL = r'http://(?:www\.)?douyutv\.com/(?P<id>[A-Za-z0-9]+)'
+    _VALID_URL = r'https?://(?:www\.)?douyutv\.com/(?P<id>[A-Za-z0-9]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.douyutv.com/iseven',
         'url': 'http://www.douyutv.com/iseven',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/dplay.py

@@ -10,7 +10,7 @@ from ..utils import int_or_none
 
 
 
 
 class DPlayIE(InfoExtractor):
 class DPlayIE(InfoExtractor):
-    _VALID_URL = r'http://(?P<domain>it\.dplay\.com|www\.dplay\.(?:dk|se|no))/[^/]+/(?P<id>[^/?#]+)'
+    _VALID_URL = r'https?://(?P<domain>it\.dplay\.com|www\.dplay\.(?:dk|se|no))/[^/]+/(?P<id>[^/?#]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://it.dplay.com/take-me-out/stagione-1-episodio-25/',
         'url': 'http://it.dplay.com/take-me-out/stagione-1-episodio-25/',

+ 1 - 1
youtube_dl/extractor/dreisat.py

@@ -7,7 +7,7 @@ from .zdf import ZDFIE
 
 
 class DreiSatIE(ZDFIE):
 class DreiSatIE(ZDFIE):
     IE_NAME = '3sat'
     IE_NAME = '3sat'
-    _VALID_URL = r'(?:http://)?(?:www\.)?3sat\.de/mediathek/(?:index\.php|mediathek\.php)?\?(?:(?:mode|display)=[^&]+&)*obj=(?P<id>[0-9]+)$'
+    _VALID_URL = r'(?:https?://)?(?:www\.)?3sat\.de/mediathek/(?:index\.php|mediathek\.php)?\?(?:(?:mode|display)=[^&]+&)*obj=(?P<id>[0-9]+)$'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://www.3sat.de/mediathek/index.php?mode=play&obj=45918',
             'url': 'http://www.3sat.de/mediathek/index.php?mode=play&obj=45918',

+ 1 - 1
youtube_dl/extractor/dvtv.py

@@ -15,7 +15,7 @@ class DVTVIE(InfoExtractor):
     IE_NAME = 'dvtv'
     IE_NAME = 'dvtv'
     IE_DESC = 'http://video.aktualne.cz/'
     IE_DESC = 'http://video.aktualne.cz/'
 
 
-    _VALID_URL = r'http://video\.aktualne\.cz/(?:[^/]+/)+r~(?P<id>[0-9a-f]{32})'
+    _VALID_URL = r'https?://video\.aktualne\.cz/(?:[^/]+/)+r~(?P<id>[0-9a-f]{32})'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://video.aktualne.cz/dvtv/vondra-o-ceskem-stoleti-pri-pohledu-na-havla-mi-bylo-trapne/r~e5efe9ca855511e4833a0025900fea04/',
         'url': 'http://video.aktualne.cz/dvtv/vondra-o-ceskem-stoleti-pri-pohledu-na-havla-mi-bylo-trapne/r~e5efe9ca855511e4833a0025900fea04/',

+ 1 - 1
youtube_dl/extractor/echomsk.py

@@ -7,7 +7,7 @@ from .common import InfoExtractor
 
 
 
 
 class EchoMskIE(InfoExtractor):
 class EchoMskIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?echo\.msk\.ru/sounds/(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www\.)?echo\.msk\.ru/sounds/(?P<id>\d+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.echo.msk.ru/sounds/1464134.html',
         'url': 'http://www.echo.msk.ru/sounds/1464134.html',
         'md5': '2e44b3b78daff5b458e4dbc37f191f7c',
         'md5': '2e44b3b78daff5b458e4dbc37f191f7c',

+ 1 - 1
youtube_dl/extractor/exfm.py

@@ -8,7 +8,7 @@ from .common import InfoExtractor
 class ExfmIE(InfoExtractor):
 class ExfmIE(InfoExtractor):
     IE_NAME = 'exfm'
     IE_NAME = 'exfm'
     IE_DESC = 'ex.fm'
     IE_DESC = 'ex.fm'
-    _VALID_URL = r'http://(?:www\.)?ex\.fm/song/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://(?:www\.)?ex\.fm/song/(?P<id>[^/]+)'
     _SOUNDCLOUD_URL = r'http://(?:www\.)?api\.soundcloud\.com/tracks/([^/]+)/stream'
     _SOUNDCLOUD_URL = r'http://(?:www\.)?api\.soundcloud\.com/tracks/([^/]+)/stream'
     _TESTS = [
     _TESTS = [
         {
         {

+ 1 - 1
youtube_dl/extractor/fc2.py

@@ -17,7 +17,7 @@ from ..utils import (
 
 
 
 
 class FC2IE(InfoExtractor):
 class FC2IE(InfoExtractor):
-    _VALID_URL = r'^http://video\.fc2\.com/(?:[^/]+/)*content/(?P<id>[^/]+)'
+    _VALID_URL = r'^https?://video\.fc2\.com/(?:[^/]+/)*content/(?P<id>[^/]+)'
     IE_NAME = 'fc2'
     IE_NAME = 'fc2'
     _NETRC_MACHINE = 'fc2'
     _NETRC_MACHINE = 'fc2'
     _TESTS = [{
     _TESTS = [{

+ 1 - 1
youtube_dl/extractor/firstpost.py

@@ -4,7 +4,7 @@ from .common import InfoExtractor
 
 
 
 
 class FirstpostIE(InfoExtractor):
 class FirstpostIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?firstpost\.com/[^/]+/.*-(?P<id>[0-9]+)\.html'
+    _VALID_URL = r'https?://(?:www\.)?firstpost\.com/[^/]+/.*-(?P<id>[0-9]+)\.html'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.firstpost.com/india/india-to-launch-indigenous-aircraft-carrier-monday-1025403.html',
         'url': 'http://www.firstpost.com/india/india-to-launch-indigenous-aircraft-carrier-monday-1025403.html',

+ 1 - 1
youtube_dl/extractor/firsttv.py

@@ -8,7 +8,7 @@ from ..utils import int_or_none
 class FirstTVIE(InfoExtractor):
 class FirstTVIE(InfoExtractor):
     IE_NAME = '1tv'
     IE_NAME = '1tv'
     IE_DESC = 'Первый канал'
     IE_DESC = 'Первый канал'
-    _VALID_URL = r'http://(?:www\.)?1tv\.ru/(?:[^/]+/)+(?P<id>.+)'
+    _VALID_URL = r'https?://(?:www\.)?1tv\.ru/(?:[^/]+/)+(?P<id>.+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.1tv.ru/videoarchive/73390',
         'url': 'http://www.1tv.ru/videoarchive/73390',

+ 1 - 1
youtube_dl/extractor/fktv.py

@@ -10,7 +10,7 @@ from ..utils import (
 
 
 class FKTVIE(InfoExtractor):
 class FKTVIE(InfoExtractor):
     IE_NAME = 'fernsehkritik.tv'
     IE_NAME = 'fernsehkritik.tv'
-    _VALID_URL = r'http://(?:www\.)?fernsehkritik\.tv/folge-(?P<id>[0-9]+)(?:/.*)?'
+    _VALID_URL = r'https?://(?:www\.)?fernsehkritik\.tv/folge-(?P<id>[0-9]+)(?:/.*)?'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://fernsehkritik.tv/folge-1',
         'url': 'http://fernsehkritik.tv/folge-1',

+ 1 - 1
youtube_dl/extractor/footyroom.py

@@ -5,7 +5,7 @@ from .common import InfoExtractor
 
 
 
 
 class FootyRoomIE(InfoExtractor):
 class FootyRoomIE(InfoExtractor):
-    _VALID_URL = r'http://footyroom\.com/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://footyroom\.com/(?P<id>[^/]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://footyroom.com/schalke-04-0-2-real-madrid-2015-02/',
         'url': 'http://footyroom.com/schalke-04-0-2-real-madrid-2015-02/',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/foxgay.py

@@ -4,7 +4,7 @@ from .common import InfoExtractor
 
 
 
 
 class FoxgayIE(InfoExtractor):
 class FoxgayIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?foxgay\.com/videos/(?:\S+-)?(?P<id>\d+)\.shtml'
+    _VALID_URL = r'https?://(?:www\.)?foxgay\.com/videos/(?:\S+-)?(?P<id>\d+)\.shtml'
     _TEST = {
     _TEST = {
         'url': 'http://foxgay.com/videos/fuck-turkish-style-2582.shtml',
         'url': 'http://foxgay.com/videos/fuck-turkish-style-2582.shtml',
         'md5': '80d72beab5d04e1655a56ad37afe6841',
         'md5': '80d72beab5d04e1655a56ad37afe6841',

+ 1 - 1
youtube_dl/extractor/franceinter.py

@@ -6,7 +6,7 @@ from ..utils import int_or_none
 
 
 
 
 class FranceInterIE(InfoExtractor):
 class FranceInterIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?franceinter\.fr/player/reecouter\?play=(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://(?:www\.)?franceinter\.fr/player/reecouter\?play=(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.franceinter.fr/player/reecouter?play=793962',
         'url': 'http://www.franceinter.fr/player/reecouter?play=793962',
         'md5': '4764932e466e6f6c79c317d2e74f6884',
         'md5': '4764932e466e6f6c79c317d2e74f6884',

+ 1 - 1
youtube_dl/extractor/freevideo.py

@@ -5,7 +5,7 @@ from ..utils import ExtractorError
 
 
 
 
 class FreeVideoIE(InfoExtractor):
 class FreeVideoIE(InfoExtractor):
-    _VALID_URL = r'^http://www.freevideo.cz/vase-videa/(?P<id>[^.]+)\.html(?:$|[?#])'
+    _VALID_URL = r'^https?://www.freevideo.cz/vase-videa/(?P<id>[^.]+)\.html(?:$|[?#])'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.freevideo.cz/vase-videa/vysukany-zadecek-22033.html',
         'url': 'http://www.freevideo.cz/vase-videa/vysukany-zadecek-22033.html',

+ 1 - 1
youtube_dl/extractor/gamekings.py

@@ -10,7 +10,7 @@ from .youtube import YoutubeIE
 
 
 
 
 class GamekingsIE(InfoExtractor):
 class GamekingsIE(InfoExtractor):
-    _VALID_URL = r'http://www\.gamekings\.nl/(?:videos|nieuws)/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://www\.gamekings\.nl/(?:videos|nieuws)/(?P<id>[^/]+)'
     _TESTS = [{
     _TESTS = [{
         # YouTube embed video
         # YouTube embed video
         'url': 'http://www.gamekings.nl/videos/phoenix-wright-ace-attorney-dual-destinies-review/',
         'url': 'http://www.gamekings.nl/videos/phoenix-wright-ace-attorney-dual-destinies-review/',

+ 1 - 1
youtube_dl/extractor/gamespot.py

@@ -14,7 +14,7 @@ from ..utils import (
 
 
 
 
 class GameSpotIE(InfoExtractor):
 class GameSpotIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?gamespot\.com/.*-(?P<id>\d+)/?'
+    _VALID_URL = r'https?://(?:www\.)?gamespot\.com/.*-(?P<id>\d+)/?'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.gamespot.com/videos/arma-3-community-guide-sitrep-i/2300-6410818/',
         'url': 'http://www.gamespot.com/videos/arma-3-community-guide-sitrep-i/2300-6410818/',
         'md5': 'b2a30deaa8654fcccd43713a6b6a4825',
         'md5': 'b2a30deaa8654fcccd43713a6b6a4825',

+ 1 - 1
youtube_dl/extractor/gamestar.py

@@ -13,7 +13,7 @@ from ..utils import (
 
 
 
 
 class GameStarIE(InfoExtractor):
 class GameStarIE(InfoExtractor):
-    _VALID_URL = r'http://www\.gamestar\.de/videos/.*,(?P<id>[0-9]+)\.html'
+    _VALID_URL = r'https?://www\.gamestar\.de/videos/.*,(?P<id>[0-9]+)\.html'
     _TEST = {
     _TEST = {
         'url': 'http://www.gamestar.de/videos/trailer,3/hobbit-3-die-schlacht-der-fuenf-heere,76110.html',
         'url': 'http://www.gamestar.de/videos/trailer,3/hobbit-3-die-schlacht-der-fuenf-heere,76110.html',
         'md5': '96974ecbb7fd8d0d20fca5a00810cea7',
         'md5': '96974ecbb7fd8d0d20fca5a00810cea7',

+ 1 - 1
youtube_dl/extractor/gametrailers.py

@@ -9,7 +9,7 @@ from ..utils import (
 
 
 
 
 class GametrailersIE(InfoExtractor):
 class GametrailersIE(InfoExtractor):
-    _VALID_URL = r'http://www\.gametrailers\.com/videos/view/[^/]+/(?P<id>.+)'
+    _VALID_URL = r'https?://www\.gametrailers\.com/videos/view/[^/]+/(?P<id>.+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.gametrailers.com/videos/view/gametrailers-com/116437-Just-Cause-3-Review',
         'url': 'http://www.gametrailers.com/videos/view/gametrailers-com/116437-Just-Cause-3-Review',

+ 1 - 1
youtube_dl/extractor/hotnewhiphop.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class HotNewHipHopIE(InfoExtractor):
 class HotNewHipHopIE(InfoExtractor):
-    _VALID_URL = r'http://www\.hotnewhiphop\.com/.*\.(?P<id>.*)\.html'
+    _VALID_URL = r'https?://www\.hotnewhiphop\.com/.*\.(?P<id>.*)\.html'
     _TEST = {
     _TEST = {
         'url': 'http://www.hotnewhiphop.com/freddie-gibbs-lay-it-down-song.1435540.html',
         'url': 'http://www.hotnewhiphop.com/freddie-gibbs-lay-it-down-song.1435540.html',
         'md5': '2c2cd2f76ef11a9b3b581e8b232f3d96',
         'md5': '2c2cd2f76ef11a9b3b581e8b232f3d96',

+ 1 - 1
youtube_dl/extractor/hypem.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class HypemIE(InfoExtractor):
 class HypemIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?hypem\.com/track/(?P<id>[^/]+)/'
+    _VALID_URL = r'https?://(?:www\.)?hypem\.com/track/(?P<id>[^/]+)/'
     _TEST = {
     _TEST = {
         'url': 'http://hypem.com/track/1v6ga/BODYWORK+-+TAME',
         'url': 'http://hypem.com/track/1v6ga/BODYWORK+-+TAME',
         'md5': 'b9cc91b5af8995e9f0c1cee04c575828',
         'md5': 'b9cc91b5af8995e9f0c1cee04c575828',

+ 2 - 2
youtube_dl/extractor/imdb.py

@@ -12,7 +12,7 @@ from ..utils import (
 class ImdbIE(InfoExtractor):
 class ImdbIE(InfoExtractor):
     IE_NAME = 'imdb'
     IE_NAME = 'imdb'
     IE_DESC = 'Internet Movie Database trailers'
     IE_DESC = 'Internet Movie Database trailers'
-    _VALID_URL = r'http://(?:www|m)\.imdb\.com/video/imdb/vi(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www|m)\.imdb\.com/video/imdb/vi(?P<id>\d+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.imdb.com/video/imdb/vi2524815897',
         'url': 'http://www.imdb.com/video/imdb/vi2524815897',
@@ -70,7 +70,7 @@ class ImdbIE(InfoExtractor):
 class ImdbListIE(InfoExtractor):
 class ImdbListIE(InfoExtractor):
     IE_NAME = 'imdb:list'
     IE_NAME = 'imdb:list'
     IE_DESC = 'Internet Movie Database lists'
     IE_DESC = 'Internet Movie Database lists'
-    _VALID_URL = r'http://www\.imdb\.com/list/(?P<id>[\da-zA-Z_-]{11})'
+    _VALID_URL = r'https?://www\.imdb\.com/list/(?P<id>[\da-zA-Z_-]{11})'
     _TEST = {
     _TEST = {
         'url': 'http://www.imdb.com/list/JFs9NWw6XI0',
         'url': 'http://www.imdb.com/list/JFs9NWw6XI0',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/iqiyi.py

@@ -165,7 +165,7 @@ class IqiyiIE(InfoExtractor):
     IE_NAME = 'iqiyi'
     IE_NAME = 'iqiyi'
     IE_DESC = '爱奇艺'
     IE_DESC = '爱奇艺'
 
 
-    _VALID_URL = r'http://(?:[^.]+\.)?iqiyi\.com/.+\.html'
+    _VALID_URL = r'https?://(?:[^.]+\.)?iqiyi\.com/.+\.html'
 
 
     _NETRC_MACHINE = 'iqiyi'
     _NETRC_MACHINE = 'iqiyi'
 
 

+ 1 - 1
youtube_dl/extractor/jadorecettepub.py

@@ -9,7 +9,7 @@ from .youtube import YoutubeIE
 
 
 
 
 class JadoreCettePubIE(InfoExtractor):
 class JadoreCettePubIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?jadorecettepub\.com/[0-9]{4}/[0-9]{2}/(?P<id>.*?)\.html'
+    _VALID_URL = r'https?://(?:www\.)?jadorecettepub\.com/[0-9]{4}/[0-9]{2}/(?P<id>.*?)\.html'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.jadorecettepub.com/2010/12/star-wars-massacre-par-les-japonais.html',
         'url': 'http://www.jadorecettepub.com/2010/12/star-wars-massacre-par-les-japonais.html',

+ 1 - 1
youtube_dl/extractor/jeuxvideo.py

@@ -8,7 +8,7 @@ from .common import InfoExtractor
 
 
 
 
 class JeuxVideoIE(InfoExtractor):
 class JeuxVideoIE(InfoExtractor):
-    _VALID_URL = r'http://.*?\.jeuxvideo\.com/.*/(.*?)\.htm'
+    _VALID_URL = r'https?://.*?\.jeuxvideo\.com/.*/(.*?)\.htm'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.jeuxvideo.com/reportages-videos-jeux/0004/00046170/tearaway-playstation-vita-gc-2013-tearaway-nous-presente-ses-papiers-d-identite-00115182.htm',
         'url': 'http://www.jeuxvideo.com/reportages-videos-jeux/0004/00046170/tearaway-playstation-vita-gc-2013-tearaway-nous-presente-ses-papiers-d-identite-00115182.htm',

+ 1 - 1
youtube_dl/extractor/karaoketv.py

@@ -9,7 +9,7 @@ from ..utils import (
 
 
 
 
 class KaraoketvIE(InfoExtractor):
 class KaraoketvIE(InfoExtractor):
-    _VALID_URL = r'http://karaoketv\.co\.il/\?container=songs&id=(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://karaoketv\.co\.il/\?container=songs&id=(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://karaoketv.co.il/?container=songs&id=171568',
         'url': 'http://karaoketv.co.il/?container=songs&id=171568',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/karrierevideos.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class KarriereVideosIE(InfoExtractor):
 class KarriereVideosIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?karrierevideos\.at(?:/[^/]+)+/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://(?:www\.)?karrierevideos\.at(?:/[^/]+)+/(?P<id>[^/]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.karrierevideos.at/berufsvideos/mittlere-hoehere-schulen/altenpflegerin',
         'url': 'http://www.karrierevideos.at/berufsvideos/mittlere-hoehere-schulen/altenpflegerin',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/kontrtube.py

@@ -13,7 +13,7 @@ from ..utils import (
 class KontrTubeIE(InfoExtractor):
 class KontrTubeIE(InfoExtractor):
     IE_NAME = 'kontrtube'
     IE_NAME = 'kontrtube'
     IE_DESC = 'KontrTube.ru - Труба зовёт'
     IE_DESC = 'KontrTube.ru - Труба зовёт'
-    _VALID_URL = r'http://(?:www\.)?kontrtube\.ru/videos/(?P<id>\d+)/(?P<display_id>[^/]+)/'
+    _VALID_URL = r'https?://(?:www\.)?kontrtube\.ru/videos/(?P<id>\d+)/(?P<display_id>[^/]+)/'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.kontrtube.ru/videos/2678/nad-olimpiyskoy-derevney-v-sochi-podnyat-rossiyskiy-flag/',
         'url': 'http://www.kontrtube.ru/videos/2678/nad-olimpiyskoy-derevney-v-sochi-podnyat-rossiyskiy-flag/',

+ 1 - 1
youtube_dl/extractor/ku6.py

@@ -4,7 +4,7 @@ from .common import InfoExtractor
 
 
 
 
 class Ku6IE(InfoExtractor):
 class Ku6IE(InfoExtractor):
-    _VALID_URL = r'http://v\.ku6\.com/show/(?P<id>[a-zA-Z0-9\-\_]+)(?:\.)*html'
+    _VALID_URL = r'https?://v\.ku6\.com/show/(?P<id>[a-zA-Z0-9\-\_]+)(?:\.)*html'
     _TEST = {
     _TEST = {
         'url': 'http://v.ku6.com/show/JG-8yS14xzBr4bCn1pu0xw...html',
         'url': 'http://v.ku6.com/show/JG-8yS14xzBr4bCn1pu0xw...html',
         'md5': '01203549b9efbb45f4b87d55bdea1ed1',
         'md5': '01203549b9efbb45f4b87d55bdea1ed1',

+ 1 - 1
youtube_dl/extractor/kusi.py

@@ -16,7 +16,7 @@ from ..utils import (
 
 
 
 
 class KUSIIE(InfoExtractor):
 class KUSIIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?kusi\.com/(?P<path>story/.+|video\?clipId=(?P<clipId>\d+))'
+    _VALID_URL = r'https?://(?:www\.)?kusi\.com/(?P<path>story/.+|video\?clipId=(?P<clipId>\d+))'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.kusi.com/story/31183873/turko-files-case-closed-put-on-hold',
         'url': 'http://www.kusi.com/story/31183873/turko-files-case-closed-put-on-hold',
         'md5': 'f926e7684294cf8cb7bdf8858e1b3988',
         'md5': 'f926e7684294cf8cb7bdf8858e1b3988',

+ 6 - 6
youtube_dl/extractor/kuwo.py

@@ -55,7 +55,7 @@ class KuwoBaseIE(InfoExtractor):
 class KuwoIE(KuwoBaseIE):
 class KuwoIE(KuwoBaseIE):
     IE_NAME = 'kuwo:song'
     IE_NAME = 'kuwo:song'
     IE_DESC = '酷我音乐'
     IE_DESC = '酷我音乐'
-    _VALID_URL = r'http://www\.kuwo\.cn/yinyue/(?P<id>\d+?)'
+    _VALID_URL = r'https?://www\.kuwo\.cn/yinyue/(?P<id>\d+?)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.kuwo.cn/yinyue/635632/',
         'url': 'http://www.kuwo.cn/yinyue/635632/',
         'info_dict': {
         'info_dict': {
@@ -134,7 +134,7 @@ class KuwoIE(KuwoBaseIE):
 class KuwoAlbumIE(InfoExtractor):
 class KuwoAlbumIE(InfoExtractor):
     IE_NAME = 'kuwo:album'
     IE_NAME = 'kuwo:album'
     IE_DESC = '酷我音乐 - 专辑'
     IE_DESC = '酷我音乐 - 专辑'
-    _VALID_URL = r'http://www\.kuwo\.cn/album/(?P<id>\d+?)/'
+    _VALID_URL = r'https?://www\.kuwo\.cn/album/(?P<id>\d+?)/'
     _TEST = {
     _TEST = {
         'url': 'http://www.kuwo.cn/album/502294/',
         'url': 'http://www.kuwo.cn/album/502294/',
         'info_dict': {
         'info_dict': {
@@ -170,7 +170,7 @@ class KuwoAlbumIE(InfoExtractor):
 class KuwoChartIE(InfoExtractor):
 class KuwoChartIE(InfoExtractor):
     IE_NAME = 'kuwo:chart'
     IE_NAME = 'kuwo:chart'
     IE_DESC = '酷我音乐 - 排行榜'
     IE_DESC = '酷我音乐 - 排行榜'
-    _VALID_URL = r'http://yinyue\.kuwo\.cn/billboard_(?P<id>[^.]+).htm'
+    _VALID_URL = r'https?://yinyue\.kuwo\.cn/billboard_(?P<id>[^.]+).htm'
     _TEST = {
     _TEST = {
         'url': 'http://yinyue.kuwo.cn/billboard_香港中文龙虎榜.htm',
         'url': 'http://yinyue.kuwo.cn/billboard_香港中文龙虎榜.htm',
         'info_dict': {
         'info_dict': {
@@ -195,7 +195,7 @@ class KuwoChartIE(InfoExtractor):
 class KuwoSingerIE(InfoExtractor):
 class KuwoSingerIE(InfoExtractor):
     IE_NAME = 'kuwo:singer'
     IE_NAME = 'kuwo:singer'
     IE_DESC = '酷我音乐 - 歌手'
     IE_DESC = '酷我音乐 - 歌手'
-    _VALID_URL = r'http://www\.kuwo\.cn/mingxing/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://www\.kuwo\.cn/mingxing/(?P<id>[^/]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.kuwo.cn/mingxing/bruno+mars/',
         'url': 'http://www.kuwo.cn/mingxing/bruno+mars/',
         'info_dict': {
         'info_dict': {
@@ -251,7 +251,7 @@ class KuwoSingerIE(InfoExtractor):
 class KuwoCategoryIE(InfoExtractor):
 class KuwoCategoryIE(InfoExtractor):
     IE_NAME = 'kuwo:category'
     IE_NAME = 'kuwo:category'
     IE_DESC = '酷我音乐 - 分类'
     IE_DESC = '酷我音乐 - 分类'
-    _VALID_URL = r'http://yinyue\.kuwo\.cn/yy/cinfo_(?P<id>\d+?).htm'
+    _VALID_URL = r'https?://yinyue\.kuwo\.cn/yy/cinfo_(?P<id>\d+?).htm'
     _TEST = {
     _TEST = {
         'url': 'http://yinyue.kuwo.cn/yy/cinfo_86375.htm',
         'url': 'http://yinyue.kuwo.cn/yy/cinfo_86375.htm',
         'info_dict': {
         'info_dict': {
@@ -288,7 +288,7 @@ class KuwoCategoryIE(InfoExtractor):
 class KuwoMvIE(KuwoBaseIE):
 class KuwoMvIE(KuwoBaseIE):
     IE_NAME = 'kuwo:mv'
     IE_NAME = 'kuwo:mv'
     IE_DESC = '酷我音乐 - MV'
     IE_DESC = '酷我音乐 - MV'
-    _VALID_URL = r'http://www\.kuwo\.cn/mv/(?P<id>\d+?)/'
+    _VALID_URL = r'https?://www\.kuwo\.cn/mv/(?P<id>\d+?)/'
     _TEST = {
     _TEST = {
         'url': 'http://www.kuwo.cn/mv/6480076/',
         'url': 'http://www.kuwo.cn/mv/6480076/',
         'info_dict': {
         'info_dict': {

+ 2 - 2
youtube_dl/extractor/leeco.py

@@ -28,7 +28,7 @@ from ..utils import (
 
 
 class LeIE(InfoExtractor):
 class LeIE(InfoExtractor):
     IE_DESC = '乐视网'
     IE_DESC = '乐视网'
-    _VALID_URL = r'http://www\.le\.com/ptv/vplay/(?P<id>\d+)\.html'
+    _VALID_URL = r'https?://www\.le\.com/ptv/vplay/(?P<id>\d+)\.html'
 
 
     _URL_TEMPLATE = 'http://www.le.com/ptv/vplay/%s.html'
     _URL_TEMPLATE = 'http://www.le.com/ptv/vplay/%s.html'
 
 
@@ -196,7 +196,7 @@ class LeIE(InfoExtractor):
 
 
 
 
 class LePlaylistIE(InfoExtractor):
 class LePlaylistIE(InfoExtractor):
-    _VALID_URL = r'http://[a-z]+\.le\.com/[a-z]+/(?P<id>[a-z0-9_]+)'
+    _VALID_URL = r'https?://[a-z]+\.le\.com/[a-z]+/(?P<id>[a-z0-9_]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.le.com/tv/46177.html',
         'url': 'http://www.le.com/tv/46177.html',

+ 2 - 2
youtube_dl/extractor/lifenews.py

@@ -17,7 +17,7 @@ from ..utils import (
 class LifeNewsIE(InfoExtractor):
 class LifeNewsIE(InfoExtractor):
     IE_NAME = 'lifenews'
     IE_NAME = 'lifenews'
     IE_DESC = 'LIFE | NEWS'
     IE_DESC = 'LIFE | NEWS'
-    _VALID_URL = r'http://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)'
+    _VALID_URL = r'https?://lifenews\.ru/(?:mobile/)?(?P<section>news|video)/(?P<id>\d+)'
 
 
     _TESTS = [{
     _TESTS = [{
         # single video embedded via video/source
         # single video embedded via video/source
@@ -159,7 +159,7 @@ class LifeNewsIE(InfoExtractor):
 
 
 class LifeEmbedIE(InfoExtractor):
 class LifeEmbedIE(InfoExtractor):
     IE_NAME = 'life:embed'
     IE_NAME = 'life:embed'
-    _VALID_URL = r'http://embed\.life\.ru/embed/(?P<id>[\da-f]{32})'
+    _VALID_URL = r'https?://embed\.life\.ru/embed/(?P<id>[\da-f]{32})'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://embed.life.ru/embed/e50c2dec2867350528e2574c899b8291',
         'url': 'http://embed.life.ru/embed/e50c2dec2867350528e2574c899b8291',

+ 3 - 3
youtube_dl/extractor/limelight.py

@@ -123,7 +123,7 @@ class LimelightBaseIE(InfoExtractor):
 
 
 class LimelightMediaIE(LimelightBaseIE):
 class LimelightMediaIE(LimelightBaseIE):
     IE_NAME = 'limelight'
     IE_NAME = 'limelight'
-    _VALID_URL = r'(?:limelight:media:|http://link\.videoplatform\.limelight\.com/media/\??\bmediaId=)(?P<id>[a-z0-9]{32})'
+    _VALID_URL = r'(?:limelight:media:|https?://link\.videoplatform\.limelight\.com/media/\??\bmediaId=)(?P<id>[a-z0-9]{32})'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://link.videoplatform.limelight.com/media/?mediaId=3ffd040b522b4485b6d84effc750cd86',
         'url': 'http://link.videoplatform.limelight.com/media/?mediaId=3ffd040b522b4485b6d84effc750cd86',
         'info_dict': {
         'info_dict': {
@@ -176,7 +176,7 @@ class LimelightMediaIE(LimelightBaseIE):
 
 
 class LimelightChannelIE(LimelightBaseIE):
 class LimelightChannelIE(LimelightBaseIE):
     IE_NAME = 'limelight:channel'
     IE_NAME = 'limelight:channel'
-    _VALID_URL = r'(?:limelight:channel:|http://link\.videoplatform\.limelight\.com/media/\??\bchannelId=)(?P<id>[a-z0-9]{32})'
+    _VALID_URL = r'(?:limelight:channel:|https?://link\.videoplatform\.limelight\.com/media/\??\bchannelId=)(?P<id>[a-z0-9]{32})'
     _TEST = {
     _TEST = {
         'url': 'http://link.videoplatform.limelight.com/media/?channelId=ab6a524c379342f9b23642917020c082',
         'url': 'http://link.videoplatform.limelight.com/media/?channelId=ab6a524c379342f9b23642917020c082',
         'info_dict': {
         'info_dict': {
@@ -207,7 +207,7 @@ class LimelightChannelIE(LimelightBaseIE):
 
 
 class LimelightChannelListIE(LimelightBaseIE):
 class LimelightChannelListIE(LimelightBaseIE):
     IE_NAME = 'limelight:channel_list'
     IE_NAME = 'limelight:channel_list'
-    _VALID_URL = r'(?:limelight:channel_list:|http://link\.videoplatform\.limelight\.com/media/\?.*?\bchannelListId=)(?P<id>[a-z0-9]{32})'
+    _VALID_URL = r'(?:limelight:channel_list:|https?://link\.videoplatform\.limelight\.com/media/\?.*?\bchannelListId=)(?P<id>[a-z0-9]{32})'
     _TEST = {
     _TEST = {
         'url': 'http://link.videoplatform.limelight.com/media/?channelListId=301b117890c4465c8179ede21fd92e2b',
         'url': 'http://link.videoplatform.limelight.com/media/?channelListId=301b117890c4465c8179ede21fd92e2b',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/m6.py

@@ -8,7 +8,7 @@ from .common import InfoExtractor
 
 
 class M6IE(InfoExtractor):
 class M6IE(InfoExtractor):
     IE_NAME = 'm6'
     IE_NAME = 'm6'
-    _VALID_URL = r'http://(?:www\.)?m6\.fr/[^/]+/videos/(?P<id>\d+)-[^\.]+\.html'
+    _VALID_URL = r'https?://(?:www\.)?m6\.fr/[^/]+/videos/(?P<id>\d+)-[^\.]+\.html'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.m6.fr/emission-les_reines_du_shopping/videos/11323908-emeline_est_la_reine_du_shopping_sur_le_theme_ma_fete_d_8217_anniversaire.html',
         'url': 'http://www.m6.fr/emission-les_reines_du_shopping/videos/11323908-emeline_est_la_reine_du_shopping_sur_le_theme_ma_fete_d_8217_anniversaire.html',

+ 1 - 1
youtube_dl/extractor/metacafe.py

@@ -17,7 +17,7 @@ from ..utils import (
 
 
 
 
 class MetacafeIE(InfoExtractor):
 class MetacafeIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?metacafe\.com/watch/([^/]+)/([^/]+)/.*'
+    _VALID_URL = r'https?://(?:www\.)?metacafe\.com/watch/([^/]+)/([^/]+)/.*'
     _DISCLAIMER = 'http://www.metacafe.com/family_filter/'
     _DISCLAIMER = 'http://www.metacafe.com/family_filter/'
     _FILTER_POST = 'http://www.metacafe.com/f/index.php?inputType=filter&controllerGroup=user'
     _FILTER_POST = 'http://www.metacafe.com/f/index.php?inputType=filter&controllerGroup=user'
     IE_NAME = 'metacafe'
     IE_NAME = 'metacafe'

+ 1 - 1
youtube_dl/extractor/mit.py

@@ -91,7 +91,7 @@ class MITIE(TechTVMITIE):
 
 
 class OCWMITIE(InfoExtractor):
 class OCWMITIE(InfoExtractor):
     IE_NAME = 'ocw.mit.edu'
     IE_NAME = 'ocw.mit.edu'
-    _VALID_URL = r'^http://ocw\.mit\.edu/courses/(?P<topic>[a-z0-9\-]+)'
+    _VALID_URL = r'^https?://ocw\.mit\.edu/courses/(?P<topic>[a-z0-9\-]+)'
     _BASE_URL = 'http://ocw.mit.edu/'
     _BASE_URL = 'http://ocw.mit.edu/'
 
 
     _TESTS = [
     _TESTS = [

+ 1 - 1
youtube_dl/extractor/mitele.py

@@ -14,7 +14,7 @@ from ..utils import (
 
 
 class MiTeleIE(InfoExtractor):
 class MiTeleIE(InfoExtractor):
     IE_DESC = 'mitele.es'
     IE_DESC = 'mitele.es'
-    _VALID_URL = r'http://www\.mitele\.es/[^/]+/[^/]+/[^/]+/(?P<id>[^/]+)/'
+    _VALID_URL = r'https?://www\.mitele\.es/[^/]+/[^/]+/[^/]+/(?P<id>[^/]+)/'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.mitele.es/programas-tv/diario-de/la-redaccion/programa-144/',
         'url': 'http://www.mitele.es/programas-tv/diario-de/la-redaccion/programa-144/',

+ 1 - 1
youtube_dl/extractor/mooshare.py

@@ -13,7 +13,7 @@ from ..utils import (
 class MooshareIE(InfoExtractor):
 class MooshareIE(InfoExtractor):
     IE_NAME = 'mooshare'
     IE_NAME = 'mooshare'
     IE_DESC = 'Mooshare.biz'
     IE_DESC = 'Mooshare.biz'
-    _VALID_URL = r'http://(?:www\.)?mooshare\.biz/(?P<id>[\da-z]{12})'
+    _VALID_URL = r'https?://(?:www\.)?mooshare\.biz/(?P<id>[\da-z]{12})'
 
 
     _TESTS = [
     _TESTS = [
         {
         {

+ 1 - 1
youtube_dl/extractor/motherless.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class MotherlessIE(InfoExtractor):
 class MotherlessIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?motherless\.com/(?:g/[a-z0-9_]+/)?(?P<id>[A-Z0-9]+)'
+    _VALID_URL = r'https?://(?:www\.)?motherless\.com/(?:g/[a-z0-9_]+/)?(?P<id>[A-Z0-9]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://motherless.com/AC3FFE1',
         'url': 'http://motherless.com/AC3FFE1',
         'md5': '310f62e325a9fafe64f68c0bccb6e75f',
         'md5': '310f62e325a9fafe64f68c0bccb6e75f',

+ 1 - 1
youtube_dl/extractor/motorsport.py

@@ -9,7 +9,7 @@ from ..compat import (
 
 
 class MotorsportIE(InfoExtractor):
 class MotorsportIE(InfoExtractor):
     IE_DESC = 'motorsport.com'
     IE_DESC = 'motorsport.com'
-    _VALID_URL = r'http://www\.motorsport\.com/[^/?#]+/video/(?:[^/?#]+/)(?P<id>[^/]+)/?(?:$|[?#])'
+    _VALID_URL = r'https?://www\.motorsport\.com/[^/?#]+/video/(?:[^/?#]+/)(?P<id>[^/]+)/?(?:$|[?#])'
     _TEST = {
     _TEST = {
         'url': 'http://www.motorsport.com/f1/video/main-gallery/red-bull-racing-2014-rules-explained/',
         'url': 'http://www.motorsport.com/f1/video/main-gallery/red-bull-racing-2014-rules-explained/',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/myspass.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 
 
 class MySpassIE(InfoExtractor):
 class MySpassIE(InfoExtractor):
-    _VALID_URL = r'http://www\.myspass\.de/.*'
+    _VALID_URL = r'https?://www\.myspass\.de/.*'
     _TEST = {
     _TEST = {
         'url': 'http://www.myspass.de/myspass/shows/tvshows/absolute-mehrheit/Absolute-Mehrheit-vom-17022013-Die-Highlights-Teil-2--/11741/',
         'url': 'http://www.myspass.de/myspass/shows/tvshows/absolute-mehrheit/Absolute-Mehrheit-vom-17022013-Die-Highlights-Teil-2--/11741/',
         'md5': '0b49f4844a068f8b33f4b7c88405862b',
         'md5': '0b49f4844a068f8b33f4b7c88405862b',

+ 1 - 1
youtube_dl/extractor/myvideo.py

@@ -20,7 +20,7 @@ from ..utils import (
 
 
 class MyVideoIE(InfoExtractor):
 class MyVideoIE(InfoExtractor):
     _WORKING = False
     _WORKING = False
-    _VALID_URL = r'http://(?:www\.)?myvideo\.de/(?:[^/]+/)?watch/(?P<id>[0-9]+)/[^?/]+.*'
+    _VALID_URL = r'https?://(?:www\.)?myvideo\.de/(?:[^/]+/)?watch/(?P<id>[0-9]+)/[^?/]+.*'
     IE_NAME = 'myvideo'
     IE_NAME = 'myvideo'
     _TEST = {
     _TEST = {
         'url': 'http://www.myvideo.de/watch/8229274/bowling_fail_or_win',
         'url': 'http://www.myvideo.de/watch/8229274/bowling_fail_or_win',

+ 1 - 1
youtube_dl/extractor/myvidster.py

@@ -4,7 +4,7 @@ from .common import InfoExtractor
 
 
 
 
 class MyVidsterIE(InfoExtractor):
 class MyVidsterIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?myvidster\.com/video/(?P<id>\d+)/'
+    _VALID_URL = r'https?://(?:www\.)?myvidster\.com/video/(?P<id>\d+)/'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.myvidster.com/video/32059805/Hot_chemistry_with_raw_love_making',
         'url': 'http://www.myvidster.com/video/32059805/Hot_chemistry_with_raw_love_making',

+ 1 - 1
youtube_dl/extractor/nationalgeographic.py

@@ -8,7 +8,7 @@ from ..utils import (
 
 
 
 
 class NationalGeographicIE(InfoExtractor):
 class NationalGeographicIE(InfoExtractor):
-    _VALID_URL = r'http://video\.nationalgeographic\.com/.*?'
+    _VALID_URL = r'https?://video\.nationalgeographic\.com/.*?'
 
 
     _TESTS = [
     _TESTS = [
         {
         {

+ 2 - 2
youtube_dl/extractor/nbc.py

@@ -115,7 +115,7 @@ class NBCSportsVPlayerIE(InfoExtractor):
 
 
 class NBCSportsIE(InfoExtractor):
 class NBCSportsIE(InfoExtractor):
     # Does not include https because its certificate is invalid
     # Does not include https because its certificate is invalid
-    _VALID_URL = r'http://www\.nbcsports\.com//?(?:[^/]+/)+(?P<id>[0-9a-z-]+)'
+    _VALID_URL = r'https?://www\.nbcsports\.com//?(?:[^/]+/)+(?P<id>[0-9a-z-]+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://www.nbcsports.com//college-basketball/ncaab/tom-izzo-michigan-st-has-so-much-respect-duke',
         'url': 'http://www.nbcsports.com//college-basketball/ncaab/tom-izzo-michigan-st-has-so-much-respect-duke',
@@ -295,7 +295,7 @@ class NBCNewsIE(ThePlatformIE):
 
 
 class MSNBCIE(InfoExtractor):
 class MSNBCIE(InfoExtractor):
     # https URLs redirect to corresponding http ones
     # https URLs redirect to corresponding http ones
-    _VALID_URL = r'http://www\.msnbc\.com/[^/]+/watch/(?P<id>[^/]+)'
+    _VALID_URL = r'https?://www\.msnbc\.com/[^/]+/watch/(?P<id>[^/]+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.msnbc.com/all-in-with-chris-hayes/watch/the-chaotic-gop-immigration-vote-314487875924',
         'url': 'http://www.msnbc.com/all-in-with-chris-hayes/watch/the-chaotic-gop-immigration-vote-314487875924',
         'md5': '6d236bf4f3dddc226633ce6e2c3f814d',
         'md5': '6d236bf4f3dddc226633ce6e2c3f814d',

+ 3 - 3
youtube_dl/extractor/nextmedia.py

@@ -7,7 +7,7 @@ from ..utils import parse_iso8601
 
 
 class NextMediaIE(InfoExtractor):
 class NextMediaIE(InfoExtractor):
     IE_DESC = '蘋果日報'
     IE_DESC = '蘋果日報'
-    _VALID_URL = r'http://hk.apple.nextmedia.com/[^/]+/[^/]+/(?P<date>\d+)/(?P<id>\d+)'
+    _VALID_URL = r'https?://hk.apple.nextmedia.com/[^/]+/[^/]+/(?P<date>\d+)/(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://hk.apple.nextmedia.com/realtime/news/20141108/53109199',
         'url': 'http://hk.apple.nextmedia.com/realtime/news/20141108/53109199',
         'md5': 'dff9fad7009311c421176d1ac90bfe4f',
         'md5': 'dff9fad7009311c421176d1ac90bfe4f',
@@ -68,7 +68,7 @@ class NextMediaIE(InfoExtractor):
 
 
 class NextMediaActionNewsIE(NextMediaIE):
 class NextMediaActionNewsIE(NextMediaIE):
     IE_DESC = '蘋果日報 - 動新聞'
     IE_DESC = '蘋果日報 - 動新聞'
-    _VALID_URL = r'http://hk.dv.nextmedia.com/actionnews/[^/]+/(?P<date>\d+)/(?P<id>\d+)/\d+'
+    _VALID_URL = r'https?://hk.dv.nextmedia.com/actionnews/[^/]+/(?P<date>\d+)/(?P<id>\d+)/\d+'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://hk.dv.nextmedia.com/actionnews/hit/20150121/19009428/20061460',
         'url': 'http://hk.dv.nextmedia.com/actionnews/hit/20150121/19009428/20061460',
         'md5': '05fce8ffeed7a5e00665d4b7cf0f9201',
         'md5': '05fce8ffeed7a5e00665d4b7cf0f9201',
@@ -93,7 +93,7 @@ class NextMediaActionNewsIE(NextMediaIE):
 
 
 class AppleDailyIE(NextMediaIE):
 class AppleDailyIE(NextMediaIE):
     IE_DESC = '臺灣蘋果日報'
     IE_DESC = '臺灣蘋果日報'
-    _VALID_URL = r'http://(www|ent).appledaily.com.tw/(?:animation|appledaily|enews|realtimenews)/[^/]+/[^/]+/(?P<date>\d+)/(?P<id>\d+)(/.*)?'
+    _VALID_URL = r'https?://(www|ent).appledaily.com.tw/(?:animation|appledaily|enews|realtimenews)/[^/]+/[^/]+/(?P<date>\d+)/(?P<id>\d+)(/.*)?'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://ent.appledaily.com.tw/enews/article/entertainment/20150128/36354694',
         'url': 'http://ent.appledaily.com.tw/enews/article/entertainment/20150128/36354694',
         'md5': 'a843ab23d150977cc55ef94f1e2c1e4d',
         'md5': 'a843ab23d150977cc55ef94f1e2c1e4d',

+ 1 - 1
youtube_dl/extractor/noco.py

@@ -22,7 +22,7 @@ from ..utils import (
 
 
 
 
 class NocoIE(InfoExtractor):
 class NocoIE(InfoExtractor):
-    _VALID_URL = r'http://(?:(?:www\.)?noco\.tv/emission/|player\.noco\.tv/\?idvideo=)(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:(?:www\.)?noco\.tv/emission/|player\.noco\.tv/\?idvideo=)(?P<id>\d+)'
     _LOGIN_URL = 'http://noco.tv/do.php'
     _LOGIN_URL = 'http://noco.tv/do.php'
     _API_URL_TEMPLATE = 'https://api.noco.tv/1.1/%s?ts=%s&tk=%s'
     _API_URL_TEMPLATE = 'https://api.noco.tv/1.1/%s?ts=%s&tk=%s'
     _SUB_LANG_TEMPLATE = '&sub_lang=%s'
     _SUB_LANG_TEMPLATE = '&sub_lang=%s'

+ 1 - 1
youtube_dl/extractor/normalboots.py

@@ -9,7 +9,7 @@ from ..utils import (
 
 
 
 
 class NormalbootsIE(InfoExtractor):
 class NormalbootsIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?normalboots\.com/video/(?P<id>[0-9a-z-]*)/?$'
+    _VALID_URL = r'https?://(?:www\.)?normalboots\.com/video/(?P<id>[0-9a-z-]*)/?$'
     _TEST = {
     _TEST = {
         'url': 'http://normalboots.com/video/home-alone-games-jontron/',
         'url': 'http://normalboots.com/video/home-alone-games-jontron/',
         'md5': '8bf6de238915dd501105b44ef5f1e0f6',
         'md5': '8bf6de238915dd501105b44ef5f1e0f6',

+ 1 - 1
youtube_dl/extractor/nova.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 class NovaIE(InfoExtractor):
 class NovaIE(InfoExtractor):
     IE_DESC = 'TN.cz, Prásk.tv, Nova.cz, Novaplus.cz, FANDA.tv, Krásná.cz and Doma.cz'
     IE_DESC = 'TN.cz, Prásk.tv, Nova.cz, Novaplus.cz, FANDA.tv, Krásná.cz and Doma.cz'
-    _VALID_URL = r'http://(?:[^.]+\.)?(?P<site>tv(?:noviny)?|tn|novaplus|vymena|fanda|krasna|doma|prask)\.nova\.cz/(?:[^/]+/)+(?P<id>[^/]+?)(?:\.html|/|$)'
+    _VALID_URL = r'https?://(?:[^.]+\.)?(?P<site>tv(?:noviny)?|tn|novaplus|vymena|fanda|krasna|doma|prask)\.nova\.cz/(?:[^/]+/)+(?P<id>[^/]+?)(?:\.html|/|$)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://tvnoviny.nova.cz/clanek/novinky/co-na-sebe-sportaci-praskli-vime-jestli-pujde-hrdlicka-na-materskou.html?utm_source=tvnoviny&utm_medium=cpfooter&utm_campaign=novaplus',
         'url': 'http://tvnoviny.nova.cz/clanek/novinky/co-na-sebe-sportaci-praskli-vime-jestli-pujde-hrdlicka-na-materskou.html?utm_source=tvnoviny&utm_medium=cpfooter&utm_campaign=novaplus',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/npr.py

@@ -9,7 +9,7 @@ from ..utils import (
 
 
 
 
 class NprIE(InfoExtractor):
 class NprIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?npr\.org/player/v2/mediaPlayer\.html\?.*\bid=(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www\.)?npr\.org/player/v2/mediaPlayer\.html\?.*\bid=(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.npr.org/player/v2/mediaPlayer.html?id=449974205',
         'url': 'http://www.npr.org/player/v2/mediaPlayer.html?id=449974205',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/ntvru.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 class NTVRuIE(InfoExtractor):
 class NTVRuIE(InfoExtractor):
     IE_NAME = 'ntv.ru'
     IE_NAME = 'ntv.ru'
-    _VALID_URL = r'http://(?:www\.)?ntv\.ru/(?P<id>.+)'
+    _VALID_URL = r'https?://(?:www\.)?ntv\.ru/(?P<id>.+)'
 
 
     _TESTS = [
     _TESTS = [
         {
         {

+ 3 - 3
youtube_dl/extractor/orf.py

@@ -137,7 +137,7 @@ class ORFTVthekIE(InfoExtractor):
 class ORFOE1IE(InfoExtractor):
 class ORFOE1IE(InfoExtractor):
     IE_NAME = 'orf:oe1'
     IE_NAME = 'orf:oe1'
     IE_DESC = 'Radio Österreich 1'
     IE_DESC = 'Radio Österreich 1'
-    _VALID_URL = r'http://oe1\.orf\.at/(?:programm/|konsole.*?#\?track_id=)(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://oe1\.orf\.at/(?:programm/|konsole.*?#\?track_id=)(?P<id>[0-9]+)'
 
 
     # Audios on ORF radio are only available for 7 days, so we can't add tests.
     # Audios on ORF radio are only available for 7 days, so we can't add tests.
     _TEST = {
     _TEST = {
@@ -171,7 +171,7 @@ class ORFOE1IE(InfoExtractor):
 class ORFFM4IE(InfoExtractor):
 class ORFFM4IE(InfoExtractor):
     IE_NAME = 'orf:fm4'
     IE_NAME = 'orf:fm4'
     IE_DESC = 'radio FM4'
     IE_DESC = 'radio FM4'
-    _VALID_URL = r'http://fm4\.orf\.at/(?:7tage/?#|player/)(?P<date>[0-9]+)/(?P<show>\w+)'
+    _VALID_URL = r'https?://fm4\.orf\.at/(?:7tage/?#|player/)(?P<date>[0-9]+)/(?P<show>\w+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://fm4.orf.at/player/20160110/IS/',
         'url': 'http://fm4.orf.at/player/20160110/IS/',
@@ -222,7 +222,7 @@ class ORFFM4IE(InfoExtractor):
 class ORFIPTVIE(InfoExtractor):
 class ORFIPTVIE(InfoExtractor):
     IE_NAME = 'orf:iptv'
     IE_NAME = 'orf:iptv'
     IE_DESC = 'iptv.ORF.at'
     IE_DESC = 'iptv.ORF.at'
-    _VALID_URL = r'http://iptv\.orf\.at/(?:#/)?stories/(?P<id>\d+)'
+    _VALID_URL = r'https?://iptv\.orf\.at/(?:#/)?stories/(?P<id>\d+)'
 
 
     _TEST = {
     _TEST = {
         'url': 'http://iptv.orf.at/stories/2275236/',
         'url': 'http://iptv.orf.at/stories/2275236/',

+ 1 - 1
youtube_dl/extractor/philharmoniedeparis.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 class PhilharmonieDeParisIE(InfoExtractor):
 class PhilharmonieDeParisIE(InfoExtractor):
     IE_DESC = 'Philharmonie de Paris'
     IE_DESC = 'Philharmonie de Paris'
-    _VALID_URL = r'http://live\.philharmoniedeparis\.fr/(?:[Cc]oncert/|misc/Playlist\.ashx\?id=)(?P<id>\d+)'
+    _VALID_URL = r'https?://live\.philharmoniedeparis\.fr/(?:[Cc]oncert/|misc/Playlist\.ashx\?id=)(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://live.philharmoniedeparis.fr/concert/1032066.html',
         'url': 'http://live.philharmoniedeparis.fr/concert/1032066.html',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/photobucket.py

@@ -8,7 +8,7 @@ from ..compat import compat_urllib_parse_unquote
 
 
 
 
 class PhotobucketIE(InfoExtractor):
 class PhotobucketIE(InfoExtractor):
-    _VALID_URL = r'http://(?:[a-z0-9]+\.)?photobucket\.com/.*(([\?\&]current=)|_)(?P<id>.*)\.(?P<ext>(flv)|(mp4))'
+    _VALID_URL = r'https?://(?:[a-z0-9]+\.)?photobucket\.com/.*(([\?\&]current=)|_)(?P<id>.*)\.(?P<ext>(flv)|(mp4))'
     _TEST = {
     _TEST = {
         'url': 'http://media.photobucket.com/user/rachaneronas/media/TiredofLinkBuildingTryBacklinkMyDomaincom_zpsc0c3b9fa.mp4.html?filters[term]=search&filters[primary]=videos&filters[secondary]=images&sort=1&o=0',
         'url': 'http://media.photobucket.com/user/rachaneronas/media/TiredofLinkBuildingTryBacklinkMyDomaincom_zpsc0c3b9fa.mp4.html?filters[term]=search&filters[primary]=videos&filters[secondary]=images&sort=1&o=0',
         'md5': '7dabfb92b0a31f6c16cebc0f8e60ff99',
         'md5': '7dabfb92b0a31f6c16cebc0f8e60ff99',

+ 1 - 1
youtube_dl/extractor/pornhd.py

@@ -12,7 +12,7 @@ from ..utils import (
 
 
 
 
 class PornHdIE(InfoExtractor):
 class PornHdIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?pornhd\.com/(?:[a-z]{2,4}/)?videos/(?P<id>\d+)(?:/(?P<display_id>.+))?'
+    _VALID_URL = r'https?://(?:www\.)?pornhd\.com/(?:[a-z]{2,4}/)?videos/(?P<id>\d+)(?:/(?P<display_id>.+))?'
     _TEST = {
     _TEST = {
         'url': 'http://www.pornhd.com/videos/1962/sierra-day-gets-his-cum-all-over-herself-hd-porn-video',
         'url': 'http://www.pornhd.com/videos/1962/sierra-day-gets-his-cum-all-over-herself-hd-porn-video',
         'md5': '956b8ca569f7f4d8ec563e2c41598441',
         'md5': '956b8ca569f7f4d8ec563e2c41598441',

+ 1 - 1
youtube_dl/extractor/pornovoisines.py

@@ -13,7 +13,7 @@ from ..utils import (
 
 
 
 
 class PornoVoisinesIE(InfoExtractor):
 class PornoVoisinesIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?pornovoisines\.com/showvideo/(?P<id>\d+)/(?P<display_id>[^/]+)'
+    _VALID_URL = r'https?://(?:www\.)?pornovoisines\.com/showvideo/(?P<id>\d+)/(?P<display_id>[^/]+)'
 
 
     _VIDEO_URL_TEMPLATE = 'http://stream%d.pornovoisines.com' \
     _VIDEO_URL_TEMPLATE = 'http://stream%d.pornovoisines.com' \
         '/static/media/video/transcoded/%s-640x360-1000-trscded.mp4'
         '/static/media/video/transcoded/%s-640x360-1000-trscded.mp4'

+ 1 - 1
youtube_dl/extractor/pyvideo.py

@@ -7,7 +7,7 @@ from .common import InfoExtractor
 
 
 
 
 class PyvideoIE(InfoExtractor):
 class PyvideoIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?pyvideo\.org/video/(?P<id>\d+)/(.*)'
+    _VALID_URL = r'https?://(?:www\.)?pyvideo\.org/video/(?P<id>\d+)/(.*)'
 
 
     _TESTS = [
     _TESTS = [
         {
         {

+ 5 - 5
youtube_dl/extractor/qqmusic.py

@@ -18,7 +18,7 @@ from ..utils import (
 class QQMusicIE(InfoExtractor):
 class QQMusicIE(InfoExtractor):
     IE_NAME = 'qqmusic'
     IE_NAME = 'qqmusic'
     IE_DESC = 'QQ音乐'
     IE_DESC = 'QQ音乐'
-    _VALID_URL = r'http://y.qq.com/#type=song&mid=(?P<id>[0-9A-Za-z]+)'
+    _VALID_URL = r'https?://y.qq.com/#type=song&mid=(?P<id>[0-9A-Za-z]+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://y.qq.com/#type=song&mid=004295Et37taLD',
         'url': 'http://y.qq.com/#type=song&mid=004295Et37taLD',
         'md5': '9ce1c1c8445f561506d2e3cfb0255705',
         'md5': '9ce1c1c8445f561506d2e3cfb0255705',
@@ -172,7 +172,7 @@ class QQPlaylistBaseIE(InfoExtractor):
 class QQMusicSingerIE(QQPlaylistBaseIE):
 class QQMusicSingerIE(QQPlaylistBaseIE):
     IE_NAME = 'qqmusic:singer'
     IE_NAME = 'qqmusic:singer'
     IE_DESC = 'QQ音乐 - 歌手'
     IE_DESC = 'QQ音乐 - 歌手'
-    _VALID_URL = r'http://y.qq.com/#type=singer&mid=(?P<id>[0-9A-Za-z]+)'
+    _VALID_URL = r'https?://y.qq.com/#type=singer&mid=(?P<id>[0-9A-Za-z]+)'
     _TEST = {
     _TEST = {
         'url': 'http://y.qq.com/#type=singer&mid=001BLpXF2DyJe2',
         'url': 'http://y.qq.com/#type=singer&mid=001BLpXF2DyJe2',
         'info_dict': {
         'info_dict': {
@@ -217,7 +217,7 @@ class QQMusicSingerIE(QQPlaylistBaseIE):
 class QQMusicAlbumIE(QQPlaylistBaseIE):
 class QQMusicAlbumIE(QQPlaylistBaseIE):
     IE_NAME = 'qqmusic:album'
     IE_NAME = 'qqmusic:album'
     IE_DESC = 'QQ音乐 - 专辑'
     IE_DESC = 'QQ音乐 - 专辑'
-    _VALID_URL = r'http://y.qq.com/#type=album&mid=(?P<id>[0-9A-Za-z]+)'
+    _VALID_URL = r'https?://y.qq.com/#type=album&mid=(?P<id>[0-9A-Za-z]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://y.qq.com/#type=album&mid=000gXCTb2AhRR1',
         'url': 'http://y.qq.com/#type=album&mid=000gXCTb2AhRR1',
@@ -260,7 +260,7 @@ class QQMusicAlbumIE(QQPlaylistBaseIE):
 class QQMusicToplistIE(QQPlaylistBaseIE):
 class QQMusicToplistIE(QQPlaylistBaseIE):
     IE_NAME = 'qqmusic:toplist'
     IE_NAME = 'qqmusic:toplist'
     IE_DESC = 'QQ音乐 - 排行榜'
     IE_DESC = 'QQ音乐 - 排行榜'
-    _VALID_URL = r'http://y\.qq\.com/#type=toplist&p=(?P<id>(top|global)_[0-9]+)'
+    _VALID_URL = r'https?://y\.qq\.com/#type=toplist&p=(?P<id>(top|global)_[0-9]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://y.qq.com/#type=toplist&p=global_123',
         'url': 'http://y.qq.com/#type=toplist&p=global_123',
@@ -314,7 +314,7 @@ class QQMusicToplistIE(QQPlaylistBaseIE):
 class QQMusicPlaylistIE(QQPlaylistBaseIE):
 class QQMusicPlaylistIE(QQPlaylistBaseIE):
     IE_NAME = 'qqmusic:playlist'
     IE_NAME = 'qqmusic:playlist'
     IE_DESC = 'QQ音乐 - 歌单'
     IE_DESC = 'QQ音乐 - 歌单'
-    _VALID_URL = r'http://y\.qq\.com/#type=taoge&id=(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://y\.qq\.com/#type=taoge&id=(?P<id>[0-9]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://y.qq.com/#type=taoge&id=3462654915',
         'url': 'http://y.qq.com/#type=taoge&id=3462654915',

+ 2 - 2
youtube_dl/extractor/rai.py

@@ -18,7 +18,7 @@ from ..utils import (
 
 
 
 
 class RaiTVIE(InfoExtractor):
 class RaiTVIE(InfoExtractor):
-    _VALID_URL = r'http://(?:.+?\.)?(?:rai\.it|rai\.tv|rainews\.it)/dl/(?:[^/]+/)+media/.+?-(?P<id>[\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12})(?:-.+?)?\.html'
+    _VALID_URL = r'https?://(?:.+?\.)?(?:rai\.it|rai\.tv|rainews\.it)/dl/(?:[^/]+/)+media/.+?-(?P<id>[\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12})(?:-.+?)?\.html'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://www.rai.tv/dl/RaiTV/programmi/media/ContentItem-cb27157f-9dd0-4aee-b788-b1f67643a391.html',
             'url': 'http://www.rai.tv/dl/RaiTV/programmi/media/ContentItem-cb27157f-9dd0-4aee-b788-b1f67643a391.html',
@@ -175,7 +175,7 @@ class RaiTVIE(InfoExtractor):
 
 
 
 
 class RaiIE(InfoExtractor):
 class RaiIE(InfoExtractor):
-    _VALID_URL = r'http://(?:.+?\.)?(?:rai\.it|rai\.tv|rainews\.it)/dl/.+?-(?P<id>[\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12})(?:-.+?)?\.html'
+    _VALID_URL = r'https?://(?:.+?\.)?(?:rai\.it|rai\.tv|rainews\.it)/dl/.+?-(?P<id>[\da-f]{8}-[\da-f]{4}-[\da-f]{4}-[\da-f]{4}-[\da-f]{12})(?:-.+?)?\.html'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://www.report.rai.it/dl/Report/puntata/ContentItem-0c7a664b-d0f4-4b2c-8835-3f82e46f433e.html',
             'url': 'http://www.report.rai.it/dl/Report/puntata/ContentItem-0c7a664b-d0f4-4b2c-8835-3f82e46f433e.html',

+ 1 - 1
youtube_dl/extractor/redtube.py

@@ -5,7 +5,7 @@ from ..utils import ExtractorError
 
 
 
 
 class RedTubeIE(InfoExtractor):
 class RedTubeIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?redtube\.com/(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://(?:www\.)?redtube\.com/(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.redtube.com/66418',
         'url': 'http://www.redtube.com/66418',
         'md5': '7b8c22b5e7098a3e1c09709df1126d2d',
         'md5': '7b8c22b5e7098a3e1c09709df1126d2d',

+ 1 - 1
youtube_dl/extractor/ringtv.py

@@ -6,7 +6,7 @@ from .common import InfoExtractor
 
 
 
 
 class RingTVIE(InfoExtractor):
 class RingTVIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?ringtv\.craveonline\.com/(?P<type>news|videos/video)/(?P<id>[^/?#]+)'
+    _VALID_URL = r'https?://(?:www\.)?ringtv\.craveonline\.com/(?P<type>news|videos/video)/(?P<id>[^/?#]+)'
     _TEST = {
     _TEST = {
         'url': 'http://ringtv.craveonline.com/news/310833-luis-collazo-says-victor-ortiz-better-not-quit-on-jan-30',
         'url': 'http://ringtv.craveonline.com/news/310833-luis-collazo-says-victor-ortiz-better-not-quit-on-jan-30',
         'md5': 'd25945f5df41cdca2d2587165ac28720',
         'md5': 'd25945f5df41cdca2d2587165ac28720',

+ 2 - 2
youtube_dl/extractor/rtve.py

@@ -62,7 +62,7 @@ def _decrypt_url(png):
 class RTVEALaCartaIE(InfoExtractor):
 class RTVEALaCartaIE(InfoExtractor):
     IE_NAME = 'rtve.es:alacarta'
     IE_NAME = 'rtve.es:alacarta'
     IE_DESC = 'RTVE a la carta'
     IE_DESC = 'RTVE a la carta'
-    _VALID_URL = r'http://www\.rtve\.es/(m/)?alacarta/videos/[^/]+/[^/]+/(?P<id>\d+)'
+    _VALID_URL = r'https?://www\.rtve\.es/(m/)?alacarta/videos/[^/]+/[^/]+/(?P<id>\d+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.rtve.es/alacarta/videos/balonmano/o-swiss-cup-masculina-final-espana-suecia/2491869/',
         'url': 'http://www.rtve.es/alacarta/videos/balonmano/o-swiss-cup-masculina-final-espana-suecia/2491869/',
@@ -179,7 +179,7 @@ class RTVEInfantilIE(InfoExtractor):
 class RTVELiveIE(InfoExtractor):
 class RTVELiveIE(InfoExtractor):
     IE_NAME = 'rtve.es:live'
     IE_NAME = 'rtve.es:live'
     IE_DESC = 'RTVE.es live streams'
     IE_DESC = 'RTVE.es live streams'
-    _VALID_URL = r'http://www\.rtve\.es/directo/(?P<id>[a-zA-Z0-9-]+)'
+    _VALID_URL = r'https?://www\.rtve\.es/directo/(?P<id>[a-zA-Z0-9-]+)'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.rtve.es/directo/la-1/',
         'url': 'http://www.rtve.es/directo/la-1/',

+ 1 - 1
youtube_dl/extractor/ruhd.py

@@ -5,7 +5,7 @@ from .common import InfoExtractor
 
 
 
 
 class RUHDIE(InfoExtractor):
 class RUHDIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?ruhd\.ru/play\.php\?vid=(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www\.)?ruhd\.ru/play\.php\?vid=(?P<id>\d+)'
     _TEST = {
     _TEST = {
         'url': 'http://www.ruhd.ru/play.php?vid=207',
         'url': 'http://www.ruhd.ru/play.php?vid=207',
         'md5': 'd1a9ec4edf8598e3fbd92bb16072ba83',
         'md5': 'd1a9ec4edf8598e3fbd92bb16072ba83',

+ 3 - 3
youtube_dl/extractor/rutube.py

@@ -122,7 +122,7 @@ class RutubeEmbedIE(InfoExtractor):
 class RutubeChannelIE(InfoExtractor):
 class RutubeChannelIE(InfoExtractor):
     IE_NAME = 'rutube:channel'
     IE_NAME = 'rutube:channel'
     IE_DESC = 'Rutube channels'
     IE_DESC = 'Rutube channels'
-    _VALID_URL = r'http://rutube\.ru/tags/video/(?P<id>\d+)'
+    _VALID_URL = r'https?://rutube\.ru/tags/video/(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://rutube.ru/tags/video/1800/',
         'url': 'http://rutube.ru/tags/video/1800/',
         'info_dict': {
         'info_dict': {
@@ -156,7 +156,7 @@ class RutubeChannelIE(InfoExtractor):
 class RutubeMovieIE(RutubeChannelIE):
 class RutubeMovieIE(RutubeChannelIE):
     IE_NAME = 'rutube:movie'
     IE_NAME = 'rutube:movie'
     IE_DESC = 'Rutube movies'
     IE_DESC = 'Rutube movies'
-    _VALID_URL = r'http://rutube\.ru/metainfo/tv/(?P<id>\d+)'
+    _VALID_URL = r'https?://rutube\.ru/metainfo/tv/(?P<id>\d+)'
     _TESTS = []
     _TESTS = []
 
 
     _MOVIE_TEMPLATE = 'http://rutube.ru/api/metainfo/tv/%s/?format=json'
     _MOVIE_TEMPLATE = 'http://rutube.ru/api/metainfo/tv/%s/?format=json'
@@ -174,7 +174,7 @@ class RutubeMovieIE(RutubeChannelIE):
 class RutubePersonIE(RutubeChannelIE):
 class RutubePersonIE(RutubeChannelIE):
     IE_NAME = 'rutube:person'
     IE_NAME = 'rutube:person'
     IE_DESC = 'Rutube person videos'
     IE_DESC = 'Rutube person videos'
-    _VALID_URL = r'http://rutube\.ru/video/person/(?P<id>\d+)'
+    _VALID_URL = r'https?://rutube\.ru/video/person/(?P<id>\d+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://rutube.ru/video/person/313878/',
         'url': 'http://rutube.ru/video/person/313878/',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/screenjunkies.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 
 
 class ScreenJunkiesIE(InfoExtractor):
 class ScreenJunkiesIE(InfoExtractor):
-    _VALID_URL = r'http://www.screenjunkies.com/video/(?P<display_id>[^/]+?)(?:-(?P<id>\d+))?(?:[/?#&]|$)'
+    _VALID_URL = r'https?://www.screenjunkies.com/video/(?P<display_id>[^/]+?)(?:-(?P<id>\d+))?(?:[/?#&]|$)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.screenjunkies.com/video/best-quentin-tarantino-movie-2841915',
         'url': 'http://www.screenjunkies.com/video/best-quentin-tarantino-movie-2841915',
         'md5': '5c2b686bec3d43de42bde9ec047536b0',
         'md5': '5c2b686bec3d43de42bde9ec047536b0',

+ 1 - 1
youtube_dl/extractor/senateisvp.py

@@ -48,7 +48,7 @@ class SenateISVPIE(InfoExtractor):
         ['arch', '', 'http://ussenate-f.akamaihd.net/']
         ['arch', '', 'http://ussenate-f.akamaihd.net/']
     ]
     ]
     _IE_NAME = 'senate.gov'
     _IE_NAME = 'senate.gov'
-    _VALID_URL = r'http://www\.senate\.gov/isvp/?\?(?P<qs>.+)'
+    _VALID_URL = r'https?://www\.senate\.gov/isvp/?\?(?P<qs>.+)'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://www.senate.gov/isvp/?comm=judiciary&type=live&stt=&filename=judiciary031715&auto_play=false&wmode=transparent&poster=http%3A%2F%2Fwww.judiciary.senate.gov%2Fthemes%2Fjudiciary%2Fimages%2Fvideo-poster-flash-fit.png',
         'url': 'http://www.senate.gov/isvp/?comm=judiciary&type=live&stt=&filename=judiciary031715&auto_play=false&wmode=transparent&poster=http%3A%2F%2Fwww.judiciary.senate.gov%2Fthemes%2Fjudiciary%2Fimages%2Fvideo-poster-flash-fit.png',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/shared.py

@@ -13,7 +13,7 @@ from ..utils import (
 
 
 class SharedIE(InfoExtractor):
 class SharedIE(InfoExtractor):
     IE_DESC = 'shared.sx and vivo.sx'
     IE_DESC = 'shared.sx and vivo.sx'
-    _VALID_URL = r'http://(?:shared|vivo)\.sx/(?P<id>[\da-z]{10})'
+    _VALID_URL = r'https?://(?:shared|vivo)\.sx/(?P<id>[\da-z]{10})'
 
 
     _TESTS = [{
     _TESTS = [{
         'url': 'http://shared.sx/0060718775',
         'url': 'http://shared.sx/0060718775',

+ 1 - 1
youtube_dl/extractor/sport5.py

@@ -8,7 +8,7 @@ from ..utils import ExtractorError
 
 
 
 
 class Sport5IE(InfoExtractor):
 class Sport5IE(InfoExtractor):
-    _VALID_URL = r'http://(?:www|vod)?\.sport5\.co\.il/.*\b(?:Vi|docID)=(?P<id>\d+)'
+    _VALID_URL = r'https?://(?:www|vod)?\.sport5\.co\.il/.*\b(?:Vi|docID)=(?P<id>\d+)'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://vod.sport5.co.il/?Vc=147&Vi=176331&Page=1',
             'url': 'http://vod.sport5.co.il/?Vc=147&Vi=176331&Page=1',

+ 1 - 1
youtube_dl/extractor/ssa.py

@@ -8,7 +8,7 @@ from ..utils import (
 
 
 
 
 class SSAIE(InfoExtractor):
 class SSAIE(InfoExtractor):
-    _VALID_URL = r'http://ssa\.nls\.uk/film/(?P<id>\d+)'
+    _VALID_URL = r'https?://ssa\.nls\.uk/film/(?P<id>\d+)'
     _TEST = {
     _TEST = {
         'url': 'http://ssa.nls.uk/film/3561',
         'url': 'http://ssa.nls.uk/film/3561',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/sztvhu.py

@@ -5,7 +5,7 @@ from .common import InfoExtractor
 
 
 
 
 class SztvHuIE(InfoExtractor):
 class SztvHuIE(InfoExtractor):
-    _VALID_URL = r'http://(?:(?:www\.)?sztv\.hu|www\.tvszombathely\.hu)/(?:[^/]+)/.+-(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://(?:(?:www\.)?sztv\.hu|www\.tvszombathely\.hu)/(?:[^/]+)/.+-(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://sztv.hu/hirek/cserkeszek-nepszerusitettek-a-kornyezettudatos-eletmodot-a-savaria-teren-20130909',
         'url': 'http://sztv.hu/hirek/cserkeszek-nepszerusitettek-a-kornyezettudatos-eletmodot-a-savaria-teren-20130909',
         'md5': 'a6df607b11fb07d0e9f2ad94613375cb',
         'md5': 'a6df607b11fb07d0e9f2ad94613375cb',

+ 1 - 1
youtube_dl/extractor/teamcoco.py

@@ -16,7 +16,7 @@ from ..compat import compat_ord
 
 
 
 
 class TeamcocoIE(InfoExtractor):
 class TeamcocoIE(InfoExtractor):
-    _VALID_URL = r'http://teamcoco\.com/video/(?P<video_id>[0-9]+)?/?(?P<display_id>.*)'
+    _VALID_URL = r'https?://teamcoco\.com/video/(?P<video_id>[0-9]+)?/?(?P<display_id>.*)'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://teamcoco.com/video/80187/conan-becomes-a-mary-kay-beauty-consultant',
             'url': 'http://teamcoco.com/video/80187/conan-becomes-a-mary-kay-beauty-consultant',

+ 1 - 1
youtube_dl/extractor/tele13.py

@@ -11,7 +11,7 @@ from ..utils import (
 
 
 
 
 class Tele13IE(InfoExtractor):
 class Tele13IE(InfoExtractor):
-    _VALID_URL = r'^http://(?:www\.)?t13\.cl/videos(?:/[^/]+)+/(?P<id>[\w-]+)'
+    _VALID_URL = r'^https?://(?:www\.)?t13\.cl/videos(?:/[^/]+)+/(?P<id>[\w-]+)'
     _TESTS = [
     _TESTS = [
         {
         {
             'url': 'http://www.t13.cl/videos/actualidad/el-circulo-de-hierro-de-michelle-bachelet-en-su-regreso-a-la-moneda',
             'url': 'http://www.t13.cl/videos/actualidad/el-circulo-de-hierro-de-michelle-bachelet-en-su-regreso-a-la-moneda',

+ 1 - 1
youtube_dl/extractor/tf1.py

@@ -6,7 +6,7 @@ from .common import InfoExtractor
 
 
 class TF1IE(InfoExtractor):
 class TF1IE(InfoExtractor):
     """TF1 uses the wat.tv player."""
     """TF1 uses the wat.tv player."""
-    _VALID_URL = r'http://(?:(?:videos|www|lci)\.tf1|www\.tfou)\.fr/(?:[^/]+/)*(?P<id>.+?)\.html'
+    _VALID_URL = r'https?://(?:(?:videos|www|lci)\.tf1|www\.tfou)\.fr/(?:[^/]+/)*(?P<id>.+?)\.html'
     _TESTS = [{
     _TESTS = [{
         'url': 'http://videos.tf1.fr/auto-moto/citroen-grand-c4-picasso-2013-presentation-officielle-8062060.html',
         'url': 'http://videos.tf1.fr/auto-moto/citroen-grand-c4-picasso-2013-presentation-officielle-8062060.html',
         'info_dict': {
         'info_dict': {

+ 1 - 1
youtube_dl/extractor/thvideo.py

@@ -10,7 +10,7 @@ from ..utils import (
 
 
 
 
 class THVideoIE(InfoExtractor):
 class THVideoIE(InfoExtractor):
-    _VALID_URL = r'http://(?:www\.)?thvideo\.tv/(?:v/th|mobile\.php\?cid=)(?P<id>[0-9]+)'
+    _VALID_URL = r'https?://(?:www\.)?thvideo\.tv/(?:v/th|mobile\.php\?cid=)(?P<id>[0-9]+)'
     _TEST = {
     _TEST = {
         'url': 'http://thvideo.tv/v/th1987/',
         'url': 'http://thvideo.tv/v/th1987/',
         'md5': 'fa107b1f73817e325e9433505a70db50',
         'md5': 'fa107b1f73817e325e9433505a70db50',

Một số tệp đã không được hiển thị bởi vì quá nhiều tập tin thay đổi trong này khác