diff options
author | Sergey M․ <dstftw@gmail.com> | 2018-02-04 07:52:50 +0700 |
---|---|---|
committer | Sergey M․ <dstftw@gmail.com> | 2018-02-04 07:55:04 +0700 |
commit | 5399ab3f0c63d47d44a7f8c3506192775f2605d3 (patch) | |
tree | 6bacaf830760332c004d79e014b689de3f2c635a /youtube_dl/extractor/brightcove.py | |
parent | b91a7a4e5e6221d6fdf8e4074fbc3e9b94a18602 (diff) |
[brightcove] Pass embed page URL as referrer (closes #15486)
Diffstat (limited to 'youtube_dl/extractor/brightcove.py')
-rw-r--r-- | youtube_dl/extractor/brightcove.py | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/youtube_dl/extractor/brightcove.py b/youtube_dl/extractor/brightcove.py index f04505011..f3c0dc3fa 100644 --- a/youtube_dl/extractor/brightcove.py +++ b/youtube_dl/extractor/brightcove.py @@ -690,10 +690,17 @@ class BrightcoveNewIE(AdobePassIE): webpage, 'policy key', group='pk') api_url = 'https://edge.api.brightcove.com/playback/v1/accounts/%s/videos/%s' % (account_id, video_id) - try: - json_data = self._download_json(api_url, video_id, headers={ - 'Accept': 'application/json;pk=%s' % policy_key + headers = { + 'Accept': 'application/json;pk=%s' % policy_key, + } + referrer = smuggled_data.get('referrer') + if referrer: + headers.update({ + 'Referer': referrer, + 'Origin': re.search(r'https?://[^/]+', referrer).group(0), }) + try: + json_data = self._download_json(api_url, video_id, headers=headers) except ExtractorError as e: if isinstance(e.cause, compat_HTTPError) and e.cause.code == 403: json_data = self._parse_json(e.cause.read().decode(), video_id)[0] |