Compare commits

..

2 Commits

Author SHA1 Message Date
22ddbbde5d Reformat files 2023-11-03 18:42:37 -03:00
683daff911 Add project coding guidelines 2023-11-03 18:41:51 -03:00
10 changed files with 519 additions and 308 deletions

10
.editorconfig Normal file
View File

@ -0,0 +1,10 @@
# All files
[*]
end_of_line = lf
insert_final_newline = true
indent_style = tab
indent_size = 2
# Markup files
[*.{json,yml}]
indent_style = space

215
.gitattributes vendored Normal file
View File

@ -0,0 +1,215 @@
## GITATTRIBUTES FOR WEB PROJECTS
#
# These settings are for any web project.
#
# Details per file setting:
# text These files should be normalized (i.e. convert CRLF to LF).
# binary These files are binary and should be left untouched.
#
# Note that binary is a macro for -text -diff.
######################################################################
# Auto detect
## Handle line endings automatically for files detected as
## text and leave all files detected as binary untouched.
## This will handle all files NOT defined below.
* text=auto
# Source code
*.bash text eol=lf
*.bat text eol=crlf
*.cmd text eol=crlf
*.coffee text
*.css text diff=css
*.htm text diff=html
*.html text diff=html
*.inc text
*.ini text
*.js text
*.json text
*.jsx text
*.less text
*.ls text
*.map text -diff
*.od text
*.onlydata text
*.php text diff=php
*.pl text
*.ps1 text eol=crlf
*.py text diff=python
*.rb text diff=ruby
*.sass text
*.scm text
*.scss text diff=css
*.sh text eol=lf
.husky/* text eol=lf
*.sql text
*.styl text
*.tag text
*.ts text
*.tsx text
*.xml text
*.xhtml text diff=html
# Docker
Dockerfile text
# Documentation
*.ipynb text eol=lf
*.markdown text diff=markdown
*.md text diff=markdown
*.mdwn text diff=markdown
*.mdown text diff=markdown
*.mkd text diff=markdown
*.mkdn text diff=markdown
*.mdtxt text
*.mdtext text
*.txt text
AUTHORS text
CHANGELOG text
CHANGES text
CONTRIBUTING text
COPYING text
copyright text
*COPYRIGHT* text
INSTALL text
license text
LICENSE text
NEWS text
readme text
*README* text
TODO text
# Templates
*.dot text
*.ejs text
*.erb text
*.haml text
*.handlebars text
*.hbs text
*.hbt text
*.jade text
*.latte text
*.mustache text
*.njk text
*.phtml text
*.svelte text
*.tmpl text
*.tpl text
*.twig text
*.vue text
# Configs
*.cnf text
*.conf text
*.config text
.editorconfig text
.env text
.gitattributes text
.gitconfig text
.htaccess text
*.lock text -diff
package.json text eol=lf
package-lock.json text eol=lf -diff
pnpm-lock.yaml text eol=lf -diff
.prettierrc text
yarn.lock text -diff
*.toml text
*.yaml text
*.yml text
browserslist text
Makefile text
makefile text
# Fixes syntax highlighting on GitHub to allow comments
tsconfig.json linguist-language=JSON-with-Comments
# Heroku
Procfile text
# Graphics
*.ai binary
*.bmp binary
*.eps binary
*.gif binary
*.gifv binary
*.ico binary
*.jng binary
*.jp2 binary
*.jpg binary
*.jpeg binary
*.jpx binary
*.jxr binary
*.pdf binary
*.png binary
*.psb binary
*.psd binary
# SVG treated as an asset (binary) by default.
*.svg text
# If you want to treat it as binary,
# use the following line instead.
# *.svg binary
*.svgz binary
*.tif binary
*.tiff binary
*.wbmp binary
*.webp binary
# Audio
*.kar binary
*.m4a binary
*.mid binary
*.midi binary
*.mp3 binary
*.ogg binary
*.ra binary
# Video
*.3gpp binary
*.3gp binary
*.as binary
*.asf binary
*.asx binary
*.avi binary
*.fla binary
*.flv binary
*.m4v binary
*.mng binary
*.mov binary
*.mp4 binary
*.mpeg binary
*.mpg binary
*.ogv binary
*.swc binary
*.swf binary
*.webm binary
# Archives
*.7z binary
*.gz binary
*.jar binary
*.rar binary
*.tar binary
*.zip binary
# Fonts
*.ttf binary
*.eot binary
*.otf binary
*.woff binary
*.woff2 binary
# Executables
*.exe binary
*.pyc binary
# Prevents massive diffs caused by vendored, minified files
**/.yarn/releases/** binary
**/.yarn/plugins/** binary
# RC files (like .babelrc or .eslintrc)
*.*rc text
# Ignore files (like .npmignore or .gitignore)
*.*ignore text
# Prevents massive diffs from built files
dist/* binary

5
.idea/codeStyles/codeStyleConfig.xml generated Normal file
View File

@ -0,0 +1,5 @@
<component name="ProjectCodeStyleConfiguration">
<state>
<option name="PREFERRED_PROJECT_CODE_STYLE" value="Default" />
</state>
</component>

View File

@ -1,4 +1,4 @@
export async function main(ns: NS) { export async function main(ns: NS) {
ns.run("watcher.js") ns.run('watcher.js')
ns.run("hacknet.js") ns.run('hacknet.js')
} }

View File

@ -1,23 +1,10 @@
export async function main(ns: NS) { export async function main(ns: NS) {
const server: string = <string>ns.args[0]; const server: string = <string> ns.args[0]
while (true) { while (true) {
/* This code checks conditions that are not needed with smart scheduling // Guide https://darktechnomancer.github.io/#glossary-of-terms
const moneyThresh: number = <number>ns.args[1]; await ns.weaken(server)
const securityThresh: number = <number>ns.args[2]; await ns.grow(server)
if (ns.getServerSecurityLevel(server) > securityThresh) { await ns.weaken(server)
await ns.weaken(server); await ns.hack(server)
} else if (ns.getServerMoneyAvailable(server) < moneyThresh) {
await ns.grow(server);
} else {
await ns.hack(server);
}
*/
// Guide
// https://darktechnomancer.github.io/#glossary-of-terms
await ns.weaken(server);
await ns.grow(server);
await ns.weaken(server);
await ns.hack(server);
} }
} }

View File

@ -1,15 +1,11 @@
import {recursiveScan} from "./utils"; import { executeScriptOnServerFromAnother, recursiveScan } from './utils'
import {executeScriptOnServerFromAnother} from "./utils";
export async function main(ns: NS) { export async function main(ns: NS) {
let servers: string[] = recursiveScan(ns); let servers: string[] = recursiveScan(ns)
for (const server of servers) { for (const server of servers) {
// Commented out code is not needed with smart scheduling let numThreads = ns.getServerMaxRam(server) / ns.getScriptRam('hack.js')
//let moneyThresh = ns.getServerMaxMoney(server) * 0.75; numThreads = Math.floor(numThreads)
//let securityThresh = ns.getServerMinSecurityLevel(server) + 5; executeScriptOnServerFromAnother(ns, server, 'hack.js', numThreads, [server])
let numThreads = ns.getServerMaxRam(server) / ns.getScriptRam("hack.js")
numThreads = Math.floor(numThreads);
//executeScriptOnServerFromAnother(ns, server, "hack.js", numThreads, [server, moneyThresh, securityThresh])
executeScriptOnServerFromAnother(ns, server, "hack.js", numThreads, [server])
} }
} }

View File

@ -14,17 +14,14 @@
*/ */
enum Type { enum Type {
newNode = "node", newNode = 'node', level = 'level', ram = 'ram', core = 'code',
level = "level",
ram = "ram",
core = "code"
} }
export async function main(ns: NS) { export async function main(ns: NS) {
let timeout: number = <number>ns.args[0] let timeout: number = <number> ns.args[0]
let nodes = ns.hacknet.numNodes() let nodes = ns.hacknet.numNodes()
let costs: {type: Type, cost: number}[] = [] let costs: { type: Type, cost: number }[] = []
while (true) { while (true) {
costs = [] costs = []
// Go through each node and get the cheapest upgrade // Go through each node and get the cheapest upgrade
@ -56,12 +53,12 @@ export async function main(ns: NS) {
* @note This function will wait forever by default * @note This function will wait forever by default
*/ */
async function waitUntilMoney(ns: NS, money: number, timeout: number = -1) { async function waitUntilMoney(ns: NS, money: number, timeout: number = -1) {
while (ns.getServerMoneyAvailable("home") < money) { while (ns.getServerMoneyAvailable('home') < money) {
await ns.sleep(1000) await ns.sleep(1000)
if (timeout == 0) { if (timeout == 0) {
throw new Error("Timed out waiting for money") throw new Error('Timed out waiting for money')
} else if (timeout > -1) { } else if (timeout > -1) {
timeout--; timeout--
} }
} }
} }
@ -92,12 +89,12 @@ function getCheapestCost(ns: NS, node: number) {
let cheapest = Math.min(nodeCost, levelCost, ramCost, coreCost) let cheapest = Math.min(nodeCost, levelCost, ramCost, coreCost)
switch (cheapest) { switch (cheapest) {
case nodeCost: case nodeCost:
return {type: Type.newNode, cost: nodeCost} return { type: Type.newNode, cost: nodeCost }
case levelCost: case levelCost:
return {type: Type.level, cost: levelCost} return { type: Type.level, cost: levelCost }
case ramCost: case ramCost:
return {type: Type.ram, cost: ramCost} return { type: Type.ram, cost: ramCost }
case coreCost: case coreCost:
return {type: Type.core, cost: coreCost} return { type: Type.core, cost: coreCost }
} }
} }

View File

@ -1,4 +1,5 @@
import {recursiveScan} from "./utils"; import { recursiveScan } from './utils'
export async function main(ns: NS) { export async function main(ns: NS) {
let servers: string[] = recursiveScan(ns) let servers: string[] = recursiveScan(ns)
for (const server of servers) { for (const server of servers) {

View File

@ -1,4 +1,5 @@
// noinspection JSUnusedGlobalSymbols // noinspection JSUnusedGlobalSymbols
/** /**
* Recursively scans all servers connected to the current server, excluding home * Recursively scans all servers connected to the current server, excluding home
* @param ns global NS object * @param ns global NS object
@ -6,25 +7,25 @@
*/ */
export function recursiveScan(ns: NS) { export function recursiveScan(ns: NS) {
// Starting case // Starting case
let servers = ns.scan("home"); let servers = ns.scan('home')
// Add all servers to the list // Add all servers to the list
let allServers: string[] = []; let allServers: string[] = []
while (servers.length > 0) { while (servers.length > 0) {
let server = servers.shift(); let server = servers.shift()
if(server) { if (server) {
let newServers = ns.scan(server); let newServers = ns.scan(server)
for (let newServer of newServers) { for (let newServer of newServers) {
if (!allServers.includes(newServer)) { if (!allServers.includes(newServer)) {
allServers.push(newServer); allServers.push(newServer)
servers.push(newServer); servers.push(newServer)
} }
} }
} }
} }
// Remove the current server // Remove the current server
allServers.splice(allServers.indexOf("home"), 1); allServers.splice(allServers.indexOf('home'), 1)
// Print all servers // Print all servers
return allServers; return allServers
} }
/** /**
@ -38,8 +39,8 @@ export function recursiveScan(ns: NS) {
* you will need to modify each file path to match the server you are removing it from. * you will need to modify each file path to match the server you are removing it from.
*/ */
export function removeFilesOnAllServers(ns: NS, files: string[]) { export function removeFilesOnAllServers(ns: NS, files: string[]) {
let hosts = recursiveScan(ns); let hosts = recursiveScan(ns)
for(const host of hosts) { for (const host of hosts) {
for (const file of files) { for (const file of files) {
ns.rm(file, host) ns.rm(file, host)
} }
@ -53,29 +54,29 @@ export function removeFilesOnAllServers(ns: NS, files: string[]) {
* @returns The number of programs used to gain root access * @returns The number of programs used to gain root access
*/ */
export function rootServer(ns: NS, server: string) { export function rootServer(ns: NS, server: string) {
let counter = 0; let counter = 0
if (ns.fileExists("BruteSSH.exe", "home")) { if (ns.fileExists('BruteSSH.exe', 'home')) {
ns.brutessh(server); ns.brutessh(server)
counter++; counter++
} }
if (ns.fileExists("FTPCrack.exe", "home")) { if (ns.fileExists('FTPCrack.exe', 'home')) {
ns.ftpcrack(server); ns.ftpcrack(server)
counter++; counter++
} }
if (ns.fileExists("SMTPCrack.exe", "home")) { if (ns.fileExists('SMTPCrack.exe', 'home')) {
ns.relaysmtp(server); ns.relaysmtp(server)
counter++; counter++
} }
if (ns.fileExists("HTTPWorm.exe", "home")) { if (ns.fileExists('HTTPWorm.exe', 'home')) {
ns.httpworm(server); ns.httpworm(server)
counter++; counter++
} }
if (ns.fileExists("SQLInject.exe", "home")) { if (ns.fileExists('SQLInject.exe', 'home')) {
ns.sqlinject(server); ns.sqlinject(server)
counter++; counter++
} }
ns.nuke(server) ns.nuke(server)
return counter; return counter
} }
/** /**
@ -88,22 +89,22 @@ export function rootServer(ns: NS, server: string) {
*/ */
export function performFunctionIfCapable(ns: NS, server: string, func: CallableFunction, args: any[]) { export function performFunctionIfCapable(ns: NS, server: string, func: CallableFunction, args: any[]) {
if (ns.getHackingLevel() < ns.getServerRequiredHackingLevel(server)) { if (ns.getHackingLevel() < ns.getServerRequiredHackingLevel(server)) {
return false; return false
} }
if (ns.getServerNumPortsRequired(server) < ns.getServer(server).openPortCount) { if (ns.getServerNumPortsRequired(server) < ns.getServer(server).openPortCount) {
if (rootServer(ns, server) < ns.getServerNumPortsRequired(server)) { if (rootServer(ns, server) < ns.getServerNumPortsRequired(server)) {
return false; return false
} }
} }
if (!ns.hasRootAccess(server)) { if (!ns.hasRootAccess(server)) {
return false; return false
} }
let result = func(...args); let result = func(...args)
if (result === undefined) { if (result === undefined) {
return true; return true
} else { } else {
return result; return result
} }
} }
@ -116,13 +117,11 @@ export function performFunctionIfCapable(ns: NS, server: string, func: CallableF
* @param args The arguments to pass to the script * @param args The arguments to pass to the script
*/ */
export function executeScriptOnServerFromAnother(ns: NS, server: string, script: string, threads: number = 1, args: any[]) { export function executeScriptOnServerFromAnother(ns: NS, server: string, script: string, threads: number = 1, args: any[]) {
ns.scp(script, server); ns.scp(script, server)
performFunctionIfCapable(ns, server, ns.exec, [script, server, threads, ...args]) performFunctionIfCapable(ns, server, ns.exec, [script, server, threads, ...args])
ns.atExit( ns.atExit(() => {
() => { ns.rm(script, server)
ns.rm(script, server); })
}
)
} }
/** /**
@ -131,11 +130,11 @@ export function executeScriptOnServerFromAnother(ns: NS, server: string, script:
* @param time=5 The number of seconds to calculate the MPS over * @param time=5 The number of seconds to calculate the MPS over
*/ */
export async function calculateMPS(ns: NS, time: number = 5) { export async function calculateMPS(ns: NS, time: number = 5) {
let start = ns.getServerMoneyAvailable("home"); let start = ns.getServerMoneyAvailable('home')
let data: number[] = []; let data: number[] = []
for (let i = 0; i < time; i++) { for (let i = 0; i < time; i++) {
await ns.sleep(1000); await ns.sleep(1000)
data.push(ns.getServerMoneyAvailable("home") - start); data.push(ns.getServerMoneyAvailable('home') - start)
} }
return data.reduce((a, b) => a + b, 0) / time; return data.reduce((a, b) => a + b, 0) / time
} }

View File

@ -1,13 +1,14 @@
export async function main(ns: NS) { export async function main(ns: NS) {
let hackingLevel = ns.getHackingLevel(); ns.run('hackallservers.js')
let hackingLevel = ns.getHackingLevel()
while (hackingLevel < 9999) { while (hackingLevel < 9999) {
let oldHackingLevel = hackingLevel; let oldHackingLevel = hackingLevel
hackingLevel = ns.getHackingLevel(); hackingLevel = ns.getHackingLevel()
if(oldHackingLevel !== hackingLevel) { if (oldHackingLevel !== hackingLevel) {
ns.tprint(`Hacking level increased from ${oldHackingLevel} to ${hackingLevel}`); ns.tprint(`Hacking level increased from ${oldHackingLevel} to ${hackingLevel}`)
ns.run("killall.js"); ns.run('killall.js')
await ns.sleep(1000) // 1 second await ns.sleep(1000) // 1 second
ns.run("hackallservers.js"); ns.run('hackallservers.js')
} }
// Wait 1 second before checking again // Wait 1 second before checking again
await ns.sleep(1000) await ns.sleep(1000)