Kyouka commited on
Commit
dee498a
·
verified ·
1 Parent(s): 5892b3d

Create index.js

Browse files
Files changed (1) hide show
  1. index.js +88 -0
index.js ADDED
@@ -0,0 +1,88 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ const os = require('os')
2
+ const bytes = require('bytes')
3
+ const logger = require('morgan')
4
+ const cheerio = require('cheerio')
5
+ const express = require('express')
6
+ const stealth = require('puppeteer-extra-plugin-stealth')
7
+ const { chromium } = require('playwright-extra')
8
+ chromium.use(stealth())
9
+
10
+ const app = express()
11
+ app.set('json spaces', 4)
12
+ app.use(logger('dev'))
13
+
14
+ app.all('/', (req, res) => {
15
+ const obj = {}
16
+ const used = process.memoryUsage()
17
+ for (let key in used) obj[key] = formatSize(used[key])
18
+
19
+ const totalmem = os.totalmem()
20
+ const freemem = os.freemem()
21
+ obj.memoryUsage = `${formatSize(totalmem - freemem)} / ${formatSize(totalmem)}`
22
+
23
+ res.json({
24
+ creator: '@rippanteq7',
25
+ message: 'Hello World',
26
+ uptime: new Date(process.uptime() * 1000).toUTCString().split(' ')[4],
27
+ status: obj
28
+ })
29
+ })
30
+
31
+ app.get('/api', async (req, res) => {
32
+ try {
33
+ const { url, log } = req.query
34
+ if (!url) return res.json({ success: false, message: 'Input parameter url' })
35
+ if (!/https?:\/\//.test(url)) return res.json({ success: false, message: 'Invalid url' })
36
+
37
+ const data = await xbuddy(url, log)
38
+
39
+ data.message ?
40
+ res.json({ success: false, message: data.message, result: data.response }) :
41
+ res.json({ success: true, result: data.response })
42
+ } catch (e) {
43
+ console.log(e)
44
+ e = String(e)
45
+ res.json({ error: true, message: e === '[object Object]' ? 'Internal Server Error' : e })
46
+ }
47
+ })
48
+
49
+ const PORT = process.env.PORT || 7860
50
+ app.listen(PORT, () => console.log('App running on port', PORT))
51
+
52
+ function formatSize(num) {
53
+ return bytes(+num || 0, { unitSeparator: ' ' })
54
+ }
55
+
56
+ async function xbuddy(url) {
57
+ const browser = await chromium.launch({
58
+ headless: true,
59
+ executablePath: '/usr/bin/chromium',
60
+ args: ['--no-sandbox']
61
+ })
62
+ const page = await browser.newPage()
63
+
64
+ await page.goto(`https://9xbuddy.in/process?url=${url}`)
65
+
66
+ const request = await page.waitForRequest(req => req.url().includes('extract'))
67
+ const response = await page.waitForResponse(res =>
68
+ res.url().includes('extract') && res.request().method() === 'POST')
69
+ const json = await response.json()
70
+
71
+ if (json.status && json.response.type !== 'list') {
72
+ const html = await page.content()
73
+ const $ = cheerio.load(html)
74
+
75
+ const result = $('.text-sm.tracking-wide.px-3.py-3').get().map(el => ({
76
+ type: $(el).find('.w-24').text(),
77
+ q: $(el).find('.truncate').text(),
78
+ size: $(el).find('.w-full div:nth-child(3)').text(),
79
+ url: $(el).find('a').attr('href')
80
+ })).filter(c => /^http/.test(c.url))
81
+
82
+ json.response.formats = result
83
+ json.response.headers = request.headers()
84
+ }
85
+
86
+ await browser.close()
87
+ return json
88
+ }