This commit is contained in:
Dung Nguyen 2022-02-23 22:51:24 +07:00
commit 7d3afe7017
4 changed files with 3742 additions and 0 deletions

1
.gitignore vendored Normal file
View File

@ -0,0 +1 @@
/node_modules

288
index.js Normal file
View File

@ -0,0 +1,288 @@
// Fix telegram
process.env.NTBA_FIX_319 = 1;
const puppeteer = require('puppeteer-extra');
const cron = require('cron');
const RecaptchaPlugin = require('puppeteer-extra-plugin-recaptcha');
const TelegramBot = require("node-telegram-bot-api");
const capchaApi = "74dff1d33afbc505c712408e4bc8c5c2";
const TELEGRAM_TOKEN = '5205509778:AAEOFE72whCgwOmgr8O-PY1C2h6KZrbAwX4';
const TELEGRAM_CHANNEL = `@bot_bao_lenh`;
const TelegramAll = new TelegramBot(TELEGRAM_TOKEN, { polling: true });
global["TeleGlobal"] = TelegramAll;
puppeteer.use(
RecaptchaPlugin({
provider: {
id: '2captcha',
token: capchaApi // REPLACE THIS WITH YOUR OWN 2CAPTCHA API KEY ⚡
},
visualFeedback: true // colorize reCAPTCHAs (violet = detected, green = solved)
})
);
function coverLastResult(resultArg) {
if (typeof resultArg === 'undefined') return '⚪️';
if (typeof resultArg === 'number') {
switch (resultArg) {
case 0:
return '🟢';
case 1:
return '🔴';
default:
return '🏳️';
}
} else {
// In từ lịch sử
if (typeof resultArg !== 'undefined') {
switch (resultArg.lastResult) {
case 0:
return '🟢';
case 1:
return '🔴';
default:
return '🏳️';
}
}
}
}
var lastResult = null; // 0: Xanh 1: Đỏ
var idSession = null; // ID phiên vào lệnh
var lastEnterTheOrder = {
money: 0,
trend: '', // Up | Down
sessionID: 0, // Phiên giao dịch
ind: -1, // Số lần vào lệnh. Sẽ vào lệnh theo CONFIG -> nếu vượt quá số lần vào lệnh sẽ dừng lại.
}
/**
* Tất cả config đây
*/
const CONFIG = {
autoTrade: false,
countTradeContinue: 7, // 7 lệnh thông thì đánh ngược lại
moneyEnterOrder: [5, 10, 20, 40], // Nếu gặp 7 lệnh thông sẽ đánh ngược lại với từng mệnh giá này
maxHistory: 40, // Lưu lại lịch sử 40 phiên
historys: [], // Lưu lại lịch sử
}
function roleEnterOrder(sessionID, lastResult) {
// Xử lý lịch sử
if (CONFIG.historys.length >= CONFIG.maxHistory) {
CONFIG.historys.shift();
}
CONFIG.historys.push({ sessionID, lastResult });
// 1. Số lệnh thông = 7 thì đánh lệnh ngược lại
const listContinue = CONFIG.historys.slice(CONFIG.historys.length - CONFIG.countTradeContinue * 2, CONFIG.historys.length);
let isNotBreakdowUp = true; // Xanh
let isNotBreakdowDown = true; // Đỏ
listContinue.reverse().forEach((e, ind) => {
if (ind) {
if (e.lastResult === 0) {
// Xanh
isNotBreakdowDown = false;
} else {
isNotBreakdowUp = false;
}
}
});
if ((isNotBreakdowUp || isNotBreakdowDown) && CONFIG.historys.length >= CONFIG.countTradeContinue) {
// Thông 7 lệnh liên tiếp
TeleGlobal.sendMessage(TELEGRAM_CHANNEL, `⌁ Thông ${CONFIG.countTradeContinue} lệnh ${coverLastResult(lastResult)} liên tiếp.`, { parse_mode: 'HTML' });
if (CONFIG.autoTrade) {
TeleGlobal.sendMessage(TELEGRAM_CHANNEL, `Hệ thống sẽ tự động vào lệnh cho phiên tiếp theo`, { parse_mode: 'HTML' });
} else {
TeleGlobal.sendMessage(TELEGRAM_CHANNEL, `Hệ thống đang thông ${CONFIG.countTradeContinue} lệnh ${coverLastResult(lastResult)} liên tiếp. Mời bạn vào lệnh phiên sau!`, { parse_mode: 'HTML' });
}
}
}
function drawHistory() {
return `
${coverLastResult(CONFIG.historys[0])} ${coverLastResult(CONFIG.historys[4])} ${coverLastResult(CONFIG.historys[8])} ${coverLastResult(CONFIG.historys[12])} ${coverLastResult(CONFIG.historys[16])} ${coverLastResult(CONFIG.historys[20])} ${coverLastResult(CONFIG.historys[24])} ${coverLastResult(CONFIG.historys[28])} ${coverLastResult(CONFIG.historys[32])} ${coverLastResult(CONFIG.historys[36])}
${coverLastResult(CONFIG.historys[1])} ${coverLastResult(CONFIG.historys[5])} ${coverLastResult(CONFIG.historys[9])} ${coverLastResult(CONFIG.historys[13])} ${coverLastResult(CONFIG.historys[17])} ${coverLastResult(CONFIG.historys[21])} ${coverLastResult(CONFIG.historys[25])} ${coverLastResult(CONFIG.historys[29])} ${coverLastResult(CONFIG.historys[33])} ${coverLastResult(CONFIG.historys[37])}
${coverLastResult(CONFIG.historys[2])} ${coverLastResult(CONFIG.historys[6])} ${coverLastResult(CONFIG.historys[10])} ${coverLastResult(CONFIG.historys[14])} ${coverLastResult(CONFIG.historys[18])} ${coverLastResult(CONFIG.historys[22])} ${coverLastResult(CONFIG.historys[26])} ${coverLastResult(CONFIG.historys[30])} ${coverLastResult(CONFIG.historys[34])} ${coverLastResult(CONFIG.historys[38])}
${coverLastResult(CONFIG.historys[3])} ${coverLastResult(CONFIG.historys[7])} ${coverLastResult(CONFIG.historys[11])} ${coverLastResult(CONFIG.historys[15])} ${coverLastResult(CONFIG.historys[19])} ${coverLastResult(CONFIG.historys[23])} ${coverLastResult(CONFIG.historys[27])} ${coverLastResult(CONFIG.historys[31])} ${coverLastResult(CONFIG.historys[35])} ${coverLastResult(CONFIG.historys[39])}
`;
}
puppeteer.launch({ headless: true, args: ['--no-sandbox'] }).then(async browser => {
const page = await browser.newPage()
await page.setDefaultNavigationTimeout(0);
await page.goto('https://moonata1.net/login')
await page.type('input[name="email"]', 'gavol68807@ishop2k.com', { delay: 100 })
await page.type('input[name="password"]', '123123', { delay: 100 })
await page.click('#main-content > div > div > div > div.boxAuthentication.show > div > div.formWapper.w-100 > form > div.form-group.text-center > button')
await page.solveRecaptchas()
await Promise.all([page.waitForNavigation()]);
const job = new cron.CronJob({
cronTime: '45 0/1 * * * *',
onTick: async function () {
await page.reload({ waitUntil: ["networkidle0"] });
}
});
job.start()
let cdp = await page.target().createCDPSession();
await cdp.send('Network.enable');
await cdp.send('Page.enable');
let id = 1;
count = 0;
let countStaticData = 0;
const printResponse = async function (cdp, response) {
if (!response.response) {
return;
}
let data = response.response.payloadData;
if (data.includes("BO_PRICE")) {
idSession = JSON.parse(data.substr(2, data.length))[1].session;
}
if (data.includes("SOCKET_BO_LAST_RESULT") && data.includes("finalSide")) {
let str = response.response.payloadData;
const dataParse = JSON.parse(str.substr(2, str.length))[1][0];
if (id !== dataParse.id) {
count = 0;
id = dataParse.id;
} else {
count++;
}
if (count == 4) {
let finalSide = dataParse.finalSide
if (finalSide === "UP") {
lastResult = 0;
} else if (finalSide === "DOWN") {
lastResult = 1;
} else if (finalSide === "NORMAL") {
lastResult = 2;
}
// Xử lý các trường hợp
roleEnterOrder(dataParse.session, lastResult);
}
}
if (data === "3") {
countStaticData++;
} else {
countStaticData = 0;
}
if (countStaticData === 2) {
cdp.detach();
cdp = await page.target().createCDPSession();
await cdp.send('Network.enable');
await cdp.send('Page.enable');
cdp.on('Network.webSocketFrameReceived', printResponse.bind(this, cdp));
}
}
cdp.on('Network.webSocketFrameReceived', printResponse.bind(this, cdp));
cdp.on('Network.webSocketCreated', async (response) => {
console.log("Vào webSocketCreated")
console.log(response);
});
function isEnterOrderFn() {
return page.evaluate(() => {
const isDisableBtn = document.querySelector("#betAmount > div:nth-child(4) > div > div:nth-child(3) > button").hasAttribute('disabled');
return !isDisableBtn;
});
}
// Vào lệnh: type - buy/sell
async function enterOrderFn(type, countMoney, myTelegramID) {
const isEnterOrder = await isEnterOrderFn();
if (isEnterOrder) {
const isEnterOrderSuccess = await page.evaluate((countMoneyParam, typeArg) => {
let result = false;
// Nút vào lệnh
const inputOrder = document.querySelector("#betAmount > div.groupButtonMobile.d-flex.mb-2 > div > div > input");
if (inputOrder) {
inputOrder.value = countMoneyParam;
}
if (typeArg === 'buy') {
const btnBuy = document.querySelector("#betAmount > div:nth-child(4) > div > div:nth-child(3) > button");
if (btnBuy) btnBuy.click();
result = true;
}
if (typeArg === 'sell') {
const btnSell = document.querySelector("#betAmount > div:nth-child(4) > div > div:nth-child(1) > button")
if (btnSell) btnSell.click();
result = true;
}
return result;
}, countMoney, type);
if (isEnterOrderSuccess) {
TeleGlobal.sendMessage(myTelegramID, `👌 Đặt lệnh ${type} | ${countMoney}$ | ${idSession} thành công!`, { parse_mode: 'HTML' });
} else {
TeleGlobal.sendMessage(myTelegramID, `⚠️ Có lỗi trong quá trình đặt lệnh!`, { parse_mode: 'HTML' });
}
} else {
TeleGlobal.sendMessage(myTelegramID, `✋ Đang trong phiên chờ kết quả!`, { parse_mode: 'HTML' });
}
}
// Auto vào lệnh
TeleGlobal.on('message', async ({ text, from }) => {
const myTelegramID = from.id;
if (text === '/start') {
TeleGlobal.sendMessage(myTelegramID, `1. /config - lấy cấu hình hiện tại;
2. /enable_auto_trade - Bật auto trade;
3. /disable_auto_trade - Tắt auto trade;
4. /set_count_trade:[number] - Gặp số lượng lệnh thông như này thì đánh ngược lại
5. /set_money_enter:[5,10,20,40] - Vào tiền khi đủ điều kiện
6. /history - Vào tiền khi đủ điều kiện
7. /analytic - Thống theo ngày;`, { parse_mode: 'HTML' });
return;
}
if (text === '/config') {
// Show all configs
TeleGlobal.sendMessage(myTelegramID, JSON.stringify(CONFIG, null, 2), { parse_mode: 'HTML' });
return;
}
if (text === '/enable_auto_trade') {
CONFIG.autoTrade = true;
TeleGlobal.sendMessage(myTelegramID, `Bật auto trade thành công!.
Để vào lệnh 1 phiên bất :
BUY: /buy:[number]
SELL: /sell:[number]`, { parse_mode: 'HTML' });
return;
}
if (text === '/disable_auto_trade') {
CONFIG.autoTrade = false;
TeleGlobal.sendMessage(myTelegramID, `Tắt auto trade thành công!.
Để vào lệnh 1 phiên bất :
BUY: /buy:[number]
SELL: /sell:[number]`, { parse_mode: 'HTML' });
return;
}
if (text === '/history') {
TeleGlobal.sendMessage(myTelegramID, drawHistory(), { parse_mode: 'HTML' });
return;
}
// Nếu đang trong phiên chờ thì không mua bán gì
if (text.startsWith('/buy:')) {
const totalBuy = Number(text.replace('/buy:', ''));
if (!Number.isNaN(totalBuy)) {
await enterOrderFn('buy', totalBuy, myTelegramID);
}
} else if (text.startsWith('/sell:')) {
const totalSell = Number(text.replace('/sell:', ''));
if (!Number.isNaN(totalSell)) {
await enterOrderFn('sell', totalSell, myTelegramID);
}
}
});
});

3435
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

18
package.json Normal file
View File

@ -0,0 +1,18 @@
{
"name": "bottrade",
"version": "1.0.0",
"description": "",
"main": "index.js",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"author": "",
"license": "ISC",
"dependencies": {
"cron": "^1.8.2",
"node-telegram-bot-api": "^0.56.0",
"puppeteer-extra": "^3.2.3",
"puppeteer-extra-plugin-recaptcha": "^3.5.0",
"shelljs": "^0.8.5"
}
}