Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
MR414N-ID
GitHub Repository: MR414N-ID/botku2
Path: blob/master/node_modules/@bochilteam/scraper/lib/cjs/texts/textpro.js
1126 views
1
"use strict";
2
var __importDefault = (this && this.__importDefault) || function (mod) {
3
return (mod && mod.__esModule) ? mod : { "default": mod };
4
};
5
Object.defineProperty(exports, "__esModule", { value: true });
6
exports.textproList = void 0;
7
const got_1 = __importDefault(require("got"));
8
const cheerio_1 = require("cheerio");
9
const form_data_1 = __importDefault(require("form-data"));
10
const utils_js_1 = require("../utils.js");
11
const BASE_URL = 'https://textpro.me';
12
exports.textproList = (async () => (0, got_1.default)('https://raw.githubusercontent.com/BochilTeam/scraper/master/data/textpro.json').json())();
13
async function textpro(effect, params) {
14
var _a;
15
const list = await exports.textproList;
16
const textpro = list.find(({ title }) => title.toLowerCase() === effect.toLowerCase());
17
if (!textpro)
18
throw new Error(`TextPro "${effect}" not found`);
19
if (!Array.isArray(params))
20
params = [params];
21
const { link, parameters } = textpro;
22
if (parameters.length > params.length)
23
throw new Error(`TextPro "${effect}" requires ${parameters.length} parameters, but ${params.length} given`);
24
const resToken = await (0, got_1.default)(`${BASE_URL}${link}`);
25
const cookie = (_a = resToken.headers['set-cookie']) === null || _a === void 0 ? void 0 : _a.map(c => c.split(';')[0]).join('; ').trim();
26
const HEADERS = {
27
cookie: cookie || '__gads=ID=63da40a14f3eb127-22dccf741fd10073:T=1648080134:RT=1648080134:S=ALNI_MZfEIreNTkduqqV5CgZnuei_X1xLQ; _ga=GA1.2.342524260.1648080135; _gid=GA1.2.2036288127.1648080139; PHPSESSID=7fmr2ig9k8r7n9g9uk7fcj2ru1; _gat_gtag_UA_114571019_5=1',
28
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/99.0.4844.82 Safari/537.36'
29
};
30
const $ = (0, cheerio_1.load)(resToken.body);
31
const token = $('#token').val();
32
const build_server = $('#build_server').val();
33
const build_server_id = $('#build_server_id').val();
34
const form = new form_data_1.default();
35
for (const param of params)
36
form.append('text[]', param);
37
form.append('submit', 'Go');
38
form.append('token', token);
39
form.append('build_server', build_server);
40
form.append('build_server_id', build_server_id);
41
const html = await (0, got_1.default)(`${BASE_URL}${link}`, {
42
method: 'POST',
43
headers: {
44
...HEADERS,
45
...form.getHeaders()
46
},
47
body: form.getBuffer()
48
}).text();
49
const $$ = (0, cheerio_1.load)(html);
50
const form2 = $$('#form_value').eq(0).text();
51
if (!form2)
52
throw new utils_js_1.ScraperError(`TextPro "${effect}" failed`, html);
53
const json = await got_1.default.post(`${BASE_URL}/effect/create-image`, {
54
headers: HEADERS,
55
form: JSON.parse(form2)
56
}).json();
57
return `${BASE_URL}${json.image || json.fullsize_image}`;
58
}
59
exports.default = textpro;
60
//# sourceMappingURL=textpro.js.map
61