@pieda/video-dl 1.3.1 → 1.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { useYoutube } from './useYoutube';
|
|
2
2
|
import { useFacebook } from './useFacebook';
|
|
3
3
|
import { useVimeo } from './useVimeo';
|
|
4
|
+
import { useInstagram } from './useInstagram';
|
|
4
5
|
type TUseDownloader = {
|
|
5
|
-
type: 'youtube' | 'facebook' | 'vimeo';
|
|
6
|
+
type: 'youtube' | 'facebook' | 'vimeo' | 'instagram';
|
|
6
7
|
};
|
|
7
|
-
type TUseDownloaderResponse = typeof useYoutube | typeof useFacebook | typeof useVimeo;
|
|
8
|
+
type TUseDownloaderResponse = typeof useYoutube | typeof useFacebook | typeof useVimeo | typeof useInstagram;
|
|
8
9
|
export declare const useDownloader: ({ type }: TUseDownloader) => TUseDownloaderResponse;
|
|
9
10
|
export {};
|
package/dist/types/library.d.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export { useDownloader, useYoutube, useFacebook, useVimeo } from './composables';
|
|
1
|
+
export { useDownloader, useYoutube, useFacebook, useVimeo, useInstagram } from './composables';
|
package/dist/video-dl.cjs
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=o=>new Promise((
|
|
1
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const c=o=>new Promise((t,w)=>{import(o).then(e=>t(e.default)).catch(w)}),h=async(o,t)=>{const w=await c("fs"),e=await c("axios");return new Promise((u,r)=>{e.get(o,{responseType:"stream"}).then(n=>{const g=n.data,i=w.createWriteStream(t);g.pipe(i),i.on("finish",function(){i.close(()=>{u()})})}).catch(r)})},m=(o=!1)=>({log:(...t)=>{o&&console.log(...t)},error:(...t)=>{o&&console.error(...t)}}),f=async({videoId:o,dest:t,debug:w=!1})=>{const e=m(w);e.log(`Downloading video: ${o} to: ${t}`);const u=`https://www.youtube.com/watch?v=${o}`,r=await c("fs"),n=await c("path"),g=await c("@distube/ytdl-core");return r.existsSync(n.dirname(t))||r.mkdirSync(n.dirname(t),{recursive:!0},777),new Promise((i,a)=>{try{g(u).on("error",l=>{e.error(l),i([l,null])}).pipe(r.createWriteStream(t)).on("finish",()=>{e.log("Downloading finished."),i([null,!0])})}catch(s){console.log("error"),i([s,null])}})},y=async({videoId:o,dest:t,debug:w=!1})=>{try{const e=m(w);e.log(`Downloading video: ${o} to: ${t}`);const u=`https://m.facebook.com/watch/?v=${o}`,r=await c("fs"),n=await c("path"),g=await c("puppeteer");r.existsSync(n.dirname(t))||(r.mkdirSync(n.dirname(t),{recursive:!0},777),e.log(`建立 ${n.dirname(t)}`));const i=await g.launch();e.log("啟動 puppeteer");const a=await i.newPage();await a.setUserAgent("'Mozilla/5.0 (iPhone; CPU iPhone OS 16_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.6 Mobile/15E148 Safari/604.1'"),e.log("開新分頁"),await a.goto(u,{waitUntil:"networkidle0"}),e.log(`前往 ${u}`),await a.waitForSelector("video"),e.log("找到 video 元素");const s=await a.$eval("video",l=>l.getAttribute("src"));return e.log(`取得 video url: ${s}`),await i.close(),e.log("關閉 puppeteer"),await h(s,t),e.log(`下載完成 ${s}`),[null,!0]}catch(e){return[e,null]}},$=async({videoId:o,dest:t,debug:w=!1})=>{const e=m(w);e.log(`Downloading video: ${o} to: ${t}`);const u=await c("fs"),r=await c("path"),n=await c("axios"),g=async()=>{const a=await n.get("https://vimeo.com/_next/viewer",{responseType:"json",headers:{"X-Requested-With":"XMLHttpRequest"}}),{jwt:s}=a.data;return s||""},i=async(a="",s="")=>{const l=await n.get(`https://api.vimeo.com/videos/${a}?&fields=download`,{responseType:"json",headers:{"X-Requested-With":"XMLHttpRequest",Authorization:`jwt ${s}`}}),{download:p=[]}=l.data,d=p[0]||null;return(d==null?void 0:d.link)||""};return u.existsSync(r.dirname(t))||(u.mkdirSync(r.dirname(t),{recursive:!0},777),e.log(`建立 ${r.dirname(t)}`)),new Promise(async(a,s)=>{try{const l=await g();e.log(`取得 jwt ${l}`);const p=await i(o,l);e.log(`取得 videoUrl ${p}`),await h(p,t),e.log(`下載完成 ${t}`),a([null,!0])}catch(l){a([l,null])}})},v=async({videoId:o,dest:t,debug:w=!1})=>{try{const e=m(w);e.log(`Downloading video: ${o} to: ${t}`);const u=`https://www.instagram.com/share/${o}/`,r=await c("fs"),n=await c("path"),g=await c("puppeteer");r.existsSync(n.dirname(t))||(r.mkdirSync(n.dirname(t),{recursive:!0},777),e.log(`建立 ${n.dirname(t)}`));const i=await g.launch();e.log("啟動 puppeteer");const a=await i.newPage();await a.setUserAgent("'Mozilla/5.0 (iPhone; CPU iPhone OS 16_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.6 Mobile/15E148 Safari/604.1'"),e.log("開新分頁"),await a.goto(u,{}),e.log(`前往 ${u}`),await a.waitForSelector("video"),e.log("找到 video 元素");const s=await a.$eval("video",l=>l.getAttribute("src"));return e.log(`取得 video url: ${s}`),await i.close(),e.log("關閉 puppeteer"),await h(s,t),e.log(`下載完成 ${s}`),[null,!0]}catch(e){return[e,null]}},S=({type:o})=>{switch(o){case"youtube":return f;case"facebook":return y;case"vimeo":return $;case"instagram":return v;default:throw new Error(`Invalid video type: ${o}`)}};exports.useDownloader=S;exports.useFacebook=y;exports.useInstagram=v;exports.useVimeo=$;exports.useYoutube=f;
|
package/dist/video-dl.js
CHANGED
|
@@ -1,117 +1,142 @@
|
|
|
1
|
-
const c = (o) => new Promise((
|
|
2
|
-
import(o).then((
|
|
3
|
-
}),
|
|
4
|
-
const
|
|
5
|
-
return new Promise((
|
|
6
|
-
|
|
7
|
-
const
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
1
|
+
const c = (o) => new Promise((t, w) => {
|
|
2
|
+
import(o).then((e) => t(e.default)).catch(w);
|
|
3
|
+
}), d = async (o, t) => {
|
|
4
|
+
const w = await c("fs"), e = await c("axios");
|
|
5
|
+
return new Promise((u, r) => {
|
|
6
|
+
e.get(o, { responseType: "stream" }).then((n) => {
|
|
7
|
+
const g = n.data, i = w.createWriteStream(t);
|
|
8
|
+
g.pipe(i), i.on("finish", function() {
|
|
9
|
+
i.close(() => {
|
|
10
|
+
u();
|
|
11
11
|
});
|
|
12
12
|
});
|
|
13
13
|
}).catch(r);
|
|
14
14
|
});
|
|
15
|
-
},
|
|
16
|
-
log: (...
|
|
17
|
-
o && console.log(...
|
|
15
|
+
}, m = (o = !1) => ({
|
|
16
|
+
log: (...t) => {
|
|
17
|
+
o && console.log(...t);
|
|
18
18
|
},
|
|
19
|
-
error: (...
|
|
20
|
-
o && console.error(...
|
|
19
|
+
error: (...t) => {
|
|
20
|
+
o && console.error(...t);
|
|
21
21
|
}
|
|
22
22
|
}), f = async ({
|
|
23
23
|
videoId: o,
|
|
24
|
-
dest:
|
|
25
|
-
debug:
|
|
24
|
+
dest: t,
|
|
25
|
+
debug: w = !1
|
|
26
26
|
}) => {
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
const
|
|
30
|
-
return r.existsSync(
|
|
27
|
+
const e = m(w);
|
|
28
|
+
e.log(`Downloading video: ${o} to: ${t}`);
|
|
29
|
+
const u = `https://www.youtube.com/watch?v=${o}`, r = await c("fs"), n = await c("path"), g = await c("@distube/ytdl-core");
|
|
30
|
+
return r.existsSync(n.dirname(t)) || r.mkdirSync(n.dirname(t), { recursive: !0 }, 777), new Promise((i, a) => {
|
|
31
31
|
try {
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
throw l;
|
|
32
|
+
g(u).on("error", (l) => {
|
|
33
|
+
e.error(l), i([l, null]);
|
|
34
|
+
}).pipe(r.createWriteStream(t)).on("finish", () => {
|
|
35
|
+
e.log("Downloading finished."), i([null, !0]);
|
|
37
36
|
});
|
|
38
|
-
} catch (
|
|
39
|
-
|
|
37
|
+
} catch (s) {
|
|
38
|
+
console.log("error"), i([s, null]);
|
|
40
39
|
}
|
|
41
40
|
});
|
|
42
|
-
},
|
|
41
|
+
}, $ = async ({
|
|
43
42
|
videoId: o,
|
|
44
|
-
dest:
|
|
45
|
-
debug:
|
|
43
|
+
dest: t,
|
|
44
|
+
debug: w = !1
|
|
46
45
|
}) => {
|
|
47
46
|
try {
|
|
48
|
-
const
|
|
49
|
-
|
|
50
|
-
const
|
|
51
|
-
r.existsSync(
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
const
|
|
55
|
-
await
|
|
47
|
+
const e = m(w);
|
|
48
|
+
e.log(`Downloading video: ${o} to: ${t}`);
|
|
49
|
+
const u = `https://m.facebook.com/watch/?v=${o}`, r = await c("fs"), n = await c("path"), g = await c("puppeteer");
|
|
50
|
+
r.existsSync(n.dirname(t)) || (r.mkdirSync(n.dirname(t), { recursive: !0 }, 777), e.log(`建立 ${n.dirname(t)}`));
|
|
51
|
+
const i = await g.launch();
|
|
52
|
+
e.log("啟動 puppeteer");
|
|
53
|
+
const a = await i.newPage();
|
|
54
|
+
await a.setUserAgent(
|
|
56
55
|
"'Mozilla/5.0 (iPhone; CPU iPhone OS 16_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.6 Mobile/15E148 Safari/604.1'"
|
|
57
|
-
),
|
|
56
|
+
), e.log("開新分頁"), await a.goto(u, {
|
|
58
57
|
waitUntil: "networkidle0"
|
|
59
|
-
}),
|
|
60
|
-
const
|
|
61
|
-
return
|
|
62
|
-
} catch (
|
|
63
|
-
return [
|
|
58
|
+
}), e.log(`前往 ${u}`), await a.waitForSelector("video"), e.log("找到 video 元素");
|
|
59
|
+
const s = await a.$eval("video", (l) => l.getAttribute("src"));
|
|
60
|
+
return e.log(`取得 video url: ${s}`), await i.close(), e.log("關閉 puppeteer"), await d(s, t), e.log(`下載完成 ${s}`), [null, !0];
|
|
61
|
+
} catch (e) {
|
|
62
|
+
return [e, null];
|
|
64
63
|
}
|
|
65
|
-
},
|
|
64
|
+
}, y = async ({
|
|
66
65
|
videoId: o,
|
|
67
|
-
dest:
|
|
68
|
-
debug:
|
|
66
|
+
dest: t,
|
|
67
|
+
debug: w = !1
|
|
69
68
|
}) => {
|
|
70
|
-
const
|
|
71
|
-
|
|
72
|
-
const
|
|
73
|
-
const
|
|
69
|
+
const e = m(w);
|
|
70
|
+
e.log(`Downloading video: ${o} to: ${t}`);
|
|
71
|
+
const u = await c("fs"), r = await c("path"), n = await c("axios"), g = async () => {
|
|
72
|
+
const a = await n.get("https://vimeo.com/_next/viewer", {
|
|
74
73
|
responseType: "json",
|
|
75
74
|
headers: {
|
|
76
75
|
"X-Requested-With": "XMLHttpRequest"
|
|
77
76
|
}
|
|
78
|
-
}), { jwt:
|
|
79
|
-
return
|
|
80
|
-
},
|
|
81
|
-
const l = await
|
|
77
|
+
}), { jwt: s } = a.data;
|
|
78
|
+
return s || "";
|
|
79
|
+
}, i = async (a = "", s = "") => {
|
|
80
|
+
const l = await n.get(`https://api.vimeo.com/videos/${a}?&fields=download`, {
|
|
82
81
|
responseType: "json",
|
|
83
82
|
headers: {
|
|
84
83
|
"X-Requested-With": "XMLHttpRequest",
|
|
85
|
-
Authorization: `jwt ${
|
|
84
|
+
Authorization: `jwt ${s}`
|
|
86
85
|
}
|
|
87
|
-
}), { download:
|
|
88
|
-
return (
|
|
86
|
+
}), { download: p = [] } = l.data, h = p[0] || null;
|
|
87
|
+
return (h == null ? void 0 : h.link) || "";
|
|
89
88
|
};
|
|
90
|
-
return
|
|
89
|
+
return u.existsSync(r.dirname(t)) || (u.mkdirSync(r.dirname(t), { recursive: !0 }, 777), e.log(`建立 ${r.dirname(t)}`)), new Promise(async (a, s) => {
|
|
91
90
|
try {
|
|
92
|
-
const l = await
|
|
93
|
-
|
|
94
|
-
const
|
|
95
|
-
|
|
91
|
+
const l = await g();
|
|
92
|
+
e.log(`取得 jwt ${l}`);
|
|
93
|
+
const p = await i(o, l);
|
|
94
|
+
e.log(`取得 videoUrl ${p}`), await d(p, t), e.log(`下載完成 ${t}`), a([null, !0]);
|
|
96
95
|
} catch (l) {
|
|
97
|
-
|
|
96
|
+
a([l, null]);
|
|
98
97
|
}
|
|
99
98
|
});
|
|
100
|
-
}, v = ({
|
|
99
|
+
}, v = async ({
|
|
100
|
+
videoId: o,
|
|
101
|
+
dest: t,
|
|
102
|
+
debug: w = !1
|
|
103
|
+
}) => {
|
|
104
|
+
try {
|
|
105
|
+
const e = m(w);
|
|
106
|
+
e.log(`Downloading video: ${o} to: ${t}`);
|
|
107
|
+
const u = `https://www.instagram.com/share/${o}/`, r = await c("fs"), n = await c("path"), g = await c("puppeteer");
|
|
108
|
+
r.existsSync(n.dirname(t)) || (r.mkdirSync(n.dirname(t), { recursive: !0 }, 777), e.log(`建立 ${n.dirname(t)}`));
|
|
109
|
+
const i = await g.launch();
|
|
110
|
+
e.log("啟動 puppeteer");
|
|
111
|
+
const a = await i.newPage();
|
|
112
|
+
await a.setUserAgent(
|
|
113
|
+
"'Mozilla/5.0 (iPhone; CPU iPhone OS 16_6 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/16.6 Mobile/15E148 Safari/604.1'"
|
|
114
|
+
), e.log("開新分頁"), await a.goto(u, {
|
|
115
|
+
// waitUntil: 'networkidle0',
|
|
116
|
+
}), e.log(`前往 ${u}`), await a.waitForSelector("video"), e.log("找到 video 元素");
|
|
117
|
+
const s = await a.$eval("video", (l) => l.getAttribute("src"));
|
|
118
|
+
return e.log(`取得 video url: ${s}`), await i.close(), e.log("關閉 puppeteer"), await d(s, t), e.log(`下載完成 ${s}`), [null, !0];
|
|
119
|
+
} catch (e) {
|
|
120
|
+
return [e, null];
|
|
121
|
+
}
|
|
122
|
+
}, S = ({ type: o }) => {
|
|
101
123
|
switch (o) {
|
|
102
124
|
case "youtube":
|
|
103
125
|
return f;
|
|
104
126
|
case "facebook":
|
|
105
|
-
return y;
|
|
106
|
-
case "vimeo":
|
|
107
127
|
return $;
|
|
128
|
+
case "vimeo":
|
|
129
|
+
return y;
|
|
130
|
+
case "instagram":
|
|
131
|
+
return v;
|
|
108
132
|
default:
|
|
109
133
|
throw new Error(`Invalid video type: ${o}`);
|
|
110
134
|
}
|
|
111
135
|
};
|
|
112
136
|
export {
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
137
|
+
S as useDownloader,
|
|
138
|
+
$ as useFacebook,
|
|
139
|
+
v as useInstagram,
|
|
140
|
+
y as useVimeo,
|
|
116
141
|
f as useYoutube
|
|
117
142
|
};
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pieda/video-dl",
|
|
3
3
|
"private": false,
|
|
4
|
-
"version": "1.
|
|
4
|
+
"version": "1.4.0",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/video-dl.cjs",
|
|
7
7
|
"module": "dist/video-dl.js",
|
|
@@ -31,6 +31,7 @@
|
|
|
31
31
|
"build": "vue-tsc && vite build && tsc --declaration --emitDeclarationOnly",
|
|
32
32
|
"preview": "vite preview",
|
|
33
33
|
"prepare": "npm run build",
|
|
34
|
+
"start": "bun demo.ts",
|
|
34
35
|
"version:major": "npm version major",
|
|
35
36
|
"version:minor": "npm version minor",
|
|
36
37
|
"version:patch": "npm version patch"
|