mirror of
				https://github.com/yt-dlp/yt-dlp.git
				synced 2025-10-31 14:45:14 +00:00 
			
		
		
		
	[npo] Improve npo.nl (Fixes #4173)
This commit is contained in:
		| @@ -284,6 +284,10 @@ class TestUtil(unittest.TestCase): | |||||||
|         d = json.loads(stripped) |         d = json.loads(stripped) | ||||||
|         self.assertEqual(d, [{"id": "532cb", "x": 3}]) |         self.assertEqual(d, [{"id": "532cb", "x": 3}]) | ||||||
|  |  | ||||||
|  |         stripped = strip_jsonp('parseMetadata({"STATUS":"OK"})\n\n\n//epc') | ||||||
|  |         d = json.loads(stripped) | ||||||
|  |         self.assertEqual(d, {'STATUS': 'OK'}) | ||||||
|  |  | ||||||
|     def test_uppercase_escape(self): |     def test_uppercase_escape(self): | ||||||
|         self.assertEqual(uppercase_escape('aä'), 'aä') |         self.assertEqual(uppercase_escape('aä'), 'aä') | ||||||
|         self.assertEqual(uppercase_escape('\\U0001d550'), '𝕐') |         self.assertEqual(uppercase_escape('\\U0001d550'), '𝕐') | ||||||
|   | |||||||
| @@ -7,6 +7,7 @@ from ..utils import ( | |||||||
|     unified_strdate, |     unified_strdate, | ||||||
|     parse_duration, |     parse_duration, | ||||||
|     qualities, |     qualities, | ||||||
|  |     strip_jsonp, | ||||||
|     url_basename, |     url_basename, | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -63,7 +64,7 @@ class NPOIE(InfoExtractor): | |||||||
|             'http://e.omroep.nl/metadata/aflevering/%s' % video_id, |             'http://e.omroep.nl/metadata/aflevering/%s' % video_id, | ||||||
|             video_id, |             video_id, | ||||||
|             # We have to remove the javascript callback |             # We have to remove the javascript callback | ||||||
|             transform_source=lambda j: re.sub(r'parseMetadata\((.*?)\);\n//.*$', r'\1', j) |             transform_source=strip_jsonp, | ||||||
|         ) |         ) | ||||||
|         token_page = self._download_webpage( |         token_page = self._download_webpage( | ||||||
|             'http://ida.omroep.nl/npoplayer/i.js', |             'http://ida.omroep.nl/npoplayer/i.js', | ||||||
|   | |||||||
| @@ -1331,7 +1331,8 @@ def parse_age_limit(s): | |||||||
|  |  | ||||||
|  |  | ||||||
| def strip_jsonp(code): | def strip_jsonp(code): | ||||||
|     return re.sub(r'(?s)^[a-zA-Z0-9_]+\s*\(\s*(.*)\);?\s*?\s*$', r'\1', code) |     return re.sub( | ||||||
|  |         r'(?s)^[a-zA-Z0-9_]+\s*\(\s*(.*)\);?\s*?(?://[^\n]*)*$', r'\1', code) | ||||||
|  |  | ||||||
|  |  | ||||||
| def js_to_json(code): | def js_to_json(code): | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Philipp Hagemeister
					Philipp Hagemeister