forked from TrueCarry/JettonGramGpuMiner
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
7 changed files
with
464 additions
and
0 deletions.
There are no files selected for viewing
Binary file not shown.
Binary file not shown.
Binary file not shown.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,225 @@ | ||
"use strict"; | ||
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { | ||
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
}; | ||
var __importDefault = (this && this.__importDefault) || function (mod) { | ||
return (mod && mod.__esModule) ? mod : { "default": mod }; | ||
}; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.delay = exports.CallForSuccess = exports.getClient = exports.intToIP = void 0; | ||
const core_1 = require("@ton/core"); | ||
const crypto_1 = require("@ton/crypto"); | ||
// import { LiteClient, LiteRoundRobinEngine, LiteSingleEngine } from 'ton-lite-client' | ||
const ton_1 = require("@ton/ton"); | ||
const child_process_1 = require("child_process"); | ||
const fs_1 = __importDefault(require("fs")); | ||
const ton_2 = require("@ton/ton"); | ||
const dotenv_1 = __importDefault(require("dotenv")); | ||
dotenv_1.default.config(); | ||
dotenv_1.default.config({ path: 'config.txt' }); | ||
const mySeed = process.env.SEED; | ||
const totalDiff = BigInt('115792089237277217110272752943501742914102634520085823245724998868298727686144'); | ||
const givers = [ | ||
// { address: 'EQDSGvoktoIRTL6fBEK_ysS8YvLoq3cqW2TxB_xHviL33ex2', reward: 1000 }, | ||
// { address: 'EQCvMmHhSYStEtUAEDrpV39T2GWl-0K-iqCxSSZ7I96L4yow', reward: 1000 }, | ||
// { address: 'EQBvumwjKe7xlrjc22p2eLGT4UkdRnrmqmcEYT94J6ZCINmt', reward: 1000 }, | ||
// { address: 'EQDEume45yzDIdSy_Cdz7KIKZk0HyCFIr0yKdbtMyPfFUkbl', reward: 1000 }, | ||
// { address: 'EQAO7jXcX-fJJZl-kphbpdhbIDUqcAiYcAr9RvVlFl38Uatt', reward: 1000 }, | ||
// { address: 'EQAvheS_G-U57CE55UlwF-3M-cc4cljbLireYCmAMe_RHWGF', reward: 1000 }, | ||
// { address: 'EQCba5q9VoYGgiGykVazOUZ49UK-1RljUeZgU6E-bW0bqF2Z', reward: 1000 }, | ||
// { address: 'EQCzT8Pk1Z_aMpNukdV-Mqwc6LNaCNDt-HD6PiaSuEeCD0hV', reward: 1000 }, | ||
// { address: 'EQDglg3hI89dySlr-FR_d1GQCMirkLZH6TPF-NeojP-DbSgY', reward: 1000 }, | ||
// { address: 'EQDIDs45shbXRwhnXoFZg303PkG2CihbVvQXw1k0_yVIqxcA', reward: 1000 }, // 1000 | ||
{ address: 'EQD7VspHSNS4VSpN7QQicNgSYoJ68CmdC6oL5ZEKHSXe26Sa', reward: 10000 }, | ||
{ address: 'EQC5uEgW0MkTbCRBZB72maxCZT3m14OK2FcSLVr2H_7MTTSF', reward: 10000 }, | ||
{ address: 'EQC2nD9nQNRhcfWhdBzRK-wdlTO4hGxnPFzdSxKN777tab2_', reward: 10000 }, | ||
{ address: 'EQAqd4vV0O5oGfA7bl6fVORD_Y4PTNZG82AC2BObBux51g2w', reward: 10000 }, | ||
{ address: 'EQDcOxqaWgEhN_j6Tc4iIQNCj2dBf9AFm0S9QyouwifYo9KD', reward: 10000 }, | ||
{ address: 'EQAjYs4-QKve9gtwC_HrKNR0Eaqhze4sKUmRhRYeensX8iu3', reward: 10000 }, | ||
{ address: 'EQBGhm8bNil8tw4Z2Ekk4sKD-vV-LCz7BW_qIYCEjZpiMF6Q', reward: 10000 }, | ||
{ address: 'EQCtrloCD9BHbVT7q8aXkh-JtL_ZDvtJ5Y-eF2ahg1Ru1EUl', reward: 10000 }, | ||
{ address: 'EQCWMIUBrpwl7OeyEQsOF9-ZMKCQ7fh3_UOvM2N5y77u8uPc', reward: 10000 }, | ||
{ address: 'EQD_71XLqY8nVSf4i5pqGsCjz6EUo2kQEEQq0LUAgg6AHolO', reward: 10000 }, // 10 000 | ||
// { address: 'EQDUIeTNcRUqsz4bugyWl4q4vg16PN2EwiyyAIEbf7_WJZZH', reward: 100000 }, | ||
// { address: 'EQC4qKAIM0Od4RFG-4MAY0dJ3j4Wrcs0jc1XeWKJURYB9KSz', reward: 100000 }, | ||
// { address: 'EQC0Ssi1gl0IQKEGsCp91NeiTThdMqCzYvlX9sVLEU97rWqL', reward: 100000 }, | ||
// { address: 'EQDO2_2zkIJPqBKeE_P1VvDYOJi1vGPgiKo0Aa6Z-bY7BeuG', reward: 100000 }, | ||
// { address: 'EQADEy4zcVl-ADNMISdYSs5cVjJcHmwC9_phXXjqNKgME7j6', reward: 100000 }, | ||
// { address: 'EQDWELx3CYohD9sIjhyEIhP915kL_3XthqruCbmcB0YTWDqQ', reward: 100000 }, | ||
// { address: 'EQDdoh2hzGFHdQtiXJNPNrwA8yIGd4-sFxyuEr3z6JL5BIFi', reward: 100000 }, | ||
// { address: 'EQALXKp6G-IjWTPEqFKILkqcql-43DcoPzJ21Z02abpBPaQK', reward: 100000 }, | ||
// { address: 'EQBAHXFxs1ohHY2bzW9A-V0NDznkFlROkNF_oyppxlLfsyEJ', reward: 100000 }, | ||
// { address: 'EQCUwgBew9u4NwwuFsfPsXX9a69K55uFcieaHtc-c37OYDJO', reward: 100000 }, | ||
]; | ||
let lc = undefined; | ||
let createLiteClient; | ||
let bestGiver = { address: '', coins: 0 }; | ||
function updateBestGivers(liteClient) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const lastInfo = yield CallForSuccess(() => liteClient.getLastBlock()); | ||
let newBestGiber = { address: '', coins: 0 }; | ||
yield Promise.all(givers.map((giver) => __awaiter(this, void 0, void 0, function* () { | ||
const stack = yield CallForSuccess(() => liteClient.runMethod(lastInfo.last.seqno, core_1.Address.parse(giver.address), 'get_pow_params', [])); | ||
// const powStack = Cell.fromBase64(powInfo.result as string) | ||
// const stack = parseTuple(powStack) | ||
const reader = new core_1.TupleReader(stack.result); | ||
const seed = reader.readBigNumber(); | ||
const complexity = reader.readBigNumber(); | ||
const iterations = reader.readBigNumber(); | ||
const hashes = totalDiff / complexity; | ||
const coinsPerHash = giver.reward / Number(hashes); | ||
if (coinsPerHash > newBestGiber.coins) { | ||
newBestGiber = { address: giver.address, coins: coinsPerHash }; | ||
} | ||
}))); | ||
bestGiver = newBestGiber; | ||
}); | ||
} | ||
let go = true; | ||
let i = 0; | ||
function main() { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
const keyPair = yield (0, crypto_1.mnemonicToWalletKey)(mySeed.split(' ')); | ||
const liteClient = yield getClient(); | ||
const wallet = ton_2.WalletContractV4.create({ | ||
workchain: 0, | ||
publicKey: keyPair.publicKey | ||
}); | ||
const opened = liteClient.open(wallet); | ||
yield updateBestGivers(liteClient); | ||
setInterval(() => { | ||
updateBestGivers(liteClient); | ||
}, 1000); | ||
while (go) { | ||
const giverAddress = bestGiver.address; | ||
const lastInfo = yield CallForSuccess(() => liteClient.getLastBlock()); | ||
const powInfo = yield CallForSuccess(() => liteClient.runMethod(lastInfo.last.seqno, core_1.Address.parse(giverAddress), 'get_pow_params', [])); | ||
// const powStack = Cell.fromBase64(powInfo.result as string) | ||
// const stack = parseTuple(powStack) | ||
const reader = new core_1.TupleReader(powInfo.result); | ||
const seed = reader.readBigNumber(); | ||
const complexity = reader.readBigNumber(); | ||
const iterations = reader.readBigNumber(); | ||
const randomName = (yield (0, crypto_1.getSecureRandomBytes)(8)).toString('hex') + '.boc'; | ||
const path = `bocs/${randomName}`; | ||
const command = `.\\pow-miner-opencl.exe -g 0 -F 128 -t 5 ${wallet.address.toString({ urlSafe: true, bounceable: true })} ${seed} ${complexity} ${iterations} ${giverAddress} ${path}`; | ||
try { | ||
const output = (0, child_process_1.execSync)(command, { encoding: 'utf-8', stdio: "pipe" }); // the default is 'buffer' | ||
} | ||
catch (e) { | ||
} | ||
let mined = undefined; | ||
try { | ||
mined = fs_1.default.readFileSync(path); | ||
fs_1.default.rmSync(path); | ||
} | ||
catch (e) { | ||
// | ||
} | ||
if (!mined) { | ||
console.log(`${new Date()}: not mined`, seed, i++); | ||
} | ||
if (mined) { | ||
const lastInfo = yield CallForSuccess(() => liteClient.getLastBlock()); | ||
const powInfo = yield CallForSuccess(() => liteClient.runMethod(lastInfo.last.seqno, core_1.Address.parse(giverAddress), 'get_pow_params', [])); | ||
// const powStack = Cell.fromBase64(powInfo.result as string) | ||
// const stack = parseTuple(powStack) | ||
const reader = new core_1.TupleReader(powInfo.result); | ||
const newSeed = reader.readBigNumber(); | ||
if (newSeed !== seed) { | ||
console.log('Mined already too late seed'); | ||
continue; | ||
} | ||
console.log(`${new Date()}: mined`, seed, i++); | ||
let seqno = 0; | ||
try { | ||
seqno = yield CallForSuccess(() => opened.getSeqno()); | ||
} | ||
catch (e) { | ||
// | ||
} | ||
for (let j = 0; j < 5; j++) { | ||
try { | ||
yield CallForSuccess(() => { | ||
return opened.sendTransfer({ | ||
seqno, | ||
secretKey: keyPair.secretKey, | ||
messages: [(0, core_1.internal)({ | ||
to: giverAddress, | ||
value: (0, core_1.toNano)('0.05'), | ||
bounce: true, | ||
body: core_1.Cell.fromBoc(mined)[0].asSlice().loadRef(), | ||
})], | ||
sendMode: 3, | ||
}); | ||
}); | ||
break; | ||
} | ||
catch (e) { | ||
if (j === 4) { | ||
throw e; | ||
} | ||
// | ||
} | ||
} | ||
} | ||
} | ||
}); | ||
} | ||
main(); | ||
function intToIP(int) { | ||
const part1 = int & 255; | ||
const part2 = (int >> 8) & 255; | ||
const part3 = (int >> 16) & 255; | ||
const part4 = (int >> 24) & 255; | ||
return `${part4}.${part3}.${part2}.${part1}`; | ||
} | ||
exports.intToIP = intToIP; | ||
function getClient(_configUrl) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
if (lc) { | ||
return lc; | ||
} | ||
lc = new ton_1.TonClient4({ endpoint: _configUrl !== null && _configUrl !== void 0 ? _configUrl : 'https://mainnet-v4.tonhubapi.com' }); | ||
return lc; | ||
}); | ||
} | ||
exports.getClient = getClient; | ||
// Function to call ton api untill we get response. | ||
// Because testnet is pretty unstable we need to make sure response is final | ||
// eslint-disable-next-line @typescript-eslint/no-explicit-any | ||
function CallForSuccess(toCall, attempts = 20, delayMs = 100) { | ||
return __awaiter(this, void 0, void 0, function* () { | ||
if (typeof toCall !== 'function') { | ||
throw new Error('unknown input'); | ||
} | ||
let i = 0; | ||
let lastError; | ||
while (i < attempts) { | ||
try { | ||
const res = yield toCall(); | ||
return res; | ||
} | ||
catch (err) { | ||
lastError = err; | ||
i++; | ||
yield delay(delayMs); | ||
} | ||
} | ||
console.log('error after attempts', i); | ||
throw lastError; | ||
}); | ||
} | ||
exports.CallForSuccess = CallForSuccess; | ||
function delay(ms) { | ||
return new Promise((resolve) => { | ||
setTimeout(resolve, ms); | ||
}); | ||
} | ||
exports.delay = delay; |
Oops, something went wrong.