koishi-plugin-meinv 1.0.2 → 1.0.4
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.
- package/package.json +1 -1
- package/src/index.js +75 -12
package/package.json
CHANGED
package/src/index.js
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
const { Context } = require('koishi')
|
|
2
2
|
const axios = require('axios')
|
|
3
|
+
const fs = require('fs').promises
|
|
4
|
+
const path = require('path')
|
|
5
|
+
|
|
6
|
+
// 创建临时目录
|
|
7
|
+
const TEMP_DIR = path.resolve(__dirname, '../temp')
|
|
8
|
+
fs.mkdir(TEMP_DIR, { recursive: true }).catch(() => {})
|
|
3
9
|
|
|
4
10
|
exports.name = 'meinv'
|
|
5
11
|
exports.using = ['logger']
|
|
@@ -8,23 +14,80 @@ exports.apply = (ctx) => {
|
|
|
8
14
|
ctx.command('meinv', '随机获取小姐姐视频')
|
|
9
15
|
.alias('小姐姐')
|
|
10
16
|
.action(async ({ session }) => {
|
|
17
|
+
// 第一步:先回复用户提示
|
|
18
|
+
await session.send('请稍等 视频就在来的路上了......\nby.pldduck')
|
|
19
|
+
|
|
11
20
|
try {
|
|
21
|
+
// 第二步:请求 API
|
|
12
22
|
const res = await axios.get('https://www.tmini.net/api/meinv?mp4=json', {
|
|
13
|
-
timeout:
|
|
14
|
-
headers: {
|
|
23
|
+
timeout: 15000,
|
|
24
|
+
headers: {
|
|
25
|
+
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0 Safari/537.36',
|
|
26
|
+
'Referer': 'https://www.tmini.net/'
|
|
27
|
+
}
|
|
15
28
|
})
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
29
|
+
|
|
30
|
+
// 第三步:解析视频链接
|
|
31
|
+
let videoUrl = ''
|
|
32
|
+
if (res.data?.data?.link) {
|
|
33
|
+
videoUrl = res.data.data.link
|
|
34
|
+
} else if (res.data?.url) {
|
|
35
|
+
videoUrl = res.data.url
|
|
23
36
|
}
|
|
24
|
-
|
|
37
|
+
|
|
38
|
+
if (!videoUrl) {
|
|
39
|
+
return '❌ 未获取到有效视频链接。'
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// 第四步:生成临时文件路径
|
|
43
|
+
const filename = `meinv_${Date.now()}.mp4`
|
|
44
|
+
const filePath = path.join(TEMP_DIR, filename)
|
|
45
|
+
|
|
46
|
+
// 第五步:下载视频到本地
|
|
47
|
+
ctx.logger('meinv').info(`开始下载视频: ${videoUrl}`)
|
|
48
|
+
const response = await axios({
|
|
49
|
+
method: 'GET',
|
|
50
|
+
url: videoUrl,
|
|
51
|
+
responseType: 'stream',
|
|
52
|
+
timeout: 30000
|
|
53
|
+
})
|
|
54
|
+
|
|
55
|
+
const writer = fs.createWriteStream(filePath)
|
|
56
|
+
response.data.pipe(writer)
|
|
57
|
+
|
|
58
|
+
// 等待下载完成
|
|
59
|
+
await new Promise((resolve, reject) => {
|
|
60
|
+
writer.on('finish', resolve)
|
|
61
|
+
writer.on('error', reject)
|
|
62
|
+
})
|
|
63
|
+
|
|
64
|
+
ctx.logger('meinv').info(`视频下载完成: ${filePath}`)
|
|
65
|
+
|
|
66
|
+
// 第六步:发送本地文件
|
|
67
|
+
await session.send({
|
|
68
|
+
type: 'file',
|
|
69
|
+
path: filePath
|
|
70
|
+
})
|
|
71
|
+
|
|
72
|
+
// 第七步:成功后删除临时文件
|
|
73
|
+
await fs.unlink(filePath).catch(e => {
|
|
74
|
+
ctx.logger('meinv').warn(`临时文件删除失败: ${e.message}`)
|
|
75
|
+
})
|
|
76
|
+
|
|
77
|
+
return '✅ 视频已送达!'
|
|
78
|
+
|
|
25
79
|
} catch (e) {
|
|
26
|
-
ctx.logger('meinv').error(e)
|
|
27
|
-
|
|
80
|
+
ctx.logger('meinv').error('插件执行出错:', e)
|
|
81
|
+
|
|
82
|
+
// 尝试清理可能残留的文件
|
|
83
|
+
const tempFiles = await fs.readdir(TEMP_DIR).catch(() => [])
|
|
84
|
+
for (const file of tempFiles) {
|
|
85
|
+
if (file.startsWith('meinv_') && Date.now() - parseInt(file.split('_')[1]) > 300000) {
|
|
86
|
+
await fs.unlink(path.join(TEMP_DIR, file)).catch(() => {})
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
return '⚠️ 抱歉,视频加载失败,请稍后再试。'
|
|
28
91
|
}
|
|
29
92
|
})
|
|
30
93
|
}
|