/** @param {import(".").NS } ns */ export async function main(ns) { ns.disableLog('ALL'); let nodeCostThreshold = ns.args.length > 0 ? ns.args[0] : 0.1; let upgradeCostThreshold = ns.args.length > 1 ? ns.args[1] : 0.05; let upgradeCount = ns.args.length > 2 ? ns.args[2] : 1; let levelCap = 150; let ramCap = 64; let coreCap = 4; ns.tprint(`Bot started {nodeCostThreshold: ${nodeCostThreshold}, upgradeCostThreshold: ${upgradeCostThreshold}, upgradeCount: ${upgradeCount}}`); while (true) { let currentMoney = ns.getServerMoneyAvailable("home"); let nodePurchaseCost = ns.hacknet.getPurchaseNodeCost(); let nodeCount = ns.hacknet.numNodes(); if (nodePurchaseCost / Math.abs(currentMoney) < nodeCostThreshold) { ns.hacknet.purchaseNode(); currentMoney = ns.getServerMoneyAvailable("home"); ++nodeCount; } for (let index = 0; index < nodeCount; ++index) { let nodeStats = ns.hacknet.getNodeStats(index); if (nodeStats.level < levelCap && ns.hacknet.getLevelUpgradeCost(index, upgradeCount) / Math.abs(currentMoney) < upgradeCostThreshold) { ns.hacknet.upgradeLevel(index, upgradeCount); currentMoney = ns.getServerMoneyAvailable("home"); } if (nodeStats.ram < ramCap && ns.hacknet.getRamUpgradeCost(index, upgradeCount) / Math.abs(currentMoney) < upgradeCostThreshold) { ns.hacknet.upgradeRam(index, upgradeCount); currentMoney = ns.getServerMoneyAvailable("home"); } if (nodeStats.cores < coreCap && ns.hacknet.getCoreUpgradeCost(index, upgradeCount) / Math.abs(currentMoney) < upgradeCostThreshold) { ns.hacknet.upgradeCore(index, upgradeCount); currentMoney = ns.getServerMoneyAvailable("home"); } } let serverCost = ns.getPurchasedServerCost(16); if (serverCost < currentMoney) { let newServer = ns.purchaseServer('home', 16); if (newServer != '') { ns.tprint(`Bought a server`); ns.scp('grow-helper.js', newServer); let execExitCode = ns.exec('grow-helper.js', newServer, 5, 20); ns.tprint(`Exec 'grow-helper.js' exit code: ${execExitCode}`); } } let logFiles = ['hack-log.js', 'nuke-log.js']; for (let index = 0; index < logFiles.length; index++) { const logFile = logFiles[index]; let portData = ns.readPort(index + 1); if (portData != 'NULL PORT DATA') ns.write(logFile, portData, 'a'); } await ns.sleep(10); } }