UNPKG

discord.js-selfbot-v13-proxy

Version:

A unofficial discord.js-selfbot-v13 fork for creating selfbots with proxy [Based on discord.js v13]

136 lines (121 loc) 5.1 kB
'use strict'; const Buffer = require('node:buffer').Buffer; const https = require('node:https'); const { setTimeout } = require('node:timers'); const FormData = require('form-data'); const fetch = require('node-fetch'); const HttpsProxyAgent = require('https-proxy-agent'); let agent = null; var proxyAgent = null; class APIRequest { constructor(rest, method, path, options) { this.rest = rest; this.client = rest.client; this.method = method; this.route = options.route; this.options = options; this.retries = 0; let queryString = ''; if (options.query) { const query = Object.entries(options.query) .filter(([, value]) => value !== null && typeof value !== 'undefined') .flatMap(([key, value]) => (Array.isArray(value) ? value.map(v => [key, v]) : [[key, value]])); queryString = new URLSearchParams(query).toString(); } this.path = `${path}${queryString && `?${queryString}`}`; } make(captchaKey = undefined, captchaRqtoken = undefined) { // if (agent === null) { if (typeof this.client.options.proxy === 'string' && this.client.options.proxy.length > 0) { proxyAgent = new HttpsProxyAgent(this.client.options.proxy); } else { // agent = new https.Agent({ ...this.client.options.http.agent, keepAlive: true }); } // } const API = this.options.versioned === false ? this.client.options.http.api : `${this.client.options.http.api}/v${this.client.options.http.version}`; const url = API + this.path; let headers = { ...this.client.options.http.headers, Accept: '*/*', origin: 'https://discord.com', 'Accept-Language': 'en-US', 'Sec-Fetch-Dest': 'empty', 'Sec-Fetch-Mode': 'cors', 'Sec-Fetch-Site': 'same-origin', 'X-Debug-Options': 'bugReporterEnabled', 'X-Super-Properties': `${Buffer.from( this.client.options.jsonTransformer(this.client.options.ws.properties), 'ascii', ).toString('base64')}`, 'X-Discord-Locale': 'en-US', 'User-Agent': this.client.options.http.headers['User-Agent'], Referer: 'https://discord.com/channels/@me', Connection: 'keep-alive', 'sec-ch-ua-mobile': '?0', 'sec-ch-ua-platform': 'Windows', 'sec-ch-ua': `"Not?A_Brand";v="8", "Chromium";v="${/Chrome\/(\d+)/.exec(this.client.options.http.headers['User-Agent'])[1] }"`, }; if (this.options.auth !== false) headers.Authorization = this.rest.getAuth(); if (this.options.reason) headers['X-Audit-Log-Reason'] = encodeURIComponent(this.options.reason); if (this.options.headers) headers = Object.assign(headers, this.options.headers); // Delete all headers if undefined for (const [key, value] of Object.entries(headers)) { if (value === undefined) delete headers[key]; } if (this.options.webhook === true) { headers = { 'User-Agent': this.client.options.http.headers['User-Agent'], }; } let body; if (this.options.files?.length) { body = new FormData(); for (const [index, file] of this.options.files.entries()) { if (file?.file) body.append(file.key ?? `files[${index}]`, file.file, file.name); } if (typeof this.options.data !== 'undefined') { if (this.options.dontUsePayloadJSON) { for (const [key, value] of Object.entries(this.options.data)) body.append(key, value); } else { body.append('payload_json', JSON.stringify(this.options.data)); } } else if (typeof this.options.body !== 'undefined') { if (this.options.dontUsePayloadJSON) { for (const [key, value] of Object.entries(this.options.body)) body.append(key, value); } else { body.append('payload_json', JSON.stringify(this.options.body)); } } headers = Object.assign(headers, body.getHeaders()); // eslint-disable-next-line eqeqeq } else if (this.options.data != null) { headers['Content-Type'] = 'application/json'; if (captchaKey && typeof captchaKey == 'string') { if (!this.options.data) this.options.data = {}; // Delete cookie (https://t.me/DMDGOBugsAndFeatures/626) Wtf Unknown Message Error ??? headers.Cookie = undefined; this.options.data.captcha_key = captchaKey; if (captchaRqtoken) this.options.data.captcha_rqtoken = captchaRqtoken; } body = this.options.data ? JSON.stringify(this.options.data) : undefined; } else if (this.options.body != null) { body = new FormData(); body.append('payload_json', JSON.stringify(this.options.body)); headers = Object.assign(headers, body.getHeaders()); } const controller = new AbortController(); const timeout = setTimeout(() => controller.abort(), this.client.options.restRequestTimeout).unref(); return fetch(url, { method: this.method, headers, agent: proxyAgent, body, signal: controller.signal, }).finally(() => clearTimeout(timeout)); } } module.exports = APIRequest;