Browse Source

mod: code

Ben 10 months ago
parent
commit
58ad76d11c

File diff suppressed because it is too large
+ 0 - 0
js/bundle.js


+ 1 - 1
js/deploy.js

@@ -33,7 +33,7 @@ async function upload(filePath) {
 }
 
 Promise.all(
-    [upload('video.bundle.js')]
+    [upload('youtube.bundle.js')]
 ).then(() => {
     console.log('All files uploaded successfully!');
 });

+ 1 - 1
js/webpack.config.js

@@ -6,7 +6,7 @@ const WebpackObfuscator = require('webpack-obfuscator');
 module.exports = {
     mode: 'production',
     entry: {
-        video: './video.js',
+        youtube: './youtube/youtube.js',
     },
     output: {
         path: path.resolve(__dirname),

File diff suppressed because it is too large
+ 0 - 0
js/youtube.bundle.js


+ 0 - 0
js/base.js → js/youtube/base.js


+ 0 - 0
js/extract_function.js → js/youtube/extract_function.js


+ 0 - 0
js/main.swift → js/youtube/main.swift


+ 5 - 5
js/video_test.js → js/youtube/test.js

@@ -1,16 +1,16 @@
-detail(`https://www.youtube.com/watch?v=bu7nU9Mhpyo`, 'WEB')
+detail(`https://www.youtube.com/watch?v=OTGXR0hKEs0`, 'WEB')
     .then(res => {
         console.log(res);
     })
     .catch(e => {
         console.log(e);
     })
-//
-// search("周 杰伦", null, "WEB")
+
+// search("trump gets mercilessly booed at speech", null, "WEB")
 //     .then(res => {
 //         console.log(res);
-//
-//         search("周 杰伦", res["data"]["next"], "WEB")
+
+//         search("trump gets mercilessly booed at speech", res["data"]["next"], "WEB")
 //             .then(res => {
 //                 console.log(res);
 //             })

+ 1 - 1
js/video.html → js/youtube/youtube.html

@@ -4,6 +4,6 @@
     <meta charset="UTF-8">
     <title>JavaScript in Browser</title>
     <script src="video.js"></script>
-    <script src="video_test.js"></script>
+    <script src="test.js"></script>
 </head>
 </html>

+ 19 - 20
js/video.js → js/youtube/youtube.js

@@ -87,6 +87,7 @@ parseSetCookie = (headers) => {
 request = async (method, url, data = null, headers = {}, platform) => {
     if (platform === "WEB") {
         url = url.replace("https://www.youtube.com", "http://127.0.0.1");
+        url = url.replace("https://music.youtube.com", "http://127.0.0.1");
     }
     console.log(`request url:${url}`)
     console.log(`request data:${data}`)
@@ -274,33 +275,20 @@ detail = async (url, platform) => {
 
         let originFormats = [];
 
-        // // web
-        // const currentFormats = [];
-        // for (const format of ytInitialPlayerResponse["streamingData"]["formats"].concat(ytInitialPlayerResponse["streamingData"]["adaptiveFormats"])) {
-        //     if (format) {
-        //         format["from"] = "web"
-        //         currentFormats.push(format);
-        //     }
-        // }
-        // originFormats = originFormats.concat(currentFormats);
-        // console.log(`after html, format size:${originFormats.length}`);
-
         // android
         try {
-            const apiKey = 'AIzaSyAO_FJ2SlqU8Q4STEHLGCilw_Y9_11qcW8'
-            const apiUrl = `https://www.youtube.com/youtubei/v1/player?key=${apiKey}`;
+            const apiUrl = `https://music.youtube.com/youtubei/v1/player?key=AIzaSyAO_FJ2SlqU8Q4STEHLGCilw_Y9_11qcW8`;
             const apiResp = await request('POST', apiUrl, JSON.stringify({
-                "videoId": url.replace('https://www.youtube.com/watch?v=', ''),
-                "contentCheckOk": true,
-                "params": "8AEB",
                 "context": {
                     "client": {
-                        "clientName": "ANDROID_MUSIC",
-                        "clientVersion": "5.16.51",
-                        "androidSdkVersion": 30
+                        "clientName": "ANDROID",
+                        "hl": "en",
+                        "clientVersion": "18.49.37",
+                        "gl": "US"
                     }
                 },
-                "racyCheckOk": true
+                "videoId": url.replace('https://www.youtube.com/watch?v=', ''),
+                "params": "CgIQBg"
             }), {
                 'Host': 'www.youtube.com',
                 'Connection': 'keep-alive',
@@ -325,6 +313,17 @@ detail = async (url, platform) => {
         }
         console.log(`after android api, format size:${originFormats.length}`);
 
+        // web
+        const currentFormats = [];
+        for (const format of ytInitialPlayerResponse["streamingData"]["formats"].concat(ytInitialPlayerResponse["streamingData"]["adaptiveFormats"])) {
+            if (format) {
+                format["from"] = "web"
+                currentFormats.push(format);
+            }
+        }
+        originFormats = originFormats.concat(currentFormats);
+        console.log(`after html, format size:${originFormats.length}`);
+
         const baseJsUrl = `https://www.youtube.com${JSON.parse(html.match(/set\(({.+?})\);/)[1])["PLAYER_JS_URL"]}`
         let formatIds = [];
         const formats = [];

File diff suppressed because it is too large
+ 0 - 1236
js/yt-dlp.html


+ 0 - 0
app.py → server/app.py


+ 0 - 0
cloud-init.sh → server/cloud-init.sh


+ 0 - 0
requirements.txt → server/requirements.txt


+ 0 - 0
run.sh → server/run.sh


+ 0 - 0
test.py → server/test.py


+ 0 - 72
yt_dlp_format.json

@@ -1,72 +0,0 @@
-[
-  {
-    "asr": 44100,
-    "filesize": 16400391,
-    "format_id": "18",
-    "format_note": "360p",
-    "source_preference": -1,
-    "fps": 25,
-    "audio_channels": 2,
-    "height": 360,
-    "quality": 6.0,
-    "has_drm": false,
-    "tbr": 717.702,
-    "filesize_approx": 16400387,
-    "url": "https://rr4---sn-i3b7knsd.googlevideo.com/videoplayback?expire=1715632560&ei=UCVCZqyLEf2w0-kP3KutwAc&ip=18.163.124.204&id=o-AIWEwZLCprrVRrJY92NTQkDNsRDjv0O3tDTrijiNaphG&itag=18&source=youtube&requiressl=yes&xpc=EgVo2aDSNQ%3D%3D&mh=LC&mm=31%2C26&mn=sn-i3b7knsd%2Csn-npoe7nss&ms=au%2Conr&mv=m&mvi=4&pl=16&initcwndbps=1367500&vprv=1&svpuc=1&mime=video%2Fmp4&rqh=1&gir=yes&clen=16400391&ratebypass=yes&dur=182.810&lmt=1703531079658098&mt=1715610532&fvip=2&c=ANDROID&txp=4538434&sparams=expire%2Cei%2Cip%2Cid%2Citag%2Csource%2Crequiressl%2Cxpc%2Cvprv%2Csvpuc%2Cmime%2Crqh%2Cgir%2Cclen%2Cratebypass%2Cdur%2Clmt&sig=AJfQdSswRQIgK-KwPBfTGdMHZvtknsn_oJpHTstbIjJoUCwJrmQBb94CIQDZ7kcv_nAn6vu-By-NUvSVxVciutPUi6aGpe-FjIM-wg%3D%3D&lsparams=mh%2Cmm%2Cmn%2Cms%2Cmv%2Cmvi%2Cpl%2Cinitcwndbps&lsig=AHWaYeowRgIhAMThELxhfOClrz_7iFI-kbBHIbLdP9BSlcCeqO7GGLGfAiEA6AoB2b8-PAu9sLsXcxgvqu9rycJGjJLpF5dH3oQfw48%3D",
-    "width": 640,
-    "language": null,
-    "language_preference": -1,
-    "preference": null,
-    "ext": "mp4",
-    "vcodec": "avc1.42001E",
-    "acodec": "mp4a.40.2",
-    "dynamic_range": "SDR",
-    "downloader_options": {
-      "http_chunk_size": 10485760
-    },
-    "protocol": "https",
-    "resolution": "640x360",
-    "aspect_ratio": 1.78,
-    "http_headers": {},
-    "video_ext": "mp4",
-    "audio_ext": "none",
-    "vbr": null,
-    "abr": null,
-    "format": "18 - 640x360 (360p)"
-  },
-  {
-    "asr": 44100,
-    "filesize": null,
-    "format_id": "22",
-    "format_note": "720p",
-    "source_preference": -5,
-    "fps": 25,
-    "audio_channels": 2,
-    "height": 720,
-    "quality": 8.0,
-    "has_drm": false,
-    "tbr": 907.006,
-    "filesize_approx": 20726220,
-    "url": "https://rr4---sn-i3b7knsd.googlevideo.com/videoplayback?expire=1715632560&ei=UCVCZqyLEf2w0-kP3KutwAc&ip=18.163.124.204&id=o-AIWEwZLCprrVRrJY92NTQkDNsRDjv0O3tDTrijiNaphG&itag=22&source=youtube&requiressl=yes&xpc=EgVo2aDSNQ%3D%3D&mh=LC&mm=31%2C26&mn=sn-i3b7knsd%2Csn-npoe7nss&ms=au%2Conr&mv=m&mvi=4&pl=16&initcwndbps=1367500&vprv=1&svpuc=1&mime=video%2Fmp4&rqh=1&cnr=14&ratebypass=yes&dur=182.810&lmt=1703534767472349&mt=1715610532&fvip=2&c=ANDROID&txp=4532434&sparams=expire%2Cei%2Cip%2Cid%2Citag%2Csource%2Crequiressl%2Cxpc%2Cvprv%2Csvpuc%2Cmime%2Crqh%2Ccnr%2Cratebypass%2Cdur%2Clmt&sig=AJfQdSswRQIhAO0nJbEs1CLto-KfsmnhEouydulgG23l6udWU2SYBN3WAiAstLWVnaWL6q-mrdzgAGCKDNP56miv7W0WEqsO6WtSiA%3D%3D&lsparams=mh%2Cmm%2Cmn%2Cms%2Cmv%2Cmvi%2Cpl%2Cinitcwndbps&lsig=AHWaYeowRgIhAMThELxhfOClrz_7iFI-kbBHIbLdP9BSlcCeqO7GGLGfAiEA6AoB2b8-PAu9sLsXcxgvqu9rycJGjJLpF5dH3oQfw48%3D",
-    "width": 1280,
-    "language": null,
-    "language_preference": -1,
-    "preference": null,
-    "ext": "mp4",
-    "vcodec": "avc1.64001F",
-    "acodec": "mp4a.40.2",
-    "dynamic_range": "SDR",
-    "downloader_options": {
-      "http_chunk_size": 10485760
-    },
-    "protocol": "https",
-    "resolution": "1280x720",
-    "aspect_ratio": 1.78,
-    "http_headers": {},
-    "video_ext": "mp4",
-    "audio_ext": "none",
-    "vbr": null,
-    "abr": null,
-    "format": "22 - 1280x720 (720p)"
-  }
-]

Some files were not shown because too many files changed in this diff