2022-03-09 14:06:14 -05:00
|
|
|
import {ArgError, ArgParser} from './scripts/lib/arg-parser';
|
2022-02-10 17:30:11 -05:00
|
|
|
|
|
|
|
/**
|
2022-03-09 14:06:14 -05:00
|
|
|
* Weaken, Grow, Hack loop to "mine" target machine for money.
|
|
|
|
* @params ns {NS} - BitBurner API
|
2022-02-10 17:30:11 -05:00
|
|
|
*/
|
2022-02-04 18:56:22 -05:00
|
|
|
export async function main(ns) {
|
2022-03-09 14:06:14 -05:00
|
|
|
// Setup
|
2022-02-04 18:56:22 -05:00
|
|
|
ns.disableLog('ALL');
|
2022-03-09 14:06:14 -05:00
|
|
|
const historyLength = 15;
|
|
|
|
const messageHistory = Array(historyLength).fill('');
|
|
|
|
let maxBalance, balance, minSecurity, security;
|
|
|
|
const argParser = new ArgParser('miner.js', 'Weaken, Grow, Hack loop to "mine" target machine for money.', null, [
|
|
|
|
{name: 'target', desc: 'Device to mine, defaults to current machine', optional: true, default: ns.getHostname(), type: 'string'}
|
|
|
|
]);
|
|
|
|
let args;
|
|
|
|
try {
|
|
|
|
args = argParser.parse(ns.args);
|
|
|
|
maxBalance = await ns.getServerMaxMoney(args['target']);
|
|
|
|
balance = await ns.getServerMoneyAvailable(args['target']);
|
|
|
|
minSecurity = await ns.getServerMinSecurityLevel(args['target']) + 2;
|
|
|
|
security = await ns.getServerSecurityLevel(args['target']);
|
|
|
|
} catch(err) {
|
|
|
|
if(err instanceof ArgError) return ns.tprint(argParser.help(err.message));
|
|
|
|
throw err;
|
|
|
|
}
|
2022-02-04 18:56:22 -05:00
|
|
|
|
2022-02-10 17:30:11 -05:00
|
|
|
/**
|
|
|
|
* Print header with logs
|
|
|
|
* @param message - message to append to logs
|
|
|
|
*/
|
|
|
|
function log(message) {
|
|
|
|
const sec = `${Math.round(security)}/${minSecurity}`;
|
|
|
|
ns.clearLog();
|
|
|
|
ns.print('===================================================');
|
2022-03-09 14:06:14 -05:00
|
|
|
ns.print(`Mining: ${args['target']}`);
|
2022-02-10 17:30:11 -05:00
|
|
|
ns.print('===================================================');
|
|
|
|
ns.print(`Security: ${sec}${sec.length < 6 ? '\t' : ''}\tBalance: $${Math.round(balance * 100) / 100}`);
|
|
|
|
ns.print('===================================================');
|
|
|
|
if(message != null) messageHistory.push(message);
|
|
|
|
messageHistory.splice(0, messageHistory.length - historyLength);
|
|
|
|
messageHistory.forEach(m => ns.print(m));
|
|
|
|
}
|
2022-02-04 18:56:22 -05:00
|
|
|
|
2022-02-10 17:30:11 -05:00
|
|
|
log();
|
2022-03-09 14:06:14 -05:00
|
|
|
do {
|
2022-02-10 17:30:11 -05:00
|
|
|
// Update information
|
2022-03-09 14:06:14 -05:00
|
|
|
security = await ns.getServerSecurityLevel(args['target']);
|
|
|
|
balance = await ns.getServerMoneyAvailable(args['target']);
|
2022-02-04 18:56:22 -05:00
|
|
|
|
2022-02-10 17:30:11 -05:00
|
|
|
// Pick step
|
2022-02-11 01:08:32 -05:00
|
|
|
if(security > minSecurity) { // Weaken
|
2022-02-10 17:30:11 -05:00
|
|
|
log('Attacking Security...');
|
2022-03-09 14:06:14 -05:00
|
|
|
const w = await ns.weaken(args['target']);
|
2022-02-10 17:30:11 -05:00
|
|
|
log(`Security: -${w}`);
|
2022-03-09 14:06:14 -05:00
|
|
|
} else if(balance < maxBalance) { // Grow
|
2022-02-10 17:30:11 -05:00
|
|
|
log('Spoofing Balance...');
|
2022-03-09 14:06:14 -05:00
|
|
|
const g = await ns.grow(args['target']);
|
2022-02-10 17:30:11 -05:00
|
|
|
log(`Balance: +$${Math.round((g * balance - balance) * 100) / 100}`);
|
2022-02-11 01:08:32 -05:00
|
|
|
} else { // Hack
|
2022-02-10 17:30:11 -05:00
|
|
|
log('Hacking Account...');
|
2022-03-09 14:06:14 -05:00
|
|
|
const h = await ns.hack(args['target']);
|
2022-02-10 17:30:11 -05:00
|
|
|
log(`Balance: -$${h}`);
|
2022-02-04 18:56:22 -05:00
|
|
|
}
|
2022-03-09 14:06:14 -05:00
|
|
|
} while(true);
|
2022-02-04 18:56:22 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
export function autocomplete(data) {
|
|
|
|
return [...data.servers];
|
|
|
|
}
|