2021-09-05 01:09:30 +02:00
import { vsprintf , sprintf } from "sprintf-js" ;
import * as libarg from "arg" ;
2017-10-12 22:10:34 +02:00
2019-05-05 06:03:40 +02:00
import { getRamCost } from "./Netscript/RamCostGenerator" ;
2019-06-22 10:12:17 +02:00
import { WorkerScriptStartStopEventEmitter } from "./Netscript/WorkerScriptStartStopEventEmitter" ;
2019-05-05 06:03:40 +02:00
2019-04-11 10:37:40 +02:00
import { Augmentations } from "./Augmentation/Augmentations" ;
2021-09-09 05:47:34 +02:00
import { augmentationExists , installAugmentations } from "./Augmentation/AugmentationHelpers" ;
2021-03-07 10:49:57 +01:00
import { prestigeAugmentation } from "./Prestige" ;
2019-04-11 10:37:40 +02:00
import { AugmentationNames } from "./Augmentation/data/AugmentationNames" ;
import { BitNodeMultipliers } from "./BitNode/BitNodeMultipliers" ;
import { findCrime } from "./Crime/CrimeHelpers" ;
2021-08-17 00:43:55 +02:00
import { Bladeburner } from "./Bladeburner/Bladeburner" ;
2019-04-11 10:37:40 +02:00
import { Company } from "./Company/Company" ;
2021-05-01 09:17:31 +02:00
import { Companies } from "./Company/Companies" ;
2019-04-11 10:37:40 +02:00
import { CompanyPosition } from "./Company/CompanyPosition" ;
import { CompanyPositions } from "./Company/CompanyPositions" ;
import { CONSTANTS } from "./Constants" ;
import { DarkWebItems } from "./DarkWeb/DarkWebItems" ;
2021-09-02 04:16:48 +02:00
import {
2021-09-05 01:09:30 +02:00
NewIndustry ,
NewCity ,
UnlockUpgrade ,
LevelUpgrade ,
IssueDividends ,
SellMaterial ,
SellProduct ,
SetSmartSupply ,
BuyMaterial ,
2021-09-10 06:13:28 +02:00
AssignJob ,
UpgradeOfficeSize ,
ThrowParty ,
2021-09-10 06:53:39 +02:00
PurchaseWarehouse ,
UpgradeWarehouse ,
BuyCoffee ,
HireAdVert ,
MakeProduct ,
2021-09-10 08:17:55 +02:00
Research ,
ExportMaterial ,
CancelExportMaterial ,
SetMaterialMarketTA1 ,
SetMaterialMarketTA2 ,
SetProductMarketTA1 ,
SetProductMarketTA2 ,
2021-09-05 01:09:30 +02:00
} from "./Corporation/Actions" ;
2021-09-02 04:16:48 +02:00
import { CorporationUnlockUpgrades } from "./Corporation/data/CorporationUnlockUpgrades" ;
import { CorporationUpgrades } from "./Corporation/data/CorporationUpgrades" ;
2019-04-11 10:37:40 +02:00
import {
2021-09-05 01:09:30 +02:00
calculateHackingChance ,
calculateHackingExpGain ,
calculatePercentMoneyHacked ,
calculateHackingTime ,
calculateGrowTime ,
calculateWeakenTime ,
2019-04-11 10:37:40 +02:00
} from "./Hacking" ;
2021-03-31 06:45:21 +02:00
import { calculateServerGrowth } from "./Server/formulas/grow" ;
2021-06-17 00:38:29 +02:00
import { Gang } from "./Gang/Gang" ;
2021-06-16 06:28:20 +02:00
import { AllGangs } from "./Gang/AllGangs" ;
2021-06-14 21:42:38 +02:00
import { GangMemberTasks } from "./Gang/GangMemberTasks" ;
import { GangMemberUpgrades } from "./Gang/GangMemberUpgrades" ;
2019-04-11 10:37:40 +02:00
import { Factions , factionExists } from "./Faction/Factions" ;
import { joinFaction , purchaseAugmentation } from "./Faction/FactionHelpers" ;
import { FactionWorkType } from "./Faction/FactionWorkTypeEnum" ;
2021-09-09 05:47:34 +02:00
import { netscriptCanGrow , netscriptCanHack , netscriptCanWeaken } from "./Hacking/netscriptCanHack" ;
2019-03-30 04:01:34 +01:00
2019-04-11 10:37:40 +02:00
import {
2021-09-05 01:09:30 +02:00
getCostOfNextHacknetNode ,
getCostOfNextHacknetServer ,
hasHacknetServers ,
purchaseHacknet ,
purchaseLevelUpgrade ,
purchaseRamUpgrade ,
purchaseCoreUpgrade ,
purchaseCacheUpgrade ,
purchaseHashUpgrade ,
updateHashManagerCapacity ,
2019-04-11 10:37:40 +02:00
} from "./Hacknet/HacknetHelpers" ;
2021-03-31 06:45:21 +02:00
import {
2021-09-05 01:09:30 +02:00
calculateMoneyGainRate ,
calculateLevelUpgradeCost ,
calculateRamUpgradeCost ,
calculateCoreUpgradeCost ,
calculateNodeCost ,
2021-03-31 06:45:21 +02:00
} from "./Hacknet/formulas/HacknetNodes" ;
import {
2021-09-05 01:09:30 +02:00
calculateHashGainRate as HScalculateHashGainRate ,
calculateLevelUpgradeCost as HScalculateLevelUpgradeCost ,
calculateRamUpgradeCost as HScalculateRamUpgradeCost ,
calculateCoreUpgradeCost as HScalculateCoreUpgradeCost ,
calculateCacheUpgradeCost as HScalculateCacheUpgradeCost ,
calculateServerCost as HScalculateServerCost ,
2021-03-31 06:45:21 +02:00
} from "./Hacknet/formulas/HacknetServers" ;
2021-09-09 05:47:34 +02:00
import { HacknetNodeConstants , HacknetServerConstants } from "./Hacknet/data/Constants" ;
2021-05-01 09:17:31 +02:00
import { HacknetServer } from "./Hacknet/HacknetServer" ;
2019-04-11 10:37:40 +02:00
import { CityName } from "./Locations/data/CityNames" ;
import { LocationName } from "./Locations/data/LocationNames" ;
2021-03-23 21:02:34 +01:00
import { Terminal } from "./Terminal" ;
2021-09-05 01:09:30 +02:00
import { calculateSkill , calculateExp } from "./PersonObjects/formulas/skill" ;
2019-04-04 02:12:11 +02:00
2019-04-11 10:37:40 +02:00
import { Message } from "./Message/Message" ;
import { inMission } from "./Missions" ;
import { Player } from "./Player" ;
import { Programs } from "./Programs/Programs" ;
import { Script } from "./Script/Script" ;
2021-09-09 05:47:34 +02:00
import { findRunningScript , findRunningScriptByPid } from "./Script/ScriptHelpers" ;
2019-04-11 10:37:40 +02:00
import { isScriptFilename } from "./Script/ScriptHelpersTS" ;
2021-09-09 05:47:34 +02:00
import { AllServers , AddToAllServers , createUniqueRandomIp } from "./Server/AllServers" ;
2021-03-12 02:37:58 +01:00
import { RunningScript } from "./Script/RunningScript" ;
2019-04-11 10:37:40 +02:00
import {
2021-09-05 01:09:30 +02:00
GetServerByHostname ,
getServer ,
getServerOnNetwork ,
numCycleForGrowth ,
processSingleServerGrowth ,
safetlyCreateUniqueServer ,
2019-04-11 10:37:40 +02:00
} from "./Server/ServerHelpers" ;
2021-09-09 05:47:34 +02:00
import { getPurchaseServerCost , getPurchaseServerLimit , getPurchaseServerMaxRam } from "./Server/ServerPurchases" ;
2019-04-11 10:37:40 +02:00
import { SpecialServerIps } from "./Server/SpecialServerIps" ;
2019-05-05 06:03:40 +02:00
import { SourceFileFlags } from "./SourceFile/SourceFileFlags" ;
2021-09-09 05:47:34 +02:00
import { buyStock , sellStock , shortStock , sellShort } from "./StockMarket/BuyingAndSelling" ;
import { influenceStockThroughServerHack , influenceStockThroughServerGrow } from "./StockMarket/PlayerInfluencing" ;
2021-09-17 08:31:19 +02:00
import { StockMarket , SymbolToStockMap , placeOrder , cancelOrder } from "./StockMarket/StockMarket" ;
2021-09-09 05:47:34 +02:00
import { getBuyTransactionCost , getSellTransactionGain } from "./StockMarket/StockMarketHelpers" ;
2019-04-23 10:48:15 +02:00
import { OrderTypes } from "./StockMarket/data/OrderTypes" ;
import { PositionTypes } from "./StockMarket/data/PositionTypes" ;
import { StockSymbols } from "./StockMarket/data/StockSymbols" ;
2021-09-09 05:47:34 +02:00
import { getStockMarket4SDataCost , getStockMarket4STixApiCost } from "./StockMarket/StockMarketCosts" ;
import { isValidFilePath , removeLeadingSlash } from "./Terminal/DirectoryHelpers" ;
2019-04-11 10:37:40 +02:00
import { TextFile , getTextFile , createTextFile } from "./TextFile" ;
2017-08-30 19:44:29 +02:00
2021-09-09 05:47:34 +02:00
import { NetscriptPorts , runScriptFromScript , startWorkerScript } from "./NetscriptWorker" ;
2019-05-16 08:05:36 +02:00
import { killWorkerScript } from "./Netscript/killWorkerScript" ;
import { workerScripts } from "./Netscript/WorkerScripts" ;
2021-09-09 05:47:34 +02:00
import { makeRuntimeRejectMsg , netscriptDelay , resolveNetscriptRequestedThreads } from "./NetscriptEvaluator" ;
2021-04-21 14:20:26 +02:00
import { Interpreter } from "./JSInterpreter" ;
2019-04-11 10:37:40 +02:00
import { NetscriptPort } from "./NetscriptPort" ;
import { SleeveTaskType } from "./PersonObjects/Sleeve/SleeveTaskTypesEnum" ;
2019-04-30 05:54:20 +02:00
import { findSleevePurchasableAugs } from "./PersonObjects/Sleeve/SleeveHelpers" ;
2021-09-05 01:09:30 +02:00
import { Exploit } from "./Exploits/Exploit.ts" ;
2017-08-30 19:44:29 +02:00
2019-04-11 10:37:40 +02:00
import { numeralWrapper } from "./ui/numeralFormat" ;
import { setTimeoutRef } from "./utils/SetTimeoutRef" ;
import { is2DArray } from "./utils/helpers/is2DArray" ;
2021-05-17 23:12:35 +02:00
import { convertTimeMsToTimeElapsedString } from "../utils/StringHelperFunctions" ;
2019-02-27 03:26:29 +01:00
2019-07-05 03:01:09 +02:00
import { logBoxCreate } from "../utils/LogBox" ;
import { arrayToString } from "../utils/helpers/arrayToString" ;
2019-04-11 10:37:40 +02:00
import { isString } from "../utils/helpers/isString" ;
2017-08-21 18:59:06 +02:00
2019-04-11 10:37:40 +02:00
import { createElement } from "../utils/uiHelpers/createElement" ;
import { createPopup } from "../utils/uiHelpers/createPopup" ;
import { removeElementById } from "../utils/uiHelpers/removeElementById" ;
2019-02-09 03:46:30 +01:00
2021-09-05 01:09:30 +02:00
const defaultInterpreter = new Interpreter ( "" , ( ) => undefined ) ;
2021-04-21 14:20:26 +02:00
// the acorn interpreter has a bug where it doesn't convert arrays correctly.
// so we have to more or less copy it here.
function toNative ( pseudoObj ) {
2021-09-05 01:09:30 +02:00
if ( pseudoObj == null ) return null ;
if (
! pseudoObj . hasOwnProperty ( "properties" ) ||
! pseudoObj . hasOwnProperty ( "getter" ) ||
! pseudoObj . hasOwnProperty ( "setter" ) ||
! pseudoObj . hasOwnProperty ( "proto" )
) {
return pseudoObj ; // it wasn't a pseudo object anyway.
}
let nativeObj ;
if ( pseudoObj . hasOwnProperty ( "class" ) && pseudoObj . class === "Array" ) {
nativeObj = [ ] ;
const length = defaultInterpreter . getProperty ( pseudoObj , "length" ) ;
for ( let i = 0 ; i < length ; i ++ ) {
if ( defaultInterpreter . hasProperty ( pseudoObj , i ) ) {
nativeObj [ i ] = toNative ( defaultInterpreter . getProperty ( pseudoObj , i ) ) ;
2021-04-21 14:20:26 +02:00
}
2021-09-05 01:09:30 +02:00
}
} else {
// Object.
nativeObj = { } ;
for ( var key in pseudoObj . properties ) {
const val = pseudoObj . properties [ key ] ;
nativeObj [ key ] = toNative ( val ) ;
}
}
return nativeObj ;
2021-04-21 14:20:26 +02:00
}
2017-06-28 11:47:42 +02:00
function NetscriptFunctions ( workerScript ) {
2021-09-05 01:09:30 +02:00
const updateDynamicRam = function ( fnName , ramCost ) {
if ( workerScript . dynamicLoadedFns [ fnName ] ) {
return ;
}
workerScript . dynamicLoadedFns [ fnName ] = true ;
let threads = workerScript . scriptRef . threads ;
if ( typeof threads !== "number" ) {
2021-09-09 05:47:34 +02:00
console . warn ( ` WorkerScript detected NaN for threadcount for ${ workerScript . name } on ${ workerScript . serverIp } ` ) ;
2021-09-05 01:09:30 +02:00
threads = 1 ;
2018-09-23 02:25:48 +02:00
}
2021-09-05 01:09:30 +02:00
workerScript . dynamicRamUsage += ramCost * threads ;
if ( workerScript . dynamicRamUsage > 1.01 * workerScript . ramUsage ) {
throw makeRuntimeRejectMsg (
workerScript ,
2021-09-05 01:27:16 +02:00
` Dynamic RAM usage calculated to be greater than initial RAM usage on fn: ${ fnName } .
This is probably because you somehow circumvented the static RAM calculation .
2021-09-09 05:47:34 +02:00
Dynamic RAM Usage : $ { numeralWrapper . formatRAM ( workerScript . dynamicRamUsage ) }
2021-09-05 01:27:16 +02:00
Static RAM Usage : $ { numeralWrapper . formatRAM ( workerScript . ramUsage ) }
One of these could be the reason :
* Using eval ( ) to get a reference to a ns function
& nbsp ; & nbsp ; const scan = eval ( 'ns.scan' ) ;
* Using map access to do the same
& nbsp ; & nbsp ; const scan = ns [ 'scan' ] ;
* Saving script in the improper order .
& nbsp ; & nbsp ; Increase the cost of an imported script , save it , then run the
& nbsp ; & nbsp ; parent . To fix this just re - open & save every script in order
& nbsp ; & nbsp ; from most imported to least imported ( parent script ) .
Sorry : ( ` ,
2021-09-05 01:09:30 +02:00
) ;
}
} ;
/ * *
* Gets the Server for a specific hostname / ip , throwing an error
* if the server doesn ' t exist .
* @ param { string } ip - Hostname or IP of the server
* @ param { string } callingFnName - Name of calling function . For logging purposes
* @ returns { Server } The specified Server
* /
const safeGetServer = function ( ip , callingFnName = "" ) {
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( callingFnName , ` Invalid IP/hostname: ${ ip } ` ) ;
}
return server ;
} ;
/ * *
* Searches for and returns the RunningScript object for the specified script .
* If the 'fn' argument is not specified , this returns the current RunningScript .
* @ param { string } fn - Filename of script
* @ param { string } ip - Hostname / ip of the server on which the script resides
* @ param { any [ ] } scriptArgs - Running script ' s arguments
* @ returns { RunningScript }
* Running script identified by the parameters , or null if no such script
* exists , or the current running script if the first argument 'fn'
* is not specified .
* /
const getRunningScript = function ( fn , ip , callingFnName , scriptArgs ) {
if ( typeof callingFnName !== "string" || callingFnName === "" ) {
callingFnName = "getRunningScript" ;
2019-07-05 03:01:09 +02:00
}
2021-09-05 01:09:30 +02:00
if ( ! Array . isArray ( scriptArgs ) ) {
throw makeRuntimeRejectMsg (
workerScript ,
` Invalid scriptArgs argument passed into getRunningScript() from ${ callingFnName } (). ` +
` This is probably a bug. Please report to game developer ` ,
) ;
2021-04-21 14:20:26 +02:00
}
2021-09-05 01:09:30 +02:00
if ( fn != null && typeof fn === "string" ) {
// Get Logs of another script
if ( ip == null ) {
ip = workerScript . serverIp ;
}
const server = safeGetServer ( ip , callingFnName ) ;
2019-07-05 03:01:09 +02:00
2021-09-05 01:09:30 +02:00
return findRunningScript ( fn , scriptArgs , server ) ;
2019-07-05 03:01:09 +02:00
}
2021-09-05 01:09:30 +02:00
// If no arguments are specified, return the current RunningScript
return workerScript . scriptRef ;
} ;
const getRunningScriptByPid = function ( pid , callingFnName ) {
if ( typeof callingFnName !== "string" || callingFnName === "" ) {
callingFnName = "getRunningScriptgetRunningScriptByPid" ;
2019-04-29 08:20:27 +02:00
}
2021-09-05 01:09:30 +02:00
for ( const name of Object . keys ( AllServers ) ) {
const server = AllServers [ name ] ;
const runningScript = findRunningScriptByPid ( pid , server ) ;
if ( runningScript ) return runningScript ;
}
return null ;
} ;
/ * *
* Helper function for getting the error log message when the user specifies
* a nonexistent running script
* @ param { string } fn - Filename of script
* @ param { string } ip - Hostname / ip of the server on which the script resides
* @ param { any [ ] } scriptArgs - Running script ' s arguments
* @ returns { string } Error message to print to logs
* /
const getCannotFindRunningScriptErrorMessage = function ( fn , ip , scriptArgs ) {
if ( ! Array . isArray ( scriptArgs ) ) {
scriptArgs = [ ] ;
}
2019-04-29 08:20:27 +02:00
2021-09-09 05:47:34 +02:00
return ` Cannot find running script ${ fn } on server ${ ip } with args: ${ arrayToString ( scriptArgs ) } ` ;
2021-09-05 01:09:30 +02:00
} ;
/ * *
* Checks if the player has TIX API access . Throws an error if the player does not
* /
const checkTixApiAccess = function ( callingFn = "" ) {
if ( ! Player . hasWseAccount ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( callingFn , ` You don't have WSE Access! Cannot use ${ callingFn } () ` ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! Player . hasTixApiAccess ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( callingFn , ` You don't have TIX API Access! Cannot use ${ callingFn } () ` ) ;
2021-09-05 01:09:30 +02:00
}
} ;
/ * *
* Gets a stock , given its symbol . Throws an error if the symbol is invalid
* @ param { string } symbol - Stock ' s symbol
* @ returns { Stock } stock object
* /
const getStockFromSymbol = function ( symbol , callingFn = "" ) {
const stock = SymbolToStockMap [ symbol ] ;
if ( stock == null ) {
throw makeRuntimeErrorMsg ( callingFn , ` Invalid stock symbol: ' ${ symbol } ' ` ) ;
2019-04-29 08:20:27 +02:00
}
2021-09-05 01:09:30 +02:00
return stock ;
} ;
/ * *
* Used to fail a function if the function ' s target is a Hacknet Server .
* This is used for functions that should run on normal Servers , but not Hacknet Servers
* @ param { Server } server - Target server
* @ param { string } callingFn - Name of calling function . For logging purposes
* @ returns { boolean } True if the server is a Hacknet Server , false otherwise
* /
const failOnHacknetServer = function ( server , callingFn = "" ) {
if ( server instanceof HacknetServer ) {
workerScript . log ( callingFn , ` Does not work on Hacknet Servers ` ) ;
return true ;
} else {
return false ;
}
} ;
// Utility function to get Hacknet Node object
const getHacknetNode = function ( i , callingFn = "" ) {
if ( isNaN ( i ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( callingFn , "Invalid index specified for Hacknet Node: " + i ) ;
2021-09-05 01:09:30 +02:00
}
if ( i < 0 || i >= Player . hacknetNodes . length ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( callingFn , "Index specified for Hacknet Node is out-of-bounds: " + i ) ;
2019-03-31 04:53:57 +02:00
}
2021-09-09 09:17:01 +02:00
if ( hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
const hserver = AllServers [ Player . hacknetNodes [ i ] ] ;
if ( hserver == null ) {
throw makeRuntimeErrorMsg (
callingFn ,
` Could not get Hacknet Server for index ${ i } . This is probably a bug, please report to game dev ` ,
) ;
}
return hserver ;
} else {
return Player . hacknetNodes [ i ] ;
}
} ;
const makeRuntimeErrorMsg = function ( caller , msg ) {
const stack = new Error ( ) . stack . split ( "\n" ) . slice ( 1 ) ;
const scripts = workerScript . getServer ( ) . scripts ;
const userstack = [ ] ;
for ( const stackline of stack ) {
let filename ;
for ( const script of scripts ) {
if ( script . url && stackline . includes ( script . url ) ) {
filename = script . filename ;
2018-07-15 02:25:50 +02:00
}
2021-09-05 01:09:30 +02:00
for ( const dependency of script . dependencies ) {
if ( stackline . includes ( dependency . url ) ) {
filename = dependency . filename ;
}
2018-07-15 02:25:50 +02:00
}
2021-09-05 01:09:30 +02:00
}
if ( ! filename ) continue ;
2019-03-30 00:14:32 +01:00
2021-09-05 01:09:30 +02:00
function parseChromeStackline ( line ) {
const lineRe = /.*:(\d+):\d+.*/ ;
const funcRe = /.*at (.+) \(.*/ ;
2019-03-30 00:14:32 +01:00
2021-09-05 01:09:30 +02:00
const lineMatch = line . match ( lineRe ) ;
const funcMatch = line . match ( funcRe ) ;
if ( lineMatch && funcMatch ) {
return { line : lineMatch [ 1 ] , func : funcMatch [ 1 ] } ;
}
return null ;
}
let call = { line : "-1" , func : "unknown" } ;
const chromeCall = parseChromeStackline ( stackline ) ;
if ( chromeCall ) {
call = chromeCall ;
}
2021-03-25 07:48:15 +01:00
2021-09-05 01:09:30 +02:00
function parseFirefoxStackline ( line ) {
const lineRe = /.*:(\d+):\d+$/ ;
const lineMatch = line . match ( lineRe ) ;
2021-03-10 07:27:14 +01:00
2021-09-05 01:09:30 +02:00
const lio = line . lastIndexOf ( "@" ) ;
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
if ( lineMatch && lio !== - 1 ) {
return { line : lineMatch [ 1 ] , func : line . slice ( 0 , lio ) } ;
}
return null ;
}
2021-03-25 07:48:15 +01:00
2021-09-05 01:09:30 +02:00
let firefoxCall = parseFirefoxStackline ( stackline ) ;
if ( firefoxCall ) {
call = firefoxCall ;
}
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
userstack . push ( ` ${ filename } :L ${ call . line } @ ${ call . func } ` ) ;
}
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
workerScript . log ( caller , msg ) ;
let rejectMsg = ` ${ caller } : ${ msg } ` ;
2021-09-09 05:47:34 +02:00
if ( userstack . length !== 0 ) rejectMsg += ` <br><br>Stack:<br> ${ userstack . join ( "<br>" ) } ` ;
2021-09-05 01:09:30 +02:00
return makeRuntimeRejectMsg ( workerScript , rejectMsg ) ;
} ;
const checkFormulasAccess = function ( func , n ) {
2021-09-09 05:47:34 +02:00
if ( ( SourceFileFlags [ 5 ] < 1 && Player . bitNodeN !== 5 ) || ( SourceFileFlags [ n ] < 1 && Player . bitNodeN !== n ) ) {
2021-09-05 01:09:30 +02:00
let extra = "" ;
if ( n !== 5 ) {
extra = ` and Source-File ${ n } -1 ` ;
}
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` formulas. ${ func } ` , ` Requires Source-File 5-1 ${ extra } to run. ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
} ;
const checkSingularityAccess = function ( func , n ) {
if ( Player . bitNodeN !== 4 ) {
if ( SourceFileFlags [ 4 ] < n ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( func , ` This singularity function requires Source-File 4- ${ n } to run. ` ) ;
2021-09-05 01:09:30 +02:00
}
}
} ;
const checkBladeburnerAccess = function ( func , skipjoined = false ) {
const apiAccess =
Player . bitNodeN === 7 ||
Player . sourceFiles . some ( ( a ) => {
return a . n === 7 ;
} ) ;
if ( ! apiAccess ) {
const apiDenied = ` You do not currently have access to the Bladeburner API. You must either be in BitNode-7 or have Source-File 7. ` ;
throw makeRuntimeErrorMsg ( ` bladeburner. ${ func } ` , apiDenied ) ;
}
if ( ! skipjoined ) {
const bladeburnerAccess = Player . bladeburner instanceof Bladeburner ;
if ( ! bladeburnerAccess ) {
const bladeburnerDenied = ` You must be a member of the Bladeburner division to use this API. ` ;
throw makeRuntimeErrorMsg ( ` bladeburner. ${ func } ` , bladeburnerDenied ) ;
}
}
} ;
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
const checkBladeburnerCity = function ( func , city ) {
if ( ! Player . bladeburner . cities . hasOwnProperty ( city ) ) {
throw makeRuntimeErrorMsg ( ` bladeburner. ${ func } ` , ` Invalid city: ${ city } ` ) ;
}
} ;
const checkSleeveAPIAccess = function ( func ) {
if ( Player . bitNodeN !== 10 && ! SourceFileFlags [ 10 ] ) {
throw makeRuntimeErrorMsg (
` sleeve. ${ func } ` ,
"You do not currently have access to the Sleeve API. This is either because you are not in BitNode-10 or because you do not have Source-File 10" ,
) ;
2021-03-31 06:45:21 +02:00
}
2021-09-05 01:09:30 +02:00
} ;
2021-03-31 06:45:21 +02:00
2021-09-05 01:09:30 +02:00
const checkSleeveNumber = function ( func , sleeveNumber ) {
if ( sleeveNumber >= Player . sleeves . length || sleeveNumber < 0 ) {
const msg = ` Invalid sleeve number: ${ sleeveNumber } ` ;
workerScript . log ( func , msg ) ;
throw makeRuntimeErrorMsg ( ` sleeve. ${ func } ` , msg ) ;
}
} ;
const getCodingContract = function ( func , ip , fn ) {
const server = safeGetServer ( ip , func ) ;
const contract = server . getContract ( fn ) ;
if ( contract == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` codingcontract. ${ func } ` , ` Cannot find contract ' ${ fn } ' on server ' ${ ip } ' ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return contract ;
} ;
const checkGangApiAccess = function ( func ) {
const hasAccess = Player . gang instanceof Gang ;
if ( ! hasAccess ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` gang. ${ func } ` , ` You do not currently have a Gang ` ) ;
2021-09-05 01:09:30 +02:00
}
} ;
const getGangMember = function ( func , name ) {
2021-09-09 05:47:34 +02:00
for ( const member of Player . gang . members ) if ( member . name === name ) return member ;
2021-09-05 01:09:30 +02:00
throw makeRuntimeErrorMsg ( ` gang. ${ func } ` , ` Invalid gang member: ' ${ name } ' ` ) ;
} ;
const getGangTask = function ( func , name ) {
const task = GangMemberTasks [ name ] ;
if ( ! task ) {
throw makeRuntimeErrorMsg ( ` gang. ${ func } ` , ` Invalid task: ' ${ name } ' ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return task ;
} ;
const getBladeburnerActionObject = function ( func , type , name ) {
const actionId = Player . bladeburner . getActionIdFromTypeAndName ( type , name ) ;
if ( ! actionId ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` bladeburner. ${ func } ` , ` Invalid action type=' ${ type } ', name=' ${ name } ' ` ) ;
2021-09-05 01:09:30 +02:00
}
const actionObj = Player . bladeburner . getActionObject ( actionId ) ;
if ( ! actionObj ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` bladeburner. ${ func } ` , ` Invalid action type=' ${ type } ', name=' ${ name } ' ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return actionObj ;
} ;
const getCompany = function ( func , name ) {
const company = Companies [ name ] ;
if ( company == null || ! ( company instanceof Company ) ) {
throw makeRuntimeErrorMsg ( func , ` Invalid company name: ' ${ name } ' ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return company ;
} ;
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
const getFaction = function ( func , name ) {
if ( ! factionExists ( name ) ) {
throw makeRuntimeErrorMsg ( func , ` Invalid faction name: ' ${ name } ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return Factions [ name ] ;
} ;
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
const getAugmentation = function ( func , name ) {
if ( ! augmentationExists ( name ) ) {
throw makeRuntimeErrorMsg ( func , ` Invalid augmentation: ' ${ name } ' ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return Augmentations [ name ] ;
} ;
function getDivision ( divisionName ) {
2021-09-09 05:47:34 +02:00
const division = Player . corporation . divisions . find ( ( div ) => div . name === divisionName ) ;
if ( division === undefined ) throw new Error ( ` No division named ' ${ divisionName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return division ;
}
2021-09-10 06:13:28 +02:00
function getOffice ( divisionName , cityName ) {
const division = getDivision ( divisionName ) ;
if ( ! ( cityName in division . offices ) ) throw new Error ( ` Invalid city name ' ${ cityName } ' ` ) ;
const office = division . offices [ cityName ] ;
if ( office === 0 ) throw new Error ( ` ${ division . name } has not expanded to ' ${ cityName } ' ` ) ;
return office ;
}
2021-09-05 01:09:30 +02:00
function getWarehouse ( divisionName , cityName ) {
const division = getDivision ( divisionName ) ;
2021-09-09 05:47:34 +02:00
if ( ! ( cityName in division . warehouses ) ) throw new Error ( ` Invalid city name ' ${ cityName } ' ` ) ;
2021-09-05 01:09:30 +02:00
const warehouse = division . warehouses [ cityName ] ;
2021-09-09 05:47:34 +02:00
if ( warehouse === 0 ) throw new Error ( ` ${ division . name } has not expanded to ' ${ cityName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return warehouse ;
}
function getMaterial ( divisionName , cityName , materialName ) {
const warehouse = getWarehouse ( divisionName , cityName ) ;
const material = warehouse . materials [ materialName ] ;
2021-09-09 05:47:34 +02:00
if ( material === undefined ) throw new Error ( ` Invalid material name: ' ${ materialName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return material ;
}
function getProduct ( divisionName , productName ) {
const division = getDivision ( divisionName ) ;
const product = division . products [ productName ] ;
2021-09-09 05:47:34 +02:00
if ( product === undefined ) throw new Error ( ` Invalid product name: ' ${ productName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return product ;
}
2021-09-10 06:13:28 +02:00
function getEmployee ( divisionName , cityName , employeeName ) {
const office = getOffice ( divisionName , cityName ) ;
const employee = office . employees . find ( ( e ) => e . name === employeeName ) ;
if ( employee === undefined ) throw new Error ( ` Invalid employee name: ' ${ employeeName } ' ` ) ;
return employee ;
}
2021-09-05 01:09:30 +02:00
const runAfterReset = function ( cbScript = null ) {
//Run a script after reset
if ( cbScript && isString ( cbScript ) ) {
const home = Player . getHomeComputer ( ) ;
for ( const script of home . scripts ) {
if ( script . filename === cbScript ) {
const ramUsage = script . ramUsage ;
const ramAvailable = home . maxRam - home . ramUsed ;
if ( ramUsage > ramAvailable ) {
return ; // Not enough RAM
}
const runningScriptObj = new RunningScript ( script , [ ] ) ; // No args
runningScriptObj . threads = 1 ; // Only 1 thread
startWorkerScript ( runningScriptObj , home ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
}
}
} ;
2021-09-09 05:47:34 +02:00
const hack = function ( ip , manual , { threads : requestedThreads , stock } = { } ) {
2021-09-05 01:09:30 +02:00
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "hack" , "Takes 1 argument." ) ;
}
2021-09-09 05:47:34 +02:00
const threads = resolveNetscriptRequestedThreads ( workerScript , "hack" , requestedThreads ) ;
2021-09-05 01:09:30 +02:00
const server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "hack" , ` Invalid IP/hostname: ${ ip } . ` ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
// Calculate the hacking time
var hackingTime = calculateHackingTime ( server , Player ) ; // This is in seconds
// No root access or skill level too low
const canHack = netscriptCanHack ( server , Player ) ;
if ( ! canHack . res ) {
throw makeRuntimeErrorMsg ( "hack" , canHack . msg ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
workerScript . log (
"hack" ,
` Executing ${ ip } in ${ convertTimeMsToTimeElapsedString (
hackingTime * 1000 ,
true ,
) } ( t = $ { numeralWrapper . formatThreads ( threads ) } ) ` ,
) ;
return netscriptDelay ( hackingTime * 1000 , workerScript ) . then ( function ( ) {
if ( workerScript . env . stopFlag ) {
return Promise . reject ( workerScript ) ;
}
var hackChance = calculateHackingChance ( server , Player ) ;
var rand = Math . random ( ) ;
2021-09-09 05:47:34 +02:00
var expGainedOnSuccess = calculateHackingExpGain ( server , Player ) * threads ;
2021-09-05 01:09:30 +02:00
var expGainedOnFailure = expGainedOnSuccess / 4 ;
if ( rand < hackChance ) {
// Success!
const percentHacked = calculatePercentMoneyHacked ( server , Player ) ;
2021-09-09 05:47:34 +02:00
let maxThreadNeeded = Math . ceil ( ( 1 / percentHacked ) * ( server . moneyAvailable / server . moneyMax ) ) ;
2021-09-05 01:09:30 +02:00
if ( isNaN ( maxThreadNeeded ) ) {
// Server has a 'max money' of 0 (probably). We'll set this to an arbitrarily large value
maxThreadNeeded = 1e6 ;
2021-03-11 09:02:05 +01:00
}
2021-09-09 05:47:34 +02:00
let moneyDrained = Math . floor ( server . moneyAvailable * percentHacked ) * threads ;
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
// Over-the-top safety checks
if ( moneyDrained <= 0 ) {
moneyDrained = 0 ;
expGainedOnSuccess = expGainedOnFailure ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
if ( moneyDrained > server . moneyAvailable ) {
moneyDrained = server . moneyAvailable ;
}
server . moneyAvailable -= moneyDrained ;
if ( server . moneyAvailable < 0 ) {
server . moneyAvailable = 0 ;
2021-03-11 09:02:05 +01:00
}
2021-09-09 05:47:34 +02:00
const moneyGained = moneyDrained * BitNodeMultipliers . ScriptHackMoneyGain ;
2021-09-05 01:09:30 +02:00
Player . gainMoney ( moneyGained ) ;
workerScript . scriptRef . onlineMoneyMade += moneyGained ;
Player . scriptProdSinceLastAug += moneyGained ;
Player . recordMoneySource ( moneyGained , "hacking" ) ;
workerScript . scriptRef . recordHack ( server . ip , moneyGained , threads ) ;
Player . gainHackingExp ( expGainedOnSuccess ) ;
workerScript . scriptRef . onlineExpGained += expGainedOnSuccess ;
workerScript . log (
"hack" ,
2021-09-09 05:47:34 +02:00
` Successfully hacked ' ${ server . hostname } ' for ${ numeralWrapper . formatMoney (
2021-09-05 01:09:30 +02:00
moneyGained ,
2021-09-09 05:47:34 +02:00
) } and $ { numeralWrapper . formatExp ( expGainedOnSuccess ) } exp ( t = $ { numeralWrapper . formatThreads ( threads ) } ) ` ,
2021-09-05 01:09:30 +02:00
) ;
2021-09-09 05:47:34 +02:00
server . fortify ( CONSTANTS . ServerFortifyAmount * Math . min ( threads , maxThreadNeeded ) ) ;
2021-09-05 01:09:30 +02:00
if ( stock ) {
influenceStockThroughServerHack ( server , moneyGained ) ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
if ( manual ) {
server . backdoorInstalled = true ;
}
return Promise . resolve ( moneyGained ) ;
} else {
// Player only gains 25% exp for failure?
Player . gainHackingExp ( expGainedOnFailure ) ;
workerScript . scriptRef . onlineExpGained += expGainedOnFailure ;
workerScript . log (
"hack" ,
2021-09-09 05:47:34 +02:00
` Failed to hack ' ${ server . hostname } '. Gained ${ numeralWrapper . formatExp (
2021-09-05 01:09:30 +02:00
expGainedOnFailure ,
) } exp ( t = $ { numeralWrapper . formatThreads ( threads ) } ) ` ,
) ;
return Promise . resolve ( 0 ) ;
}
} ) ;
} ;
const argsToString = function ( args ) {
let out = "" ;
for ( let arg of args ) {
arg = toNative ( arg ) ;
if ( typeof arg === "object" ) {
out += JSON . stringify ( arg ) ;
continue ;
}
out += ` ${ arg } ` ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return out ;
} ;
const functions = {
hacknet : {
numNodes : function ( ) {
return Player . hacknetNodes . length ;
} ,
maxNumNodes : function ( ) {
2021-09-09 09:17:01 +02:00
if ( hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return HacknetServerConstants . MaxServers ;
}
return Infinity ;
} ,
purchaseNode : function ( ) {
2021-09-09 09:17:01 +02:00
return purchaseHacknet ( Player ) ;
2021-09-05 01:09:30 +02:00
} ,
getPurchaseNodeCost : function ( ) {
2021-09-09 09:17:01 +02:00
if ( hasHacknetServers ( Player ) ) {
return getCostOfNextHacknetServer ( Player ) ;
2021-09-05 01:09:30 +02:00
} else {
2021-09-09 09:17:01 +02:00
return getCostOfNextHacknetNode ( Player ) ;
2021-09-05 01:09:30 +02:00
}
} ,
getNodeStats : function ( i ) {
const node = getHacknetNode ( i , "getNodeStats" ) ;
2021-09-09 09:17:01 +02:00
const hasUpgraded = hasHacknetServers ( Player ) ;
2021-09-05 01:09:30 +02:00
const res = {
name : hasUpgraded ? node . hostname : node . name ,
level : node . level ,
ram : hasUpgraded ? node . maxRam : node . ram ,
cores : node . cores ,
production : hasUpgraded ? node . hashRate : node . moneyGainRatePerSecond ,
timeOnline : node . onlineTimeSeconds ,
2021-09-09 05:47:34 +02:00
totalProduction : hasUpgraded ? node . totalHashesGenerated : node . totalMoneyGenerated ,
2021-09-05 01:09:30 +02:00
} ;
if ( hasUpgraded ) {
res . cache = node . cache ;
res . hashCapacity = node . hashCapacity ;
2021-03-11 09:02:05 +01:00
}
2021-09-05 01:09:30 +02:00
return res ;
} ,
upgradeLevel : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeLevel" ) ;
2021-09-09 09:17:01 +02:00
return purchaseLevelUpgrade ( Player , node , n ) ;
2021-09-05 01:09:30 +02:00
} ,
upgradeRam : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeRam" ) ;
2021-09-09 09:17:01 +02:00
return purchaseRamUpgrade ( Player , node , n ) ;
2021-09-05 01:09:30 +02:00
} ,
upgradeCore : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeCore" ) ;
2021-09-09 09:17:01 +02:00
return purchaseCoreUpgrade ( Player , node , n ) ;
2021-09-05 01:09:30 +02:00
} ,
upgradeCache : function ( i , n ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return false ;
}
const node = getHacknetNode ( i , "upgradeCache" ) ;
2021-09-09 09:17:01 +02:00
const res = purchaseCacheUpgrade ( Player , node , n ) ;
2021-09-05 01:09:30 +02:00
if ( res ) {
2021-09-09 09:17:01 +02:00
updateHashManagerCapacity ( Player ) ;
2021-09-05 01:09:30 +02:00
}
return res ;
} ,
getLevelUpgradeCost : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeLevel" ) ;
2021-09-09 05:47:34 +02:00
return node . calculateLevelUpgradeCost ( n , Player . hacknet _node _level _cost _mult ) ;
2021-09-05 01:09:30 +02:00
} ,
getRamUpgradeCost : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeRam" ) ;
2021-09-09 05:47:34 +02:00
return node . calculateRamUpgradeCost ( n , Player . hacknet _node _ram _cost _mult ) ;
2021-09-05 01:09:30 +02:00
} ,
getCoreUpgradeCost : function ( i , n ) {
const node = getHacknetNode ( i , "upgradeCore" ) ;
2021-09-09 05:47:34 +02:00
return node . calculateCoreUpgradeCost ( n , Player . hacknet _node _core _cost _mult ) ;
2021-09-05 01:09:30 +02:00
} ,
getCacheUpgradeCost : function ( i , n ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return Infinity ;
}
const node = getHacknetNode ( i , "upgradeCache" ) ;
return node . calculateCacheUpgradeCost ( n ) ;
} ,
numHashes : function ( ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return 0 ;
}
return Player . hashManager . hashes ;
} ,
hashCapacity : function ( ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return 0 ;
}
return Player . hashManager . capacity ;
} ,
hashCost : function ( upgName ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return Infinity ;
}
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
return Player . hashManager . getUpgradeCost ( upgName ) ;
} ,
spendHashes : function ( upgName , upgTarget ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return false ;
2021-03-11 09:02:05 +01:00
}
2021-09-09 09:17:01 +02:00
return purchaseHashUpgrade ( Player , upgName , upgTarget ) ;
2021-09-05 01:09:30 +02:00
} ,
getHashUpgradeLevel : function ( upgName ) {
const level = Player . hashManager . upgrades [ upgName ] ;
if ( level === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "hacknet.hashUpgradeLevel" , ` Invalid Hash Upgrade: ${ upgName } ` ) ;
2021-09-05 01:09:30 +02:00
}
return level ;
} ,
getStudyMult : function ( ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return false ;
}
return Player . hashManager . getStudyMult ( ) ;
} ,
getTrainingMult : function ( ) {
2021-09-09 09:17:01 +02:00
if ( ! hasHacknetServers ( Player ) ) {
2021-09-05 01:09:30 +02:00
return false ;
}
return Player . hashManager . getTrainingMult ( ) ;
} ,
} ,
sprintf : sprintf ,
vsprintf : vsprintf ,
scan : function ( ip = workerScript . serverIp , hostnames = true ) {
updateDynamicRam ( "scan" , getRamCost ( "scan" ) ) ;
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "scan" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
var out = [ ] ;
for ( var i = 0 ; i < server . serversOnNetwork . length ; i ++ ) {
var entry ;
if ( hostnames ) {
entry = getServerOnNetwork ( server , i ) . hostname ;
} else {
entry = getServerOnNetwork ( server , i ) . ip ;
}
if ( entry == null ) {
continue ;
}
out . push ( entry ) ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "scan" , ` returned ${ server . serversOnNetwork . length } connections for ${ server . hostname } ` ) ;
2021-09-05 01:09:30 +02:00
return out ;
} ,
hack : function ( ip , { threads : requestedThreads , stock } = { } ) {
updateDynamicRam ( "hack" , getRamCost ( "hack" ) ) ;
return hack ( ip , false , { threads : requestedThreads , stock : stock } ) ;
} ,
hackAnalyzeThreads : function ( ip , hackAmount ) {
updateDynamicRam ( "hackAnalyzeThreads" , getRamCost ( "hackAnalyzeThreads" ) ) ;
// Check argument validity
const server = safeGetServer ( ip , "hackAnalyzeThreads" ) ;
if ( isNaN ( hackAmount ) ) {
throw makeRuntimeErrorMsg (
workerScript ,
` Invalid growth argument passed into hackAnalyzeThreads: ${ hackAmount } . Must be numeric. ` ,
) ;
}
2021-03-10 07:27:14 +01:00
2021-09-05 01:09:30 +02:00
if ( hackAmount < 0 || hackAmount > server . moneyAvailable ) {
return - 1 ;
}
2021-03-10 07:27:14 +01:00
2021-09-05 01:09:30 +02:00
const percentHacked = calculatePercentMoneyHacked ( server , Player ) ;
2021-09-02 06:36:33 +02:00
2021-09-05 01:09:30 +02:00
return hackAmount / Math . floor ( server . moneyAvailable * percentHacked ) ;
} ,
hackAnalyzePercent : function ( ip ) {
updateDynamicRam ( "hackAnalyzePercent" , getRamCost ( "hackAnalyzePercent" ) ) ;
2021-09-02 06:36:33 +02:00
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "hackAnalyzePercent" ) ;
2021-09-02 06:36:33 +02:00
2021-09-05 01:09:30 +02:00
return calculatePercentMoneyHacked ( server , Player ) * 100 ;
} ,
hackChance : function ( ip ) {
updateDynamicRam ( "hackChance" , getRamCost ( "hackChance" ) ) ;
2021-09-02 06:36:33 +02:00
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "hackChance" ) ;
return calculateHackingChance ( server , Player ) ;
} ,
sleep : function ( time ) {
if ( time === undefined ) {
throw makeRuntimeErrorMsg ( "sleep" , "Takes 1 argument." ) ;
}
workerScript . log ( "sleep" , ` Sleeping for ${ time } milliseconds ` ) ;
return netscriptDelay ( time , workerScript ) . then ( function ( ) {
return Promise . resolve ( true ) ;
} ) ;
} ,
grow : function ( ip , { threads : requestedThreads , stock } = { } ) {
updateDynamicRam ( "grow" , getRamCost ( "grow" ) ) ;
2021-09-09 05:47:34 +02:00
const threads = resolveNetscriptRequestedThreads ( workerScript , "grow" , requestedThreads ) ;
2021-09-05 01:09:30 +02:00
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "grow" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "grow" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
const host = getServer ( workerScript . serverIp ) ;
// No root access or skill level too low
const canHack = netscriptCanGrow ( server ) ;
if ( ! canHack . res ) {
throw makeRuntimeErrorMsg ( "grow" , canHack . msg ) ;
}
2021-03-12 02:37:58 +01:00
2021-09-05 01:09:30 +02:00
var growTime = calculateGrowTime ( server , Player ) ;
workerScript . log (
"grow" ,
2021-09-09 05:47:34 +02:00
` Executing on ' ${ server . hostname } ' in ${ convertTimeMsToTimeElapsedString (
2021-09-05 01:09:30 +02:00
growTime * 1000 ,
true ,
) } ( t = $ { numeralWrapper . formatThreads ( threads ) } ) . ` ,
) ;
return netscriptDelay ( growTime * 1000 , workerScript ) . then ( function ( ) {
if ( workerScript . env . stopFlag ) {
return Promise . reject ( workerScript ) ;
2021-03-24 02:30:15 +01:00
}
2021-09-09 05:47:34 +02:00
const moneyBefore = server . moneyAvailable <= 0 ? 1 : server . moneyAvailable ;
2021-09-05 01:09:30 +02:00
server . moneyAvailable += 1 * threads ; // It can be grown even if it has no money
processSingleServerGrowth ( server , threads , Player , host . cpuCores ) ;
const moneyAfter = server . moneyAvailable ;
workerScript . scriptRef . recordGrow ( server . ip , threads ) ;
var expGain = calculateHackingExpGain ( server , Player ) * threads ;
const logGrowPercent = moneyAfter / moneyBefore - 1 ;
workerScript . log (
"grow" ,
2021-09-09 05:47:34 +02:00
` Available money on ' ${ server . hostname } ' grown by ${ numeralWrapper . formatPercentage (
2021-09-05 01:09:30 +02:00
logGrowPercent ,
6 ,
2021-09-09 05:47:34 +02:00
) } . Gained $ { numeralWrapper . formatExp ( expGain ) } hacking exp ( t = $ { numeralWrapper . formatThreads ( threads ) } ) . ` ,
2021-09-05 01:09:30 +02:00
) ;
workerScript . scriptRef . onlineExpGained += expGain ;
Player . gainHackingExp ( expGain ) ;
if ( stock ) {
influenceStockThroughServerGrow ( server , moneyAfter - moneyBefore ) ;
}
return Promise . resolve ( moneyAfter / moneyBefore ) ;
} ) ;
} ,
growthAnalyze : function ( ip , growth ) {
updateDynamicRam ( "growthAnalyze" , getRamCost ( "growthAnalyze" ) ) ;
// Check argument validity
const server = safeGetServer ( ip , "growthAnalyze" ) ;
2021-09-09 05:47:34 +02:00
if ( typeof growth !== "number" || isNaN ( growth ) || growth < 1 || ! isFinite ( growth ) ) {
throw makeRuntimeErrorMsg ( "growthAnalyze" , ` Invalid argument: growth must be numeric and >= 1, is ${ growth } . ` ) ;
2021-09-05 01:09:30 +02:00
}
2021-03-24 02:30:15 +01:00
2021-09-05 01:09:30 +02:00
return numCycleForGrowth ( server , Number ( growth ) , Player ) ;
} ,
weaken : function ( ip , { threads : requestedThreads } = { } ) {
updateDynamicRam ( "weaken" , getRamCost ( "weaken" ) ) ;
2021-09-09 05:47:34 +02:00
var threads = resolveNetscriptRequestedThreads ( workerScript , "weaken" , requestedThreads ) ;
2021-09-05 01:09:30 +02:00
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "weaken" , "Takes 1 argument." ) ;
}
const server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "weaken" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
// No root access or skill level too low
const canHack = netscriptCanWeaken ( server ) ;
if ( ! canHack . res ) {
throw makeRuntimeErrorMsg ( "weaken" , canHack . msg ) ;
}
const weakenTime = calculateWeakenTime ( server , Player ) ;
workerScript . log (
"weaken" ,
2021-09-09 05:47:34 +02:00
` Executing on ' ${ server . hostname } ' in ${ convertTimeMsToTimeElapsedString (
2021-09-05 01:09:30 +02:00
weakenTime * 1000 ,
true ,
) } ( t = $ { numeralWrapper . formatThreads ( threads ) } ) ` ,
) ;
return netscriptDelay ( weakenTime * 1000 , workerScript ) . then ( function ( ) {
if ( workerScript . env . stopFlag ) return Promise . reject ( workerScript ) ;
const host = getServer ( workerScript . serverIp ) ;
const coreBonus = 1 + ( host . cpuCores - 1 ) / 16 ;
server . weaken ( CONSTANTS . ServerWeakenAmount * threads * coreBonus ) ;
workerScript . scriptRef . recordWeaken ( server . ip , threads ) ;
const expGain = calculateHackingExpGain ( server , Player ) * threads ;
workerScript . log (
"weaken" ,
2021-09-09 05:47:34 +02:00
` ' ${ server . hostname } ' security level weakened to ${ server . hackDifficulty } . Gained ${ numeralWrapper . formatExp (
2021-09-05 01:09:30 +02:00
expGain ,
) } hacking exp ( t = $ { numeralWrapper . formatThreads ( threads ) } ) ` ,
) ;
workerScript . scriptRef . onlineExpGained += expGain ;
Player . gainHackingExp ( expGain ) ;
return Promise . resolve ( CONSTANTS . ServerWeakenAmount * threads ) ;
} ) ;
} ,
print : function ( ) {
if ( arguments . length === 0 ) {
throw makeRuntimeErrorMsg ( "print" , "Takes at least 1 argument." ) ;
}
workerScript . print ( argsToString ( arguments ) ) ;
} ,
tprint : function ( ) {
if ( arguments . length === 0 ) {
throw makeRuntimeErrorMsg ( "tprint" , "Takes at least 1 argument." ) ;
}
2021-09-16 08:52:45 +02:00
Terminal . print ( ` ${ workerScript . scriptRef . filename } : ${ argsToString ( arguments ) } ` ) ;
2021-09-05 01:09:30 +02:00
} ,
tprintf : function ( format , ... args ) {
2021-09-16 08:52:45 +02:00
Terminal . print ( vsprintf ( format , args ) ) ;
2021-09-05 01:09:30 +02:00
} ,
clearLog : function ( ) {
workerScript . scriptRef . clearLog ( ) ;
} ,
disableLog : function ( fn ) {
if ( fn === "ALL" ) {
for ( fn in possibleLogs ) {
workerScript . disableLogs [ fn ] = true ;
2021-04-18 17:18:56 +02:00
}
2021-09-05 01:09:30 +02:00
workerScript . log ( "disableLog" , ` Disabled logging for all functions ` ) ;
} else if ( possibleLogs [ fn ] === undefined ) {
throw makeRuntimeErrorMsg ( "disableLog" , ` Invalid argument: ${ fn } . ` ) ;
} else {
workerScript . disableLogs [ fn ] = true ;
workerScript . log ( "disableLog" , ` Disabled logging for ${ fn } ` ) ;
}
} ,
enableLog : function ( fn ) {
if ( possibleLogs [ fn ] === undefined ) {
throw makeRuntimeErrorMsg ( "enableLog" , ` Invalid argument: ${ fn } . ` ) ;
}
delete workerScript . disableLogs [ fn ] ;
workerScript . log ( "enableLog" , ` Enabled logging for ${ fn } ` ) ;
} ,
isLogEnabled : function ( fn ) {
if ( possibleLogs [ fn ] === undefined ) {
throw makeRuntimeErrorMsg ( "isLogEnabled" , ` Invalid argument: ${ fn } . ` ) ;
}
return workerScript . disableLogs [ fn ] ? false : true ;
} ,
getScriptLogs : function ( fn , ip , ... scriptArgs ) {
2021-09-09 05:47:34 +02:00
const runningScriptObj = getRunningScript ( fn , ip , "getScriptLogs" , scriptArgs ) ;
2021-09-05 01:09:30 +02:00
if ( runningScriptObj == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "getScriptLogs" , getCannotFindRunningScriptErrorMessage ( fn , ip , scriptArgs ) ) ;
2021-09-05 01:09:30 +02:00
return "" ;
}
2021-04-18 17:18:56 +02:00
2021-09-05 01:09:30 +02:00
return runningScriptObj . logs . slice ( ) ;
} ,
tail : function ( fn , ip = workerScript . serverIp , ... scriptArgs ) {
let runningScriptObj ;
if ( arguments . length === 0 ) {
runningScriptObj = workerScript . scriptRef ;
} else if ( typeof fn === "number" ) {
runningScriptObj = getRunningScriptByPid ( fn , "tail" ) ;
} else {
runningScriptObj = getRunningScript ( fn , ip , "tail" , scriptArgs ) ;
}
if ( runningScriptObj == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "tail" , getCannotFindRunningScriptErrorMessage ( fn , ip , scriptArgs ) ) ;
2021-09-05 01:09:30 +02:00
return ;
}
2021-04-18 17:18:56 +02:00
2021-09-05 01:09:30 +02:00
logBoxCreate ( runningScriptObj ) ;
} ,
nuke : function ( ip ) {
updateDynamicRam ( "nuke" , getRamCost ( "nuke" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "nuke" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "nuke" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
if ( ! Player . hasProgram ( Programs . NukeProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "nuke" , "You do not have the NUKE.exe virus!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( server . openPortCount < server . numOpenPortsRequired ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "nuke" , "Not enough ports opened to use NUKE.exe virus." ) ;
2021-09-05 01:09:30 +02:00
}
if ( server . hasAdminRights ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "nuke" , ` Already have root access to ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
} else {
server . hasAdminRights = true ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "nuke" , ` Executed NUKE.exe virus on ' ${ server . hostname } ' to gain root access. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
brutessh : function ( ip ) {
updateDynamicRam ( "brutessh" , getRamCost ( "brutessh" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "brutessh" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "brutessh" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
if ( ! Player . hasProgram ( Programs . BruteSSHProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "brutessh" , "You do not have the BruteSSH.exe program!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! server . sshPortOpen ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "brutessh" , ` Executed BruteSSH.exe on ' ${ server . hostname } ' to open SSH port (22). ` ) ;
2021-09-05 01:09:30 +02:00
server . sshPortOpen = true ;
++ server . openPortCount ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "brutessh" , ` SSH Port (22) already opened on ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
ftpcrack : function ( ip ) {
updateDynamicRam ( "ftpcrack" , getRamCost ( "ftpcrack" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "ftpcrack" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "ftpcrack" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
if ( ! Player . hasProgram ( Programs . FTPCrackProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "ftpcrack" , "You do not have the FTPCrack.exe program!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! server . ftpPortOpen ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "ftpcrack" , ` Executed FTPCrack.exe on ' ${ server . hostname } ' to open FTP port (21). ` ) ;
2021-09-05 01:09:30 +02:00
server . ftpPortOpen = true ;
++ server . openPortCount ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "ftpcrack" , ` FTP Port (21) already opened on ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
relaysmtp : function ( ip ) {
updateDynamicRam ( "relaysmtp" , getRamCost ( "relaysmtp" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "relaysmtp" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "relaysmtp" , ` Invalid IP/hostname: ${ ip } . ` ) ;
}
if ( ! Player . hasProgram ( Programs . RelaySMTPProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "relaysmtp" , "You do not have the relaySMTP.exe program!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! server . smtpPortOpen ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "relaysmtp" , ` Executed relaySMTP.exe on ' ${ server . hostname } ' to open SMTP port (25). ` ) ;
2021-09-05 01:09:30 +02:00
server . smtpPortOpen = true ;
++ server . openPortCount ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "relaysmtp" , ` SMTP Port (25) already opened on ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
httpworm : function ( ip ) {
updateDynamicRam ( "httpworm" , getRamCost ( "httpworm" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "httpworm" , "Takes 1 argument" ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "httpworm" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
if ( ! Player . hasProgram ( Programs . HTTPWormProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "httpworm" , "You do not have the HTTPWorm.exe program!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! server . httpPortOpen ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "httpworm" , ` Executed HTTPWorm.exe on ' ${ server . hostname } ' to open HTTP port (80). ` ) ;
2021-09-05 01:09:30 +02:00
server . httpPortOpen = true ;
++ server . openPortCount ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "httpworm" , ` HTTP Port (80) already opened on ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
sqlinject : function ( ip ) {
updateDynamicRam ( "sqlinject" , getRamCost ( "sqlinject" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "sqlinject" , "Takes 1 argument." ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "sqlinject" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
if ( ! Player . hasProgram ( Programs . SQLInjectProgram . name ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "sqlinject" , "You do not have the SQLInject.exe program!" ) ;
2021-09-05 01:09:30 +02:00
}
if ( ! server . sqlPortOpen ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "sqlinject" , ` Executed SQLInject.exe on ' ${ server . hostname } ' to open SQL port (1433). ` ) ;
2021-09-05 01:09:30 +02:00
server . sqlPortOpen = true ;
++ server . openPortCount ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "sqlinject" , ` SQL Port (1433) already opened on ' ${ server . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} ,
run : function ( scriptname , threads = 1 ) {
updateDynamicRam ( "run" , getRamCost ( "run" ) ) ;
if ( scriptname === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "run" , "Usage: run(scriptname, [numThreads], [arg1], [arg2]...)" ) ;
2021-09-05 01:09:30 +02:00
}
if ( isNaN ( threads ) || threads <= 0 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "run" , ` Invalid thread count. Must be numeric and > 0, is ${ threads } ` ) ;
2021-09-05 01:09:30 +02:00
}
var argsForNewScript = [ ] ;
for ( var i = 2 ; i < arguments . length ; ++ i ) {
argsForNewScript . push ( arguments [ i ] ) ;
}
var scriptServer = getServer ( workerScript . serverIp ) ;
if ( scriptServer == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "run" , "Could not find server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
2019-01-03 09:39:32 +01:00
2021-09-09 05:47:34 +02:00
return runScriptFromScript ( "run" , scriptServer , scriptname , argsForNewScript , workerScript , threads ) ;
2021-09-05 01:09:30 +02:00
} ,
exec : function ( scriptname , ip , threads = 1 ) {
updateDynamicRam ( "exec" , getRamCost ( "exec" ) ) ;
if ( scriptname === undefined || ip === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "exec" , "Usage: exec(scriptname, server, [numThreads], [arg1], [arg2]...)" ) ;
2021-09-05 01:09:30 +02:00
}
if ( isNaN ( threads ) || threads <= 0 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "exec" , ` Invalid thread count. Must be numeric and > 0, is ${ threads } ` ) ;
2021-09-05 01:09:30 +02:00
}
var argsForNewScript = [ ] ;
for ( var i = 3 ; i < arguments . length ; ++ i ) {
argsForNewScript . push ( arguments [ i ] ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "exec" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
2021-09-09 05:47:34 +02:00
return runScriptFromScript ( "exec" , server , scriptname , argsForNewScript , workerScript , threads ) ;
2021-09-05 01:09:30 +02:00
} ,
spawn : function ( scriptname , threads ) {
updateDynamicRam ( "spawn" , getRamCost ( "spawn" ) ) ;
if ( ! scriptname || ! threads ) {
throw makeRuntimeErrorMsg ( "spawn" , "Usage: spawn(scriptname, threads)" ) ;
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
const spawnDelay = 10 ;
setTimeoutRef ( ( ) => {
if ( isNaN ( threads ) || threads <= 0 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "spawn" , ` Invalid thread count. Must be numeric and > 0, is ${ threads } ` ) ;
2021-09-05 01:09:30 +02:00
}
var argsForNewScript = [ ] ;
for ( var i = 2 ; i < arguments . length ; ++ i ) {
argsForNewScript . push ( arguments [ i ] ) ;
}
var scriptServer = getServer ( workerScript . serverIp ) ;
if ( scriptServer == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "spawn" , "Could not find server. This is a bug. Report to dev" ) ;
2021-09-05 01:09:30 +02:00
}
2019-01-03 09:39:32 +01:00
2021-09-09 05:47:34 +02:00
return runScriptFromScript ( "spawn" , scriptServer , scriptname , argsForNewScript , workerScript , threads ) ;
2021-09-05 01:09:30 +02:00
} , spawnDelay * 1e3 ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "spawn" , ` Will execute ' ${ scriptname } ' in ${ spawnDelay } seconds ` ) ;
2021-09-05 01:09:30 +02:00
workerScript . running = false ; // Prevent workerScript from "finishing execution naturally"
if ( killWorkerScript ( workerScript ) ) {
workerScript . log ( "spawn" , "Exiting..." ) ;
}
} ,
kill : function ( filename , ip , ... scriptArgs ) {
updateDynamicRam ( "kill" , getRamCost ( "kill" ) ) ;
let res ;
const killByPid = typeof filename === "number" ;
if ( killByPid ) {
// Kill by pid
res = killWorkerScript ( filename ) ;
} else {
// Kill by filename/ip
if ( filename === undefined || ip === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "kill" , "Usage: kill(scriptname, server, [arg1], [arg2]...)" ) ;
2021-09-05 01:09:30 +02:00
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip ) ;
2021-09-09 05:47:34 +02:00
const runningScriptObj = getRunningScript ( filename , ip , "kill" , scriptArgs ) ;
2021-09-05 01:09:30 +02:00
if ( runningScriptObj == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "kill" , getCannotFindRunningScriptErrorMessage ( filename , ip , scriptArgs ) ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
res = killWorkerScript ( runningScriptObj , server . ip ) ;
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
if ( res ) {
if ( killByPid ) {
workerScript . log ( "kill" , ` Killing script with PID ${ filename } ` ) ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "kill" , ` Killing ' ${ filename } ' on ' ${ ip } ' with args: ${ arrayToString ( scriptArgs ) } . ` ) ;
2021-09-05 01:09:30 +02:00
}
return true ;
} else {
if ( killByPid ) {
workerScript . log ( "kill" , ` No script with PID ${ filename } ` ) ;
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "kill" , ` No such script ' ${ filename } ' on ' ${ ip } ' with args: ${ arrayToString ( scriptArgs ) } ` ) ;
2021-09-05 01:09:30 +02:00
}
return false ;
}
} ,
killall : function ( ip = workerScript . serverIp ) {
updateDynamicRam ( "killall" , getRamCost ( "killall" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "killall" , "Takes 1 argument" ) ;
}
const server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "killall" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
const scriptsRunning = server . runningScripts . length > 0 ;
for ( let i = server . runningScripts . length - 1 ; i >= 0 ; -- i ) {
killWorkerScript ( server . runningScripts [ i ] , server . ip , false ) ;
}
WorkerScriptStartStopEventEmitter . emitEvent ( ) ;
workerScript . log (
"killall" ,
` Killing all scripts on ' ${ server . hostname } '. May take a few minutes for the scripts to die. ` ,
) ;
return scriptsRunning ;
} ,
exit : function ( ) {
workerScript . running = false ; // Prevent workerScript from "finishing execution naturally"
if ( killWorkerScript ( workerScript ) ) {
workerScript . log ( "exit" , "Exiting..." ) ;
} else {
workerScript . log ( "exit" , "Failed. This is a bug. Report to dev." ) ;
}
} ,
scp : function ( scriptname , ip1 , ip2 ) {
updateDynamicRam ( "scp" , getRamCost ( "scp" ) ) ;
if ( arguments . length !== 2 && arguments . length !== 3 ) {
throw makeRuntimeErrorMsg ( "scp" , "Takes 2 or 3 arguments" ) ;
}
if ( scriptname && scriptname . constructor === Array ) {
// Recursively call scp on all elements of array
var res = false ;
scriptname . forEach ( function ( script ) {
if ( NetscriptFunctions ( workerScript ) . scp ( script , ip1 , ip2 ) ) {
res = true ;
}
} ) ;
return res ;
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
// Invalid file type
if ( ! isValidFilePath ( scriptname ) ) {
throw makeRuntimeErrorMsg ( "scp" , ` Invalid filename: ' ${ scriptname } ' ` ) ;
}
2019-01-03 09:39:32 +01:00
2021-09-05 01:09:30 +02:00
// Invalid file name
2021-09-09 05:47:34 +02:00
if ( ! scriptname . endsWith ( ".lit" ) && ! isScriptFilename ( scriptname ) && ! scriptname . endsWith ( "txt" ) ) {
throw makeRuntimeErrorMsg ( "scp" , "Only works for .script, .lit, and .txt files" ) ;
2021-09-05 01:09:30 +02:00
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
var destServer , currServ ;
2021-08-19 22:37:59 +02:00
2021-09-05 01:09:30 +02:00
if ( ip2 != null ) {
// 3 Argument version: scriptname, source, destination
2021-09-09 05:47:34 +02:00
if ( scriptname === undefined || ip1 === undefined || ip2 === undefined ) {
2021-09-05 01:09:30 +02:00
throw makeRuntimeErrorMsg ( "scp" , "Takes 2 or 3 arguments" ) ;
}
destServer = getServer ( ip2 ) ;
if ( destServer == null ) {
throw makeRuntimeErrorMsg ( "scp" , ` Invalid IP/hostname: ${ ip2 } ` ) ;
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
currServ = getServer ( ip1 ) ;
if ( currServ == null ) {
throw makeRuntimeErrorMsg ( "scp" , ` Invalid IP/hostname: ${ ip1 } ` ) ;
}
} else if ( ip1 != null ) {
// 2 Argument version: scriptname, destination
if ( scriptname === undefined || ip1 === undefined ) {
throw makeRuntimeErrorMsg ( "scp" , "Takes 2 or 3 arguments" ) ;
}
destServer = getServer ( ip1 ) ;
if ( destServer == null ) {
throw makeRuntimeErrorMsg ( "scp" , ` Invalid IP/hostname: ${ ip1 } ` ) ;
}
2018-11-20 06:54:03 +01:00
2021-09-05 01:09:30 +02:00
currServ = getServer ( workerScript . serverIp ) ;
if ( currServ == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "scp" , "Could not find server ip for this script. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
} else {
throw makeRuntimeErrorMsg ( "scp" , "Takes 2 or 3 arguments" ) ;
}
2018-11-20 06:54:03 +01:00
2021-09-05 01:09:30 +02:00
// Scp for lit files
if ( scriptname . endsWith ( ".lit" ) ) {
var found = false ;
for ( var i = 0 ; i < currServ . messages . length ; ++ i ) {
2021-09-09 05:47:34 +02:00
if ( ! ( currServ . messages [ i ] instanceof Message ) && currServ . messages [ i ] == scriptname ) {
2021-09-05 01:09:30 +02:00
found = true ;
break ;
}
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
if ( ! found ) {
workerScript . log ( "scp" , ` File ' ${ scriptname } ' does not exist. ` ) ;
return false ;
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
for ( var i = 0 ; i < destServer . messages . length ; ++ i ) {
if ( destServer . messages [ i ] === scriptname ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` File ' ${ scriptname } ' copied over to ' ${ destServer . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
return true ; // Already exists
}
}
destServer . messages . push ( scriptname ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` File ' ${ scriptname } ' copied over to ' ${ destServer . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2017-09-07 07:45:14 +02:00
2021-09-05 01:09:30 +02:00
// Scp for text files
if ( scriptname . endsWith ( ".txt" ) ) {
var found = false ,
txtFile ;
for ( var i = 0 ; i < currServ . textFiles . length ; ++ i ) {
if ( currServ . textFiles [ i ] . fn === scriptname ) {
found = true ;
txtFile = currServ . textFiles [ i ] ;
break ;
}
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
if ( ! found ) {
workerScript . log ( "scp" , ` File ' ${ scriptname } ' does not exist. ` ) ;
return false ;
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
for ( var i = 0 ; i < destServer . textFiles . length ; ++ i ) {
if ( destServer . textFiles [ i ] . fn === scriptname ) {
// Overwrite
destServer . textFiles [ i ] . text = txtFile . text ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` File ' ${ scriptname } ' copied over to ' ${ destServer . hostname } '. ` ) ;
2017-06-28 11:47:42 +02:00
return true ;
2021-09-05 01:09:30 +02:00
}
}
var newFile = new TextFile ( txtFile . fn , txtFile . text ) ;
destServer . textFiles . push ( newFile ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` File ' ${ scriptname } ' copied over to ' ${ destServer . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2018-09-23 02:25:48 +02:00
2021-09-05 01:09:30 +02:00
// Scp for script files
let sourceScript = null ;
for ( let i = 0 ; i < currServ . scripts . length ; ++ i ) {
if ( scriptname == currServ . scripts [ i ] . filename ) {
sourceScript = currServ . scripts [ i ] ;
break ;
}
}
if ( sourceScript == null ) {
workerScript . log ( "scp" , ` File ' ${ scriptname } ' does not exist. ` ) ;
return false ;
}
2019-04-29 08:20:27 +02:00
2021-09-05 01:09:30 +02:00
// Overwrite script if it already exists
for ( let i = 0 ; i < destServer . scripts . length ; ++ i ) {
if ( scriptname == destServer . scripts [ i ] . filename ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` WARNING: File ' ${ scriptname } ' overwritten on ' ${ destServer . hostname } ' ` ) ;
2021-09-05 01:09:30 +02:00
const oldScript = destServer . scripts [ i ] ;
// If it's the exact same file don't actually perform the
// copy to avoid recompiling uselessly. Players tend to scp
// liberally.
if ( oldScript . code === sourceScript . code ) return true ;
oldScript . code = sourceScript . code ;
oldScript . ramUsage = sourceScript . ramUsage ;
oldScript . markUpdated ( ) ;
return true ;
}
}
2019-04-29 08:20:27 +02:00
2021-09-05 01:09:30 +02:00
// Create new script if it does not already exist
const newScript = new Script ( scriptname ) ;
newScript . code = sourceScript . code ;
newScript . ramUsage = sourceScript . ramUsage ;
newScript . server = destServer . ip ;
destServer . scripts . push ( newScript ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "scp" , ` File ' ${ scriptname } ' copied over to ' ${ destServer . hostname } '. ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
} ,
ls : function ( ip , grep ) {
updateDynamicRam ( "ls" , getRamCost ( "ls" ) ) ;
if ( ip === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "ls" , "Usage: ls(ip/hostname, [grep filter])" ) ;
2021-09-05 01:09:30 +02:00
}
const server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "ls" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
2019-04-29 08:20:27 +02:00
2021-09-05 01:09:30 +02:00
// Get the grep filter, if one exists
let filter = false ;
if ( arguments . length >= 2 ) {
filter = grep . toString ( ) ;
}
2019-01-09 11:06:49 +01:00
2021-09-05 01:09:30 +02:00
const allFiles = [ ] ;
for ( let i = 0 ; i < server . programs . length ; i ++ ) {
if ( filter ) {
if ( server . programs [ i ] . includes ( filter ) ) {
allFiles . push ( server . programs [ i ] ) ;
}
} else {
allFiles . push ( server . programs [ i ] ) ;
}
}
for ( let i = 0 ; i < server . scripts . length ; i ++ ) {
if ( filter ) {
if ( server . scripts [ i ] . filename . includes ( filter ) ) {
allFiles . push ( server . scripts [ i ] . filename ) ;
}
} else {
allFiles . push ( server . scripts [ i ] . filename ) ;
}
}
for ( let i = 0 ; i < server . messages . length ; i ++ ) {
if ( filter ) {
if ( server . messages [ i ] instanceof Message ) {
if ( server . messages [ i ] . filename . includes ( filter ) ) {
allFiles . push ( server . messages [ i ] . filename ) ;
}
} else if ( server . messages [ i ] . includes ( filter ) ) {
allFiles . push ( server . messages [ i ] ) ;
}
} else {
if ( server . messages [ i ] instanceof Message ) {
allFiles . push ( server . messages [ i ] . filename ) ;
} else {
allFiles . push ( server . messages [ i ] ) ;
}
}
}
2019-06-03 05:28:02 +02:00
2021-09-05 01:09:30 +02:00
for ( var i = 0 ; i < server . textFiles . length ; i ++ ) {
if ( filter ) {
if ( server . textFiles [ i ] . fn . includes ( filter ) ) {
allFiles . push ( server . textFiles [ i ] . fn ) ;
}
} else {
allFiles . push ( server . textFiles [ i ] . fn ) ;
}
}
2019-06-03 05:28:02 +02:00
2021-09-05 01:09:30 +02:00
for ( var i = 0 ; i < server . contracts . length ; ++ i ) {
if ( filter ) {
if ( server . contracts [ i ] . fn . includes ( filter ) ) {
allFiles . push ( server . contracts [ i ] . fn ) ;
}
} else {
allFiles . push ( server . contracts [ i ] . fn ) ;
}
}
2019-06-03 05:28:02 +02:00
2021-09-05 01:09:30 +02:00
// Sort the files alphabetically then print each
allFiles . sort ( ) ;
return allFiles ;
} ,
ps : function ( ip = workerScript . serverIp ) {
updateDynamicRam ( "ps" , getRamCost ( "ps" ) ) ;
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "ps" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
const processes = [ ] ;
for ( const i in server . runningScripts ) {
const script = server . runningScripts [ i ] ;
processes . push ( {
filename : script . filename ,
threads : script . threads ,
args : script . args . slice ( ) ,
pid : script . pid ,
} ) ;
}
return processes ;
} ,
hasRootAccess : function ( ip ) {
updateDynamicRam ( "hasRootAccess" , getRamCost ( "hasRootAccess" ) ) ;
if ( ip === undefined ) {
throw makeRuntimeErrorMsg ( "hasRootAccess" , "Takes 1 argument" ) ;
}
var server = getServer ( ip ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "hasRootAccess" , ` Invalid IP/hostname: ${ ip } ` ) ;
2021-09-05 01:09:30 +02:00
}
return server . hasAdminRights ;
} ,
getIp : function ( ) {
updateDynamicRam ( "getIp" , getRamCost ( "getIp" ) ) ;
var scriptServer = getServer ( workerScript . serverIp ) ;
if ( scriptServer == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getIp" , "Could not find server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
return scriptServer . ip ;
} ,
getHostname : function ( ) {
updateDynamicRam ( "getHostname" , getRamCost ( "getHostname" ) ) ;
var scriptServer = getServer ( workerScript . serverIp ) ;
if ( scriptServer == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( workerScript , "Could not find server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
return scriptServer . hostname ;
} ,
getHackingLevel : function ( ) {
updateDynamicRam ( "getHackingLevel" , getRamCost ( "getHackingLevel" ) ) ;
Player . updateSkillLevels ( ) ;
workerScript . log ( "getHackingLevel" , ` returned ${ Player . hacking _skill } ` ) ;
return Player . hacking _skill ;
} ,
getHackingMultipliers : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getHackingMultipliers" , getRamCost ( "getHackingMultipliers" ) ) ;
2021-09-05 01:09:30 +02:00
return {
chance : Player . hacking _chance _mult ,
speed : Player . hacking _speed _mult ,
money : Player . hacking _money _mult ,
growth : Player . hacking _grow _mult ,
} ;
} ,
getHacknetMultipliers : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getHacknetMultipliers" , getRamCost ( "getHacknetMultipliers" ) ) ;
2021-09-05 01:09:30 +02:00
return {
production : Player . hacknet _node _money _mult ,
purchaseCost : Player . hacknet _node _purchase _cost _mult ,
ramCost : Player . hacknet _node _ram _cost _mult ,
coreCost : Player . hacknet _node _core _cost _mult ,
levelCost : Player . hacknet _node _level _cost _mult ,
} ;
} ,
getBitNodeMultipliers : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getBitNodeMultipliers" , getRamCost ( "getBitNodeMultipliers" ) ) ;
2021-09-05 01:09:30 +02:00
if ( SourceFileFlags [ 5 ] <= 0 && Player . bitNodeN !== 5 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getBitNodeMultipliers" , "Requires Source-File 5 to run." ) ;
2021-09-05 01:09:30 +02:00
}
let copy = Object . assign ( { } , BitNodeMultipliers ) ;
return copy ;
} ,
getServer : function ( ip ) {
updateDynamicRam ( "getServer" , getRamCost ( "getServer" ) ) ;
if ( SourceFileFlags [ 5 ] <= 0 && Player . bitNodeN !== 5 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getServer" , "Requires Source-File 5 to run." ) ;
2021-09-05 01:09:30 +02:00
}
const server = safeGetServer ( ip , "getServer" ) ;
const copy = Object . assign ( { } , server ) ;
// These fields should be hidden.
copy . contracts = undefined ;
copy . messages = undefined ;
copy . runningScripts = undefined ;
copy . scripts = undefined ;
copy . textFiles = undefined ;
copy . programs = undefined ;
copy . serversOnNetwork = undefined ;
return copy ;
} ,
getServerMoneyAvailable : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerMoneyAvailable" , getRamCost ( "getServerMoneyAvailable" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerMoneyAvailable" ) ;
if ( failOnHacknetServer ( server , "getServerMoneyAvailable" ) ) {
return 0 ;
}
if ( server . hostname == "home" ) {
// Return player's money
workerScript . log (
"getServerMoneyAvailable" ,
2021-09-09 05:47:34 +02:00
` returned player's money: ${ numeralWrapper . formatMoney ( Player . money . toNumber ( ) ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return Player . money . toNumber ( ) ;
}
workerScript . log (
"getServerMoneyAvailable" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatMoney ( server . moneyAvailable ) } for ' ${ server . hostname } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . moneyAvailable ;
} ,
getServerSecurityLevel : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerSecurityLevel" , getRamCost ( "getServerSecurityLevel" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerSecurityLevel" ) ;
if ( failOnHacknetServer ( server , "getServerSecurityLevel" ) ) {
return 1 ;
}
workerScript . log (
"getServerSecurityLevel" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatServerSecurity ( server . hackDifficulty , 3 ) } for ' ${ server . hostname } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . hackDifficulty ;
} ,
getServerBaseSecurityLevel : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerBaseSecurityLevel" , getRamCost ( "getServerBaseSecurityLevel" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerBaseSecurityLevel" ) ;
if ( failOnHacknetServer ( server , "getServerBaseSecurityLevel" ) ) {
return 1 ;
}
workerScript . log (
"getServerBaseSecurityLevel" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatServerSecurity ( server . baseDifficulty , 3 ) } for ' ${ server . hostname } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . baseDifficulty ;
} ,
getServerMinSecurityLevel : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerMinSecurityLevel" , getRamCost ( "getServerMinSecurityLevel" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerMinSecurityLevel" ) ;
if ( failOnHacknetServer ( server , "getServerMinSecurityLevel" ) ) {
return 1 ;
}
workerScript . log (
"getServerMinSecurityLevel" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatServerSecurity ( server . minDifficulty , 3 ) } for ${ server . hostname } ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . minDifficulty ;
} ,
getServerRequiredHackingLevel : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerRequiredHackingLevel" , getRamCost ( "getServerRequiredHackingLevel" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerRequiredHackingLevel" ) ;
if ( failOnHacknetServer ( server , "getServerRequiredHackingLevel" ) ) {
return 1 ;
}
workerScript . log (
"getServerRequiredHackingLevel" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatSkill ( server . requiredHackingSkill , 0 ) } for ' ${ server . hostname } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . requiredHackingSkill ;
} ,
getServerMaxMoney : function ( ip ) {
updateDynamicRam ( "getServerMaxMoney" , getRamCost ( "getServerMaxMoney" ) ) ;
const server = safeGetServer ( ip , "getServerMaxMoney" ) ;
if ( failOnHacknetServer ( server , "getServerMaxMoney" ) ) {
return 0 ;
}
workerScript . log (
"getServerMaxMoney" ,
2021-09-09 05:47:34 +02:00
` returned ${ numeralWrapper . formatMoney ( server . moneyMax ) } for ' ${ server . hostname } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return server . moneyMax ;
} ,
getServerGrowth : function ( ip ) {
updateDynamicRam ( "getServerGrowth" , getRamCost ( "getServerGrowth" ) ) ;
const server = safeGetServer ( ip , "getServerGrowth" ) ;
if ( failOnHacknetServer ( server , "getServerGrowth" ) ) {
return 1 ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "getServerGrowth" , ` returned ${ server . serverGrowth } for ' ${ server . hostname } ' ` ) ;
2021-09-05 01:09:30 +02:00
return server . serverGrowth ;
} ,
getServerNumPortsRequired : function ( ip ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getServerNumPortsRequired" , getRamCost ( "getServerNumPortsRequired" ) ) ;
2021-09-05 01:09:30 +02:00
const server = safeGetServer ( ip , "getServerNumPortsRequired" ) ;
if ( failOnHacknetServer ( server , "getServerNumPortsRequired" ) ) {
return 5 ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "getServerNumPortsRequired" , ` returned ${ server . numOpenPortsRequired } for ' ${ server . hostname } ' ` ) ;
2021-09-05 01:09:30 +02:00
return server . numOpenPortsRequired ;
} ,
getServerRam : function ( ip ) {
updateDynamicRam ( "getServerRam" , getRamCost ( "getServerRam" ) ) ;
const server = safeGetServer ( ip , "getServerRam" ) ;
workerScript . log (
"getServerRam" ,
2021-09-09 05:47:34 +02:00
` returned [ ${ numeralWrapper . formatRAM ( server . maxRam , 2 ) } , ${ numeralWrapper . formatRAM ( server . ramUsed , 2 ) } ] ` ,
2021-09-05 01:09:30 +02:00
) ;
return [ server . maxRam , server . ramUsed ] ;
} ,
getServerMaxRam : function ( ip ) {
updateDynamicRam ( "getServerMaxRam" , getRamCost ( "getServerMaxRam" ) ) ;
const server = safeGetServer ( ip , "getServerMaxRam" ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "getServerMaxRam" , ` returned ${ numeralWrapper . formatRAM ( server . maxRam , 2 ) } ` ) ;
2021-09-05 01:09:30 +02:00
return server . maxRam ;
} ,
getServerUsedRam : function ( ip ) {
updateDynamicRam ( "getServerUsedRam" , getRamCost ( "getServerUsedRam" ) ) ;
const server = safeGetServer ( ip , "getServerUsedRam" ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "getServerUsedRam" , ` returned ${ numeralWrapper . formatRAM ( server . ramUsed , 2 ) } ` ) ;
2021-09-05 01:09:30 +02:00
return server . ramUsed ;
} ,
serverExists : function ( ip ) {
updateDynamicRam ( "serverExists" , getRamCost ( "serverExists" ) ) ;
return getServer ( ip ) !== null ;
} ,
fileExists : function ( filename , ip = workerScript . serverIp ) {
updateDynamicRam ( "fileExists" , getRamCost ( "fileExists" ) ) ;
if ( filename === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "fileExists" , "Usage: fileExists(scriptname, [server])" ) ;
2021-09-05 01:09:30 +02:00
}
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "fileExists" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
for ( var i = 0 ; i < server . scripts . length ; ++ i ) {
if ( filename == server . scripts [ i ] . filename ) {
return true ;
}
}
for ( var i = 0 ; i < server . programs . length ; ++ i ) {
if ( filename . toLowerCase ( ) == server . programs [ i ] . toLowerCase ( ) ) {
return true ;
}
}
for ( var i = 0 ; i < server . messages . length ; ++ i ) {
2021-09-09 05:47:34 +02:00
if ( ! ( server . messages [ i ] instanceof Message ) && filename . toLowerCase ( ) === server . messages [ i ] ) {
2021-09-05 01:09:30 +02:00
return true ;
}
}
var txtFile = getTextFile ( filename , server ) ;
if ( txtFile != null ) {
return true ;
}
return false ;
} ,
isRunning : function ( fn , ip = workerScript . serverIp , ... scriptArgs ) {
updateDynamicRam ( "isRunning" , getRamCost ( "isRunning" ) ) ;
if ( fn === undefined || ip === undefined ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "isRunning" , "Usage: isRunning(scriptname, server, [arg1], [arg2]...)" ) ;
2021-09-05 01:09:30 +02:00
}
if ( typeof fn === "number" ) {
return getRunningScriptByPid ( fn , "isRunning" ) != null ;
} else {
return getRunningScript ( fn , ip , "isRunning" , scriptArgs ) != null ;
}
} ,
getStockSymbols : function ( ) {
updateDynamicRam ( "getStockSymbols" , getRamCost ( "getStockSymbols" ) ) ;
checkTixApiAccess ( "getStockSymbols" ) ;
return Object . values ( StockSymbols ) ;
} ,
getStockPrice : function ( symbol ) {
updateDynamicRam ( "getStockPrice" , getRamCost ( "getStockPrice" ) ) ;
checkTixApiAccess ( "getStockPrice" ) ;
const stock = getStockFromSymbol ( symbol , "getStockPrice" ) ;
return stock . price ;
} ,
getStockAskPrice : function ( symbol ) {
updateDynamicRam ( "getStockAskPrice" , getRamCost ( "getStockAskPrice" ) ) ;
checkTixApiAccess ( "getStockAskPrice" ) ;
const stock = getStockFromSymbol ( symbol , "getStockAskPrice" ) ;
return stock . getAskPrice ( ) ;
} ,
getStockBidPrice : function ( symbol ) {
updateDynamicRam ( "getStockBidPrice" , getRamCost ( "getStockBidPrice" ) ) ;
checkTixApiAccess ( "getStockBidPrice" ) ;
const stock = getStockFromSymbol ( symbol , "getStockBidPrice" ) ;
return stock . getBidPrice ( ) ;
} ,
getStockPosition : function ( symbol ) {
updateDynamicRam ( "getStockPosition" , getRamCost ( "getStockPosition" ) ) ;
checkTixApiAccess ( "getStockPosition" ) ;
var stock = SymbolToStockMap [ symbol ] ;
if ( stock == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getStockPosition" , ` Invalid stock symbol: ${ symbol } ` ) ;
2021-09-05 01:09:30 +02:00
}
2021-09-09 05:47:34 +02:00
return [ stock . playerShares , stock . playerAvgPx , stock . playerShortShares , stock . playerAvgShortPx ] ;
2021-09-05 01:09:30 +02:00
} ,
getStockMaxShares : function ( symbol ) {
updateDynamicRam ( "getStockMaxShares" , getRamCost ( "getStockMaxShares" ) ) ;
checkTixApiAccess ( "getStockMaxShares" ) ;
const stock = getStockFromSymbol ( symbol , "getStockMaxShares" ) ;
return stock . maxShares ;
} ,
getStockPurchaseCost : function ( symbol , shares , posType ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getStockPurchaseCost" , getRamCost ( "getStockPurchaseCost" ) ) ;
2021-09-05 01:09:30 +02:00
checkTixApiAccess ( "getStockPurchaseCost" ) ;
const stock = getStockFromSymbol ( symbol , "getStockPurchaseCost" ) ;
shares = Math . round ( shares ) ;
let pos ;
const sanitizedPosType = posType . toLowerCase ( ) ;
if ( sanitizedPosType . includes ( "l" ) ) {
pos = PositionTypes . Long ;
} else if ( sanitizedPosType . includes ( "s" ) ) {
pos = PositionTypes . Short ;
} else {
return Infinity ;
}
2019-06-03 05:28:02 +02:00
2021-09-05 01:09:30 +02:00
const res = getBuyTransactionCost ( stock , shares , pos ) ;
if ( res == null ) {
return Infinity ;
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
return res ;
} ,
getStockSaleGain : function ( symbol , shares , posType ) {
updateDynamicRam ( "getStockSaleGain" , getRamCost ( "getStockSaleGain" ) ) ;
checkTixApiAccess ( "getStockSaleGain" ) ;
const stock = getStockFromSymbol ( symbol , "getStockSaleGain" ) ;
shares = Math . round ( shares ) ;
let pos ;
const sanitizedPosType = posType . toLowerCase ( ) ;
if ( sanitizedPosType . includes ( "l" ) ) {
pos = PositionTypes . Long ;
} else if ( sanitizedPosType . includes ( "s" ) ) {
pos = PositionTypes . Short ;
} else {
return 0 ;
}
2019-04-21 07:31:19 +02:00
2021-09-05 01:09:30 +02:00
const res = getSellTransactionGain ( stock , shares , pos ) ;
if ( res == null ) {
return 0 ;
}
2019-04-23 10:23:08 +02:00
2021-09-05 01:09:30 +02:00
return res ;
} ,
buyStock : function ( symbol , shares ) {
updateDynamicRam ( "buyStock" , getRamCost ( "buyStock" ) ) ;
checkTixApiAccess ( "buyStock" ) ;
const stock = getStockFromSymbol ( symbol , "buyStock" ) ;
2021-09-17 08:31:19 +02:00
const res = buyStock ( stock , shares , workerScript , { } ) ;
2021-09-05 01:09:30 +02:00
return res ? stock . price : 0 ;
} ,
sellStock : function ( symbol , shares ) {
updateDynamicRam ( "sellStock" , getRamCost ( "sellStock" ) ) ;
checkTixApiAccess ( "sellStock" ) ;
const stock = getStockFromSymbol ( symbol , "sellStock" ) ;
2021-09-17 08:31:19 +02:00
const res = sellStock ( stock , shares , workerScript , { } ) ;
2021-09-05 01:09:30 +02:00
return res ? stock . price : 0 ;
} ,
shortStock : function ( symbol , shares ) {
updateDynamicRam ( "shortStock" , getRamCost ( "shortStock" ) ) ;
checkTixApiAccess ( "shortStock" ) ;
if ( Player . bitNodeN !== 8 ) {
if ( SourceFileFlags [ 8 ] <= 1 ) {
throw makeRuntimeErrorMsg (
shortStock ,
"You must either be in BitNode-8 or you must have Source-File 8 Level 2." ,
) ;
}
}
const stock = getStockFromSymbol ( symbol , "shortStock" ) ;
2021-09-17 08:31:19 +02:00
const res = shortStock ( stock , shares , workerScript , { } ) ;
2021-09-05 01:09:30 +02:00
return res ? stock . price : 0 ;
} ,
sellShort : function ( symbol , shares ) {
updateDynamicRam ( "sellShort" , getRamCost ( "sellShort" ) ) ;
checkTixApiAccess ( "sellShort" ) ;
if ( Player . bitNodeN !== 8 ) {
if ( SourceFileFlags [ 8 ] <= 1 ) {
throw makeRuntimeErrorMsg (
"sellShort" ,
"You must either be in BitNode-8 or you must have Source-File 8 Level 2." ,
) ;
}
}
const stock = getStockFromSymbol ( symbol , "sellShort" ) ;
2021-09-17 08:31:19 +02:00
const res = sellShort ( stock , shares , workerScript , { } ) ;
2021-09-05 01:09:30 +02:00
return res ? stock . price : 0 ;
} ,
placeOrder : function ( symbol , shares , price , type , pos ) {
updateDynamicRam ( "placeOrder" , getRamCost ( "placeOrder" ) ) ;
checkTixApiAccess ( "placeOrder" ) ;
if ( Player . bitNodeN !== 8 ) {
if ( SourceFileFlags [ 8 ] <= 2 ) {
throw makeRuntimeErrorMsg (
"placeOrder" ,
"You must either be in BitNode-8 or you must have Source-File 8 Level 3." ,
) ;
}
}
const stock = getStockFromSymbol ( symbol , "placeOrder" ) ;
let orderType , orderPos ;
ltype = type . toLowerCase ( ) ;
if ( ltype . includes ( "limit" ) && ltype . includes ( "buy" ) ) {
orderType = OrderTypes . LimitBuy ;
} else if ( ltype . includes ( "limit" ) && ltype . includes ( "sell" ) ) {
orderType = OrderTypes . LimitSell ;
} else if ( ltype . includes ( "stop" ) && ltype . includes ( "buy" ) ) {
orderType = OrderTypes . StopBuy ;
} else if ( ltype . includes ( "stop" ) && ltype . includes ( "sell" ) ) {
orderType = OrderTypes . StopSell ;
} else {
throw makeRuntimeErrorMsg ( "placeOrder" , ` Invalid order type: ${ type } ` ) ;
}
2017-10-25 21:47:47 +02:00
2021-09-05 01:09:30 +02:00
lpos = pos . toLowerCase ( ) ;
if ( lpos . includes ( "l" ) ) {
orderPos = PositionTypes . Long ;
} else if ( lpos . includes ( "s" ) ) {
orderPos = PositionTypes . Short ;
} else {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "placeOrder" , ` Invalid position type: ${ pos } ` ) ;
2021-09-05 01:09:30 +02:00
}
2017-10-25 21:47:47 +02:00
2021-09-09 05:47:34 +02:00
return placeOrder ( stock , shares , price , orderType , orderPos , workerScript ) ;
2021-09-05 01:09:30 +02:00
} ,
cancelOrder : function ( symbol , shares , price , type , pos ) {
updateDynamicRam ( "cancelOrder" , getRamCost ( "cancelOrder" ) ) ;
checkTixApiAccess ( "cancelOrder" ) ;
if ( Player . bitNodeN !== 8 ) {
if ( SourceFileFlags [ 8 ] <= 2 ) {
throw makeRuntimeErrorMsg (
"cancelOrder" ,
"You must either be in BitNode-8 or you must have Source-File 8 Level 3." ,
) ;
}
}
const stock = getStockFrom ( symbol , "cancelOrder" ) ;
if ( isNaN ( shares ) || isNaN ( price ) ) {
throw makeRuntimeErrorMsg (
"cancelOrder" ,
` Invalid shares or price. Must be numeric. shares= ${ shares } , price= ${ price } ` ,
) ;
}
var orderType , orderPos ;
ltype = type . toLowerCase ( ) ;
if ( ltype . includes ( "limit" ) && ltype . includes ( "buy" ) ) {
orderType = OrderTypes . LimitBuy ;
} else if ( ltype . includes ( "limit" ) && ltype . includes ( "sell" ) ) {
orderType = OrderTypes . LimitSell ;
} else if ( ltype . includes ( "stop" ) && ltype . includes ( "buy" ) ) {
orderType = OrderTypes . StopBuy ;
} else if ( ltype . includes ( "stop" ) && ltype . includes ( "sell" ) ) {
orderType = OrderTypes . StopSell ;
} else {
throw makeRuntimeErrorMsg ( "cancelOrder" , ` Invalid order type: ${ type } ` ) ;
}
2017-10-25 21:47:47 +02:00
2021-09-05 01:09:30 +02:00
lpos = pos . toLowerCase ( ) ;
if ( lpos . includes ( "l" ) ) {
orderPos = PositionTypes . Long ;
} else if ( lpos . includes ( "s" ) ) {
orderPos = PositionTypes . Short ;
} else {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "cancelOrder" , ` Invalid position type: ${ pos } ` ) ;
2021-09-05 01:09:30 +02:00
}
var params = {
stock : stock ,
shares : shares ,
price : price ,
type : orderType ,
pos : orderPos ,
} ;
return cancelOrder ( params , workerScript ) ;
} ,
getOrders : function ( ) {
updateDynamicRam ( "getOrders" , getRamCost ( "getOrders" ) ) ;
checkTixApiAccess ( "getOrders" ) ;
if ( Player . bitNodeN !== 8 ) {
if ( SourceFileFlags [ 8 ] <= 2 ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( workerScript , "You must either be in BitNode-8 or have Source-File 8 Level 3." ) ;
2021-09-05 01:09:30 +02:00
}
}
2018-12-31 01:11:48 +01:00
2021-09-05 01:09:30 +02:00
const orders = { } ;
const stockMarketOrders = StockMarket [ "Orders" ] ;
for ( let symbol in stockMarketOrders ) {
const orderBook = stockMarketOrders [ symbol ] ;
if ( orderBook . constructor === Array && orderBook . length > 0 ) {
orders [ symbol ] = [ ] ;
for ( let i = 0 ; i < orderBook . length ; ++ i ) {
orders [ symbol ] . push ( {
shares : orderBook [ i ] . shares ,
price : orderBook [ i ] . price ,
type : orderBook [ i ] . type ,
position : orderBook [ i ] . pos ,
} ) ;
}
}
}
2018-12-31 01:11:48 +01:00
2021-09-05 01:09:30 +02:00
return orders ;
} ,
getStockVolatility : function ( symbol ) {
updateDynamicRam ( "getStockVolatility" , getRamCost ( "getStockVolatility" ) ) ;
if ( ! Player . has4SDataTixApi ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getStockVolatility" , "You don't have 4S Market Data TIX API Access!" ) ;
2021-09-05 01:09:30 +02:00
}
const stock = getStockFromSymbol ( symbol , "getStockVolatility" ) ;
return stock . mv / 100 ; // Convert from percentage to decimal
} ,
getStockForecast : function ( symbol ) {
updateDynamicRam ( "getStockForecast" , getRamCost ( "getStockForecast" ) ) ;
if ( ! Player . has4SDataTixApi ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getStockForecast" , "You don't have 4S Market Data TIX API Access!" ) ;
2021-09-05 01:09:30 +02:00
}
const stock = getStockFromSymbol ( symbol , "getStockForecast" ) ;
var forecast = 50 ;
stock . b ? ( forecast += stock . otlkMag ) : ( forecast -= stock . otlkMag ) ;
return forecast / 100 ; // Convert from percentage to decimal
} ,
purchase4SMarketData : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "purchase4SMarketData" , getRamCost ( "purchase4SMarketData" ) ) ;
2021-09-05 01:09:30 +02:00
checkTixApiAccess ( "purchase4SMarketData" ) ;
if ( Player . has4SData ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchase4SMarketData" , "Already purchased 4S Market Data." ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2019-04-29 08:20:27 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . money . lt ( getStockMarket4SDataCost ( ) ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchase4SMarketData" , "Not enough money to purchase 4S Market Data." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2019-04-29 08:20:27 +02:00
2021-09-05 01:09:30 +02:00
Player . has4SData = true ;
Player . loseMoney ( getStockMarket4SDataCost ( ) ) ;
workerScript . log ( "purchase4SMarketData" , "Purchased 4S Market Data" ) ;
return true ;
} ,
purchase4SMarketDataTixApi : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "purchase4SMarketDataTixApi" , getRamCost ( "purchase4SMarketDataTixApi" ) ) ;
2021-09-05 01:09:30 +02:00
checkTixApiAccess ( "purchase4SMarketDataTixApi" ) ;
if ( Player . has4SDataTixApi ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchase4SMarketDataTixApi" , "Already purchased 4S Market Data TIX API" ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
if ( Player . money . lt ( getStockMarket4STixApiCost ( ) ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchase4SMarketDataTixApi" , "Not enough money to purchase 4S Market Data TIX API" ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
Player . has4SDataTixApi = true ;
Player . loseMoney ( getStockMarket4STixApiCost ( ) ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchase4SMarketDataTixApi" , "Purchased 4S Market Data TIX API" ) ;
2021-09-05 01:09:30 +02:00
return true ;
} ,
getPurchasedServerLimit : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getPurchasedServerLimit" , getRamCost ( "getPurchasedServerLimit" ) ) ;
2021-09-05 01:09:30 +02:00
return getPurchaseServerLimit ( ) ;
} ,
getPurchasedServerMaxRam : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getPurchasedServerMaxRam" , getRamCost ( "getPurchasedServerMaxRam" ) ) ;
2021-09-05 01:09:30 +02:00
return getPurchaseServerMaxRam ( ) ;
} ,
getPurchasedServerCost : function ( ram ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getPurchasedServerCost" , getRamCost ( "getPurchasedServerCost" ) ) ;
2021-09-05 01:09:30 +02:00
const cost = getPurchaseServerCost ( ram ) ;
if ( cost === Infinity ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "getPurchasedServerCost" , ` Invalid argument: ram=' ${ ram } ' ` ) ;
2021-09-05 01:09:30 +02:00
return Infinity ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
return cost ;
} ,
purchaseServer : function ( hostname , ram ) {
updateDynamicRam ( "purchaseServer" , getRamCost ( "purchaseServer" ) ) ;
var hostnameStr = String ( hostname ) ;
hostnameStr = hostnameStr . replace ( /\s+/g , "" ) ;
if ( hostnameStr == "" ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseServer" , ` Invalid argument: hostname=' ${ hostnameStr } ' ` ) ;
2021-09-05 01:09:30 +02:00
return "" ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
if ( Player . purchasedServers . length >= getPurchaseServerLimit ( ) ) {
workerScript . log (
"purchaseServer" ,
` You have reached the maximum limit of ${ getPurchaseServerLimit ( ) } servers. You cannot purchase any more. ` ,
) ;
return "" ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
const cost = getPurchaseServerCost ( ram ) ;
if ( cost === Infinity ) {
workerScript . log ( "purchaseServer" , ` Invalid argument: ram=' ${ ram } ' ` ) ;
return "" ;
}
2018-11-01 19:18:32 +01:00
2021-09-05 01:09:30 +02:00
if ( Player . money . lt ( cost ) ) {
workerScript . log (
"purchaseServer" ,
2021-09-09 05:47:34 +02:00
` Not enough money to purchase server. Need ${ numeralWrapper . formatMoney ( cost ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return "" ;
}
var newServ = safetlyCreateUniqueServer ( {
ip : createUniqueRandomIp ( ) ,
hostname : hostnameStr ,
organizationName : "" ,
isConnectedTo : false ,
adminRights : true ,
purchasedByPlayer : true ,
maxRam : ram ,
} ) ;
AddToAllServers ( newServ ) ;
Player . purchasedServers . push ( newServ . ip ) ;
var homeComputer = Player . getHomeComputer ( ) ;
homeComputer . serversOnNetwork . push ( newServ . ip ) ;
newServ . serversOnNetwork . push ( homeComputer . ip ) ;
Player . loseMoney ( cost ) ;
workerScript . log (
"purchaseServer" ,
2021-09-09 05:47:34 +02:00
` Purchased new server with hostname ' ${ newServ . hostname } ' for ${ numeralWrapper . formatMoney ( cost ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return newServ . hostname ;
} ,
deleteServer : function ( hostname ) {
updateDynamicRam ( "deleteServer" , getRamCost ( "deleteServer" ) ) ;
var hostnameStr = String ( hostname ) ;
hostnameStr = hostnameStr . replace ( /\s\s+/g , "" ) ;
var server = GetServerByHostname ( hostnameStr ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "deleteServer" , ` Invalid argument: hostname=' ${ hostnameStr } ' ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2018-07-20 04:21:11 +02:00
2021-09-05 01:09:30 +02:00
if ( ! server . purchasedByPlayer || server . hostname === "home" ) {
workerScript . log ( "deleteServer" , "Cannot delete non-purchased server." ) ;
return false ;
}
2018-07-20 04:21:11 +02:00
2021-09-05 01:09:30 +02:00
var ip = server . ip ;
2018-06-20 18:43:05 +02:00
2021-09-05 01:09:30 +02:00
// Can't delete server you're currently connected to
if ( server . isConnectedTo ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "deleteServer" , "You are currently connected to the server you are trying to delete." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2018-06-20 18:43:05 +02:00
2021-09-05 01:09:30 +02:00
// A server cannot delete itself
if ( ip === workerScript . serverIp ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "deleteServer" , "Cannot delete the server this script is running on." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
// Delete all scripts running on server
if ( server . runningScripts . length > 0 ) {
workerScript . log (
"deleteServer" ,
` Cannot delete server ' ${ server . hostname } ' because it still has scripts running. ` ,
) ;
return false ;
}
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
// Delete from player's purchasedServers array
var found = false ;
for ( var i = 0 ; i < Player . purchasedServers . length ; ++ i ) {
if ( ip == Player . purchasedServers [ i ] ) {
found = true ;
Player . purchasedServers . splice ( i , 1 ) ;
break ;
}
}
2017-07-25 03:06:40 +02:00
2021-09-05 01:09:30 +02:00
if ( ! found ) {
workerScript . log (
"deleteServer" ,
` Could not identify server ${ server . hostname } as a purchased server. This is a bug. Report to dev. ` ,
) ;
return false ;
}
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
// Delete from all servers
delete AllServers [ ip ] ;
// Delete from home computer
found = false ;
var homeComputer = Player . getHomeComputer ( ) ;
for ( var i = 0 ; i < homeComputer . serversOnNetwork . length ; ++ i ) {
if ( ip == homeComputer . serversOnNetwork [ i ] ) {
homeComputer . serversOnNetwork . splice ( i , 1 ) ;
workerScript . log ( "deleteServer" , ` Deleted server ' ${ hostnameStr } ` ) ;
return true ;
}
}
// Wasn't found on home computer
workerScript . log (
"deleteServer" ,
` Could not find server ${ server . hostname } as a purchased server. This is a bug. Report to dev. ` ,
) ;
return false ;
} ,
getPurchasedServers : function ( hostname = true ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getPurchasedServers" , getRamCost ( "getPurchasedServers" ) ) ;
2021-09-05 01:09:30 +02:00
var res = [ ] ;
Player . purchasedServers . forEach ( function ( ip ) {
if ( hostname ) {
var server = getServer ( ip ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getPurchasedServers" , "Could not find server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
res . push ( server . hostname ) ;
} else {
res . push ( ip ) ;
}
} ) ;
return res ;
} ,
write : function ( port , data = "" , mode = "a" ) {
updateDynamicRam ( "write" , getRamCost ( "write" ) ) ;
if ( ! isNaN ( port ) ) {
// Write to port
// Port 1-10
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"write" ,
` Trying to write to invalid port: ${ port } . Only ports 1- ${ CONSTANTS . NumNetscriptPorts } are valid. ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "write" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port . write ( data ) ;
} else if ( isString ( port ) ) {
// Write to script or text file
let fn = port ;
if ( ! isValidFilePath ( fn ) ) {
throw makeRuntimeErrorMsg ( "write" , ` Invalid filepath: ${ fn } ` ) ;
}
2017-08-03 06:21:15 +02:00
2021-09-05 01:09:30 +02:00
if ( fn . lastIndexOf ( "/" ) === 0 ) {
fn = removeLeadingSlash ( fn ) ;
}
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
// Coerce 'data' to be a string
try {
data = String ( data ) ;
} catch ( e ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "write" , ` Invalid data ( ${ e } ). Data being written must be convertible to a string ` ) ;
2021-09-05 01:09:30 +02:00
}
2018-05-23 02:09:04 +02:00
2021-09-05 01:09:30 +02:00
const server = workerScript . getServer ( ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "write" , "Error getting Server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
if ( isScriptFilename ( fn ) ) {
// Write to script
let script = workerScript . getScriptOnServer ( fn ) ;
if ( script == null ) {
// Create a new script
script = new Script ( fn , data , server . ip , server . scripts ) ;
server . scripts . push ( script ) ;
return true ;
}
mode === "w" ? ( script . code = data ) : ( script . code += data ) ;
script . updateRamUsage ( server . scripts ) ;
script . markUpdated ( ) ;
} else {
// Write to text file
let txtFile = getTextFile ( fn , server ) ;
if ( txtFile == null ) {
txtFile = createTextFile ( fn , data , server ) ;
return true ;
}
if ( mode === "w" ) {
txtFile . write ( data ) ;
} else {
txtFile . append ( data ) ;
}
}
return true ;
} else {
throw makeRuntimeErrorMsg ( "write" , ` Invalid argument: ${ port } ` ) ;
}
} ,
tryWrite : function ( port , data = "" ) {
updateDynamicRam ( "tryWrite" , getRamCost ( "tryWrite" ) ) ;
if ( ! isNaN ( port ) ) {
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"tryWrite" ,
` Invalid port: ${ port } . Only ports 1- ${ CONSTANTS . NumNetscriptPorts } are valid. ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "tryWrite" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port . tryWrite ( data ) ;
} else {
throw makeRuntimeErrorMsg ( "tryWrite" , ` Invalid argument: ${ port } ` ) ;
}
} ,
read : function ( port ) {
updateDynamicRam ( "read" , getRamCost ( "read" ) ) ;
if ( ! isNaN ( port ) ) {
// Read from port
// Port 1-10
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"read" ,
` Invalid port: ${ port } . Only ports 1- ${ CONSTANTS . NumNetscriptPorts } are valid. ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "read" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port . read ( ) ;
} else if ( isString ( port ) ) {
// Read from script or text file
let fn = port ;
let server = getServer ( workerScript . serverIp ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "read" , "Error getting Server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
if ( isScriptFilename ( fn ) ) {
// Read from script
let script = workerScript . getScriptOnServer ( fn ) ;
if ( script == null ) {
return "" ;
}
return script . code ;
} else {
// Read from text file
let txtFile = getTextFile ( fn , server ) ;
if ( txtFile !== null ) {
return txtFile . text ;
} else {
return "" ;
}
}
} else {
throw makeRuntimeErrorMsg ( "read" , ` Invalid argument: ${ port } ` ) ;
}
} ,
peek : function ( port ) {
updateDynamicRam ( "peek" , getRamCost ( "peek" ) ) ;
if ( isNaN ( port ) ) {
throw makeRuntimeErrorMsg (
"peek" ,
` Invalid argument. Must be a port number between 1 and ${ CONSTANTS . NumNetscriptPorts } , is ${ port } ` ,
) ;
}
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"peek" ,
` Invalid argument. Must be a port number between 1 and ${ CONSTANTS . NumNetscriptPorts } , is ${ port } ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "peek" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port . peek ( ) ;
} ,
clear : function ( port ) {
updateDynamicRam ( "clear" , getRamCost ( "clear" ) ) ;
if ( ! isNaN ( port ) ) {
// Clear port
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"clear" ,
` Trying to clear invalid port: ${ port } . Only ports 1- ${ CONSTANTS . NumNetscriptPorts } are valid ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "clear" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port . clear ( ) ;
} else if ( isString ( port ) ) {
// Clear text file
var fn = port ;
var server = getServer ( workerScript . serverIp ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "clear" , "Error getting Server. This is a bug. Report to dev." ) ;
2021-09-05 01:09:30 +02:00
}
var txtFile = getTextFile ( fn , server ) ;
if ( txtFile != null ) {
txtFile . write ( "" ) ;
}
} else {
throw makeRuntimeErrorMsg ( "clear" , ` Invalid argument: ${ port } ` ) ;
}
return 0 ;
} ,
getPortHandle : function ( port ) {
updateDynamicRam ( "getPortHandle" , getRamCost ( "getPortHandle" ) ) ;
if ( isNaN ( port ) ) {
throw makeRuntimeErrorMsg (
"getPortHandle" ,
` Invalid port: ${ port } Must be an integer between 1 and ${ CONSTANTS . NumNetscriptPorts } . ` ,
) ;
}
port = Math . round ( port ) ;
if ( port < 1 || port > CONSTANTS . NumNetscriptPorts ) {
throw makeRuntimeErrorMsg (
"getPortHandle" ,
` Invalid port: ${ port } . Only ports 1- ${ CONSTANTS . NumNetscriptPorts } are valid. ` ,
) ;
}
var port = NetscriptPorts [ port - 1 ] ;
if ( port == null || ! ( port instanceof NetscriptPort ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getPortHandle" , ` Could not find port: ${ port } . This is a bug. Report to dev. ` ) ;
2021-09-05 01:09:30 +02:00
}
return port ;
} ,
rm : function ( fn , ip ) {
updateDynamicRam ( "rm" , getRamCost ( "rm" ) ) ;
2017-08-03 06:21:15 +02:00
2021-09-05 01:09:30 +02:00
if ( ip == null || ip === "" ) {
ip = workerScript . serverIp ;
}
const s = safeGetServer ( ip , "rm" ) ;
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
const status = s . removeFile ( fn ) ;
if ( ! status . res ) {
workerScript . log ( "rm" , status . msg ) ;
}
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
return status . res ;
} ,
scriptRunning : function ( scriptname , ip ) {
updateDynamicRam ( "scriptRunning" , getRamCost ( "scriptRunning" ) ) ;
var server = getServer ( ip ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "scriptRunning" , ` Invalid IP/hostname: ${ ip } ` ) ;
2021-09-05 01:09:30 +02:00
}
for ( var i = 0 ; i < server . runningScripts . length ; ++ i ) {
if ( server . runningScripts [ i ] . filename == scriptname ) {
return true ;
}
}
return false ;
} ,
scriptKill : function ( scriptname , ip ) {
updateDynamicRam ( "scriptKill" , getRamCost ( "scriptKill" ) ) ;
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "scriptKill" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
var suc = false ;
for ( var i = 0 ; i < server . runningScripts . length ; ++ i ) {
if ( server . runningScripts [ i ] . filename == scriptname ) {
killWorkerScript ( server . runningScripts [ i ] , server . ip ) ;
suc = true ;
}
}
return suc ;
} ,
getScriptName : function ( ) {
return workerScript . name ;
} ,
getScriptRam : function ( scriptname , ip = workerScript . serverIp ) {
updateDynamicRam ( "getScriptRam" , getRamCost ( "getScriptRam" ) ) ;
var server = getServer ( ip ) ;
if ( server == null ) {
throw makeRuntimeErrorMsg ( "getScriptRam" , ` Invalid IP/hostname: ${ ip } ` ) ;
}
for ( var i = 0 ; i < server . scripts . length ; ++ i ) {
if ( server . scripts [ i ] . filename == scriptname ) {
return server . scripts [ i ] . ramUsage ;
}
}
return 0 ;
} ,
getRunningScript : function ( fn , ip ) {
updateDynamicRam ( "getRunningScript" , getRamCost ( "getRunningScript" ) ) ;
let runningScript ;
if ( arguments . length === 0 ) {
runningScript = workerScript . scriptRef ;
} else if ( typeof fn === "number" ) {
runningScript = getRunningScriptByPid ( fn , "getRunningScript" ) ;
} else {
const scriptArgs = [ ] ;
for ( var i = 2 ; i < arguments . length ; ++ i ) {
scriptArgs . push ( arguments [ i ] ) ;
}
2021-09-09 05:47:34 +02:00
runningScript = getRunningScript ( fn , ip , "getRunningScript" , scriptArgs ) ;
2021-09-05 01:09:30 +02:00
}
if ( runningScript === null ) return null ;
return {
args : runningScript . args . slice ( ) ,
filename : runningScript . filename ,
logs : runningScript . logs . slice ( ) ,
offlineExpGained : runningScript . offlineExpGained ,
offlineMoneyMade : runningScript . offlineMoneyMade ,
offlineRunningTime : runningScript . offlineRunningTime ,
onlineExpGained : runningScript . onlineExpGained ,
onlineMoneyMade : runningScript . onlineMoneyMade ,
onlineRunningTime : runningScript . onlineRunningTime ,
pid : runningScript . pid ,
ramUsage : runningScript . ramUsage ,
server : runningScript . server ,
threads : runningScript . threads ,
} ;
} ,
getHackTime : function ( ip ) {
updateDynamicRam ( "getHackTime" , getRamCost ( "getHackTime" ) ) ;
const server = safeGetServer ( ip , "getHackTime" ) ;
if ( failOnHacknetServer ( server , "getHackTime" ) ) {
return Infinity ;
}
2017-07-27 04:56:14 +02:00
2021-09-05 01:09:30 +02:00
return calculateHackingTime ( server , Player ) ; // Returns seconds
} ,
getGrowTime : function ( ip ) {
updateDynamicRam ( "getGrowTime" , getRamCost ( "getGrowTime" ) ) ;
const server = safeGetServer ( ip , "getGrowTime" ) ;
if ( failOnHacknetServer ( server , "getGrowTime" ) ) {
return Infinity ;
}
2018-11-14 07:05:51 +01:00
2021-09-05 01:09:30 +02:00
return calculateGrowTime ( server , Player ) ; // Returns seconds
} ,
getWeakenTime : function ( ip ) {
updateDynamicRam ( "getWeakenTime" , getRamCost ( "getWeakenTime" ) ) ;
const server = safeGetServer ( ip , "getWeakenTime" ) ;
if ( failOnHacknetServer ( server , "getWeakenTime" ) ) {
return Infinity ;
}
2018-01-27 07:52:39 +01:00
2021-09-05 01:09:30 +02:00
return calculateWeakenTime ( server , Player ) ; // Returns seconds
} ,
getScriptIncome : function ( scriptname , ip ) {
updateDynamicRam ( "getScriptIncome" , getRamCost ( "getScriptIncome" ) ) ;
if ( arguments . length === 0 ) {
var res = [ ] ;
// First element is total income of all currently running scripts
let total = 0 ;
for ( const script of workerScripts . values ( ) ) {
2021-09-09 05:47:34 +02:00
total += script . scriptRef . onlineMoneyMade / script . scriptRef . onlineRunningTime ;
2021-09-05 01:09:30 +02:00
}
res . push ( total ) ;
// Second element is total income you've earned from scripts since you installed Augs
2021-09-09 05:47:34 +02:00
res . push ( Player . scriptProdSinceLastAug / ( Player . playtimeSinceLastAug / 1000 ) ) ;
2021-09-05 01:09:30 +02:00
return res ;
} else {
// Get income for a particular script
var server = getServer ( ip ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getScriptIncome" , ` Invalid IP/hostnamed: ${ ip } ` ) ;
2021-09-05 01:09:30 +02:00
}
var argsForScript = [ ] ;
for ( var i = 2 ; i < arguments . length ; ++ i ) {
argsForScript . push ( arguments [ i ] ) ;
}
2021-09-09 05:47:34 +02:00
var runningScriptObj = findRunningScript ( scriptname , argsForScript , server ) ;
2021-09-05 01:09:30 +02:00
if ( runningScriptObj == null ) {
workerScript . log (
"getScriptIncome" ,
2021-09-09 05:47:34 +02:00
` No such script ' ${ scriptname } ' on ' ${ server . hostname } ' with args: ${ arrayToString ( argsForScript ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return - 1 ;
}
2021-09-09 05:47:34 +02:00
return runningScriptObj . onlineMoneyMade / runningScriptObj . onlineRunningTime ;
2021-09-05 01:09:30 +02:00
}
} ,
getScriptExpGain : function ( scriptname , ip ) {
updateDynamicRam ( "getScriptExpGain" , getRamCost ( "getScriptExpGain" ) ) ;
if ( arguments . length === 0 ) {
var total = 0 ;
for ( const ws of workerScripts . values ( ) ) {
2021-09-09 05:47:34 +02:00
total += ws . scriptRef . onlineExpGained / ws . scriptRef . onlineRunningTime ;
2021-09-05 01:09:30 +02:00
}
return total ;
} else {
// Get income for a particular script
var server = getServer ( ip ) ;
if ( server == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getScriptExpGain" , ` Invalid IP/hostnamed: ${ ip } ` ) ;
2021-09-05 01:09:30 +02:00
}
var argsForScript = [ ] ;
for ( var i = 2 ; i < arguments . length ; ++ i ) {
argsForScript . push ( arguments [ i ] ) ;
}
2021-09-09 05:47:34 +02:00
var runningScriptObj = findRunningScript ( scriptname , argsForScript , server ) ;
2021-09-05 01:09:30 +02:00
if ( runningScriptObj == null ) {
workerScript . log (
"getScriptExpGain" ,
2021-09-09 05:47:34 +02:00
` No such script ' ${ scriptname } ' on ' ${ server . hostname } ' with args: ${ arrayToString ( argsForScript ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return - 1 ;
}
2021-09-09 05:47:34 +02:00
return runningScriptObj . onlineExpGained / runningScriptObj . onlineRunningTime ;
2021-09-05 01:09:30 +02:00
}
} ,
nFormat : function ( n , format ) {
if ( isNaN ( n ) || isNaN ( parseFloat ( n ) ) || typeof format !== "string" ) {
return "" ;
}
2019-04-10 08:07:12 +02:00
2021-09-05 01:09:30 +02:00
return numeralWrapper . format ( parseFloat ( n ) , format ) ;
} ,
tFormat : function ( milliseconds , milliPrecision = false ) {
return convertTimeMsToTimeElapsedString ( milliseconds , milliPrecision ) ;
} ,
getTimeSinceLastAug : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getTimeSinceLastAug" , getRamCost ( "getTimeSinceLastAug" ) ) ;
2021-09-05 01:09:30 +02:00
return Player . playtimeSinceLastAug ;
} ,
prompt : function ( txt ) {
if ( ! isString ( txt ) ) {
txt = JSON . stringify ( txt ) ;
}
2019-05-14 10:35:37 +02:00
2021-09-05 01:09:30 +02:00
// The id for this popup will consist of the first 20 characters of the prompt string..
// Thats hopefully good enough to be unique
const popupId = ` prompt-popup- ${ txt . slice ( 0 , 20 ) } ` ;
const textElement = createElement ( "p" , { innerHTML : txt } ) ;
return new Promise ( function ( resolve ) {
const yesBtn = createElement ( "button" , {
class : "popup-box-button" ,
innerText : "Yes" ,
clickListener : ( ) => {
removeElementById ( popupId ) ;
resolve ( true ) ;
} ,
} ) ;
2019-05-14 10:35:37 +02:00
2021-09-05 01:09:30 +02:00
const noBtn = createElement ( "button" , {
class : "popup-box-button" ,
innerText : "No" ,
clickListener : ( ) => {
removeElementById ( popupId ) ;
resolve ( false ) ;
} ,
} ) ;
2019-05-14 10:35:37 +02:00
2021-09-05 01:09:30 +02:00
createPopup ( popupId , [ textElement , yesBtn , noBtn ] ) ;
} ) ;
} ,
wget : async function ( url , target , ip = workerScript . serverIp ) {
if ( ! isScriptFilename ( target ) && ! target . endsWith ( ".txt" ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "wget" , ` Invalid target file: ' ${ target } '. Must be a script or text file. ` ) ;
2021-09-05 01:09:30 +02:00
return Promise . resolve ( false ) ;
}
var s = safeGetServer ( ip , "wget" ) ;
return new Promise ( function ( resolve ) {
$ . get (
url ,
function ( data ) {
let res ;
if ( isScriptFilename ( target ) ) {
res = s . writeToScriptFile ( target , data ) ;
2017-09-15 16:06:59 +02:00
} else {
2021-09-05 01:09:30 +02:00
res = s . writeToTextFile ( target , data ) ;
}
if ( ! res . success ) {
workerScript . log ( "wget" , "Failed." ) ;
return resolve ( false ) ;
}
if ( res . overwritten ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "wget" , ` Successfully retrieved content and overwrote ' ${ target } ' on ' ${ ip } ' ` ) ;
2021-09-05 01:09:30 +02:00
return resolve ( true ) ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "wget" , ` Successfully retrieved content to new file ' ${ target } ' on ' ${ ip } ' ` ) ;
2021-09-05 01:09:30 +02:00
return resolve ( true ) ;
} ,
"text" ,
) . fail ( function ( e ) {
workerScript . log ( "wget" , JSON . stringify ( e ) ) ;
return resolve ( false ) ;
} ) ;
} ) ;
} ,
getFavorToDonate : function ( ) {
updateDynamicRam ( "getFavorToDonate" , getRamCost ( "getFavorToDonate" ) ) ;
2021-09-09 05:47:34 +02:00
return Math . floor ( CONSTANTS . BaseFavorToDonate * BitNodeMultipliers . RepToDonateToFaction ) ;
2021-09-05 01:09:30 +02:00
} ,
/* Singularity Functions */
universityCourse : function ( universityName , className ) {
updateDynamicRam ( "universityCourse" , getRamCost ( "universityCourse" ) ) ;
checkSingularityAccess ( "universityCourse" , 1 ) ;
if ( inMission ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "universityCourse" , "You are in the middle of a mission." ) ;
2021-09-05 01:09:30 +02:00
return ;
}
if ( Player . isWorking ) {
var txt = Player . singularityStopWork ( ) ;
workerScript . log ( "universityCourse" , txt ) ;
}
2017-08-21 18:59:06 +02:00
2021-09-05 01:09:30 +02:00
var costMult , expMult ;
switch ( universityName . toLowerCase ( ) ) {
case LocationName . AevumSummitUniversity . toLowerCase ( ) :
if ( Player . city != CityName . Aevum ) {
workerScript . log (
"universityCourse" ,
"You cannot study at 'Summit University' because you are not in 'Aevum'." ,
) ;
return false ;
}
Player . gotoLocation ( LocationName . AevumSummitUniversity ) ;
costMult = 4 ;
expMult = 3 ;
break ;
case LocationName . Sector12RothmanUniversity . toLowerCase ( ) :
if ( Player . city != CityName . Sector12 ) {
workerScript . log (
"universityCourse" ,
"You cannot study at 'Rothman University' because you are not in 'Sector-12'." ,
) ;
return false ;
}
Player . location = LocationName . Sector12RothmanUniversity ;
costMult = 3 ;
expMult = 2 ;
break ;
case LocationName . VolhavenZBInstituteOfTechnology . toLowerCase ( ) :
if ( Player . city != CityName . Volhaven ) {
workerScript . log (
"universityCourse" ,
"You cannot study at 'ZB Institute of Technology' because you are not in 'Volhaven'." ,
) ;
return false ;
}
Player . location = LocationName . VolhavenZBInstituteOfTechnology ;
costMult = 5 ;
expMult = 4 ;
break ;
default :
2021-09-09 05:47:34 +02:00
workerScript . log ( "universityCourse" , ` Invalid university name: ' ${ universityName } '. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
var task ;
switch ( className . toLowerCase ( ) ) {
case "Study Computer Science" . toLowerCase ( ) :
task = CONSTANTS . ClassStudyComputerScience ;
break ;
case "Data Structures" . toLowerCase ( ) :
task = CONSTANTS . ClassDataStructures ;
break ;
case "Networks" . toLowerCase ( ) :
task = CONSTANTS . ClassNetworks ;
break ;
case "Algorithms" . toLowerCase ( ) :
task = CONSTANTS . ClassAlgorithms ;
break ;
case "Management" . toLowerCase ( ) :
task = CONSTANTS . ClassManagement ;
break ;
case "Leadership" . toLowerCase ( ) :
task = CONSTANTS . ClassLeadership ;
break ;
default :
2021-09-09 05:47:34 +02:00
workerScript . log ( "universityCourse" , ` Invalid class name: ${ className } . ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . startClass ( costMult , expMult , task ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "universityCourse" , ` Started ${ task } at ${ universityName } ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
} ,
gymWorkout : function ( gymName , stat ) {
updateDynamicRam ( "gymWorkout" , getRamCost ( "gymWorkout" ) ) ;
checkSingularityAccess ( "gymWorkout" , 1 ) ;
if ( inMission ) {
workerScript . log ( "gymWorkout" , "You are in the middle of a mission." ) ;
return ;
}
if ( Player . isWorking ) {
var txt = Player . singularityStopWork ( ) ;
workerScript . log ( "gymWorkout" , txt ) ;
}
var costMult , expMult ;
switch ( gymName . toLowerCase ( ) ) {
case LocationName . AevumCrushFitnessGym . toLowerCase ( ) :
if ( Player . city != CityName . Aevum ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "gymWorkout" , "You cannot workout at 'Crush Fitness' because you are not in 'Aevum'." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . location = LocationName . AevumCrushFitnessGym ;
costMult = 3 ;
expMult = 2 ;
break ;
case LocationName . AevumSnapFitnessGym . toLowerCase ( ) :
if ( Player . city != CityName . Aevum ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "gymWorkout" , "You cannot workout at 'Snap Fitness' because you are not in 'Aevum'." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . location = LocationName . AevumSnapFitnessGym ;
costMult = 10 ;
expMult = 5 ;
break ;
case LocationName . Sector12IronGym . toLowerCase ( ) :
if ( Player . city != CityName . Sector12 ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "gymWorkout" , "You cannot workout at 'Iron Gym' because you are not in 'Sector-12'." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . location = LocationName . Sector12IronGym ;
costMult = 1 ;
expMult = 1 ;
break ;
case LocationName . Sector12PowerhouseGym . toLowerCase ( ) :
if ( Player . city != CityName . Sector12 ) {
workerScript . log (
"gymWorkout" ,
"You cannot workout at 'Powerhouse Gym' because you are not in 'Sector-12'." ,
) ;
return false ;
}
Player . location = LocationName . Sector12PowerhouseGym ;
costMult = 20 ;
expMult = 10 ;
break ;
case LocationName . VolhavenMilleniumFitnessGym . toLowerCase ( ) :
if ( Player . city != CityName . Volhaven ) {
workerScript . log (
"gymWorkout" ,
"You cannot workout at 'Millenium Fitness Gym' because you are not in 'Volhaven'." ,
) ;
return false ;
}
Player . location = LocationName . VolhavenMilleniumFitnessGym ;
costMult = 7 ;
expMult = 4 ;
break ;
default :
2021-09-09 05:47:34 +02:00
workerScript . log ( "gymWorkout" , ` Invalid gym name: ${ gymName } . gymWorkout() failed ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2017-08-22 20:48:04 +02:00
2021-09-05 01:09:30 +02:00
switch ( stat . toLowerCase ( ) ) {
case "strength" . toLowerCase ( ) :
case "str" . toLowerCase ( ) :
Player . startClass ( costMult , expMult , CONSTANTS . ClassGymStrength ) ;
break ;
case "defense" . toLowerCase ( ) :
case "def" . toLowerCase ( ) :
Player . startClass ( costMult , expMult , CONSTANTS . ClassGymDefense ) ;
break ;
case "dexterity" . toLowerCase ( ) :
case "dex" . toLowerCase ( ) :
Player . startClass ( costMult , expMult , CONSTANTS . ClassGymDexterity ) ;
break ;
case "agility" . toLowerCase ( ) :
case "agi" . toLowerCase ( ) :
Player . startClass ( costMult , expMult , CONSTANTS . ClassGymAgility ) ;
break ;
default :
workerScript . log ( "gymWorkout" , ` Invalid stat: ${ stat } . ` ) ;
return false ;
}
workerScript . log ( "gymWorkout" , ` Started training ${ stat } at ${ gymName } ` ) ;
return true ;
} ,
travelToCity : function ( cityname ) {
updateDynamicRam ( "travelToCity" , getRamCost ( "travelToCity" ) ) ;
checkSingularityAccess ( "travelToCity" , 1 ) ;
switch ( cityname ) {
case CityName . Aevum :
case CityName . Chongqing :
case CityName . Sector12 :
case CityName . NewTokyo :
case CityName . Ishima :
case CityName . Volhaven :
if ( Player . money . lt ( CONSTANTS . TravelCost ) ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "travelToCity" , "Not enough money to travel." ) ;
2021-09-05 01:09:30 +02:00
}
Player . loseMoney ( CONSTANTS . TravelCost ) ;
Player . city = cityname ;
workerScript . log ( "travelToCity" , ` Traveled to ${ cityname } ` ) ;
return true ;
default :
workerScript . log ( "travelToCity" , ` Invalid city name: ' ${ cityname } '. ` ) ;
return false ;
}
} ,
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
purchaseTor : function ( ) {
updateDynamicRam ( "purchaseTor" , getRamCost ( "purchaseTor" ) ) ;
checkSingularityAccess ( "purchaseTor" , 1 ) ;
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( SpecialServerIps [ "Darkweb Server" ] != null ) {
workerScript . log ( "purchaseTor" , "You already have a TOR router!" ) ;
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . money . lt ( CONSTANTS . TorRouterCost ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseTor" , "You cannot afford to purchase a Tor router." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . loseMoney ( CONSTANTS . TorRouterCost ) ;
var darkweb = safetlyCreateUniqueServer ( {
ip : createUniqueRandomIp ( ) ,
hostname : "darkweb" ,
organizationName : "" ,
isConnectedTo : false ,
adminRights : false ,
purchasedByPlayer : false ,
maxRam : 1 ,
} ) ;
AddToAllServers ( darkweb ) ;
SpecialServerIps . addIp ( "Darkweb Server" , darkweb . ip ) ;
Player . getHomeComputer ( ) . serversOnNetwork . push ( darkweb . ip ) ;
darkweb . serversOnNetwork . push ( Player . getHomeComputer ( ) . ip ) ;
Player . gainIntelligenceExp ( CONSTANTS . IntelligenceSingFnBaseExpGain ) ;
workerScript . log ( "purchaseTor" , "You have purchased a Tor router!" ) ;
return true ;
} ,
purchaseProgram : function ( programName ) {
updateDynamicRam ( "purchaseProgram" , getRamCost ( "purchaseProgram" ) ) ;
checkSingularityAccess ( "purchaseProgram" , 1 ) ;
if ( SpecialServerIps [ "Darkweb Server" ] == null ) {
workerScript . log ( "purchaseProgram" , "You do not have the TOR router." ) ;
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
programName = programName . toLowerCase ( ) ;
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
let item = null ;
for ( const key in DarkWebItems ) {
const i = DarkWebItems [ key ] ;
if ( i . program . toLowerCase ( ) == programName ) {
item = i ;
}
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( item == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseProgram" , ` Invalid program name: ' ${ programName } . ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . money . lt ( item . price ) ) {
workerScript . log (
"purchaseProgram" ,
2021-09-09 05:47:34 +02:00
` Not enough money to purchase ' ${ item . program } '. Need ${ numeralWrapper . formatMoney ( item . price ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . hasProgram ( item . program ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseProgram" , ` You already have the ' ${ item . program } ' program ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
Player . loseMoney ( item . price ) ;
Player . getHomeComputer ( ) . programs . push ( item . program ) ;
workerScript . log (
"purchaseProgram" ,
` You have purchased the ' ${ item . program } ' program. The new program can be found on your home computer. ` ,
) ;
return true ;
} ,
getCurrentServer : function ( ) {
updateDynamicRam ( "getCurrentServer" , getRamCost ( "getCurrentServer" ) ) ;
checkSingularityAccess ( "getCurrentServer" , 1 ) ;
return Player . getCurrentServer ( ) . hostname ;
} ,
connect : function ( hostname ) {
updateDynamicRam ( "connect" , getRamCost ( "connect" ) ) ;
checkSingularityAccess ( "connect" , 1 ) ;
if ( ! hostname ) {
throw makeRuntimeErrorMsg ( "connect" , ` Invalid hostname: ' ${ hostname } ' ` ) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
let target = getServer ( hostname ) ;
if ( target == null ) {
throw makeRuntimeErrorMsg ( "connect" , ` Invalid hostname: ' ${ hostname } ' ` ) ;
return ;
}
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
if ( hostname === "home" ) {
Player . getCurrentServer ( ) . isConnectedTo = false ;
Player . currentServer = Player . getHomeComputer ( ) . ip ;
Player . getCurrentServer ( ) . isConnectedTo = true ;
2021-09-16 08:52:45 +02:00
Terminal . setcwd ( "/" ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
const server = Player . getCurrentServer ( ) ;
for ( let i = 0 ; i < server . serversOnNetwork . length ; i ++ ) {
const other = getServerOnNetwork ( server , i ) ;
if ( other . ip == hostname || other . hostname == hostname ) {
Player . getCurrentServer ( ) . isConnectedTo = false ;
Player . currentServer = target . ip ;
Player . getCurrentServer ( ) . isConnectedTo = true ;
2021-09-16 08:52:45 +02:00
Terminal . setcwd ( "/" ) ;
2021-09-05 01:09:30 +02:00
return true ;
}
}
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
return false ;
} ,
manualHack : function ( ) {
updateDynamicRam ( "manualHack" , getRamCost ( "manualHack" ) ) ;
checkSingularityAccess ( "manualHack" , 1 ) ;
const server = Player . getCurrentServer ( ) ;
return hack ( server . hostname , true ) ;
} ,
installBackdoor : function ( ) {
updateDynamicRam ( "installBackdoor" , getRamCost ( "installBackdoor" ) ) ;
checkSingularityAccess ( "installBackdoor" , 1 ) ;
const server = Player . getCurrentServer ( ) ;
const installTime = ( calculateHackingTime ( server , Player ) / 4 ) * 1000 ;
// No root access or skill level too low
const canHack = netscriptCanHack ( server , Player ) ;
if ( ! canHack . res ) {
throw makeRuntimeErrorMsg ( "installBackdoor" , canHack . msg ) ;
}
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
workerScript . log (
"installBackdoor" ,
2021-09-09 05:47:34 +02:00
` Installing backdoor on ' ${ server . hostname } ' in ${ convertTimeMsToTimeElapsedString ( installTime , true ) } ` ,
2021-09-05 01:09:30 +02:00
) ;
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
return netscriptDelay ( installTime , workerScript ) . then ( function ( ) {
if ( workerScript . env . stopFlag ) {
return Promise . reject ( workerScript ) ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "installBackdoor" , ` Successfully installed backdoor on ' ${ server . hostname } ' ` ) ;
2021-09-05 01:09:30 +02:00
server . backdoorInstalled = true ;
return Promise . resolve ( ) ;
} ) ;
} ,
getStats : function ( ) {
updateDynamicRam ( "getStats" , getRamCost ( "getStats" ) ) ;
checkSingularityAccess ( "getStats" , 1 ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "getStats" , ` getStats is deprecated, please use getPlayer ` ) ;
2021-09-05 01:09:30 +02:00
return {
hacking : Player . hacking _skill ,
strength : Player . strength ,
defense : Player . defense ,
dexterity : Player . dexterity ,
agility : Player . agility ,
charisma : Player . charisma ,
intelligence : Player . intelligence ,
} ;
} ,
getCharacterInformation : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCharacterInformation" , getRamCost ( "getCharacterInformation" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getCharacterInformation" , 1 ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "getCharacterInformation" , ` getCharacterInformation is deprecated, please use getPlayer ` ) ;
2021-09-05 01:09:30 +02:00
return {
bitnode : Player . bitNodeN ,
city : Player . city ,
factions : Player . factions . slice ( ) ,
hp : Player . hp ,
jobs : Object . keys ( Player . jobs ) ,
jobTitles : Object . values ( Player . jobs ) ,
maxHp : Player . max _hp ,
mult : {
agility : Player . agility _mult ,
agilityExp : Player . agility _exp _mult ,
companyRep : Player . company _rep _mult ,
crimeMoney : Player . crime _money _mult ,
crimeSuccess : Player . crime _success _mult ,
defense : Player . defense _mult ,
defenseExp : Player . defense _exp _mult ,
dexterity : Player . dexterity _mult ,
dexterityExp : Player . dexterity _exp _mult ,
factionRep : Player . faction _rep _mult ,
hacking : Player . hacking _mult ,
hackingExp : Player . hacking _exp _mult ,
strength : Player . strength _mult ,
strengthExp : Player . strength _exp _mult ,
workMoney : Player . work _money _mult ,
} ,
timeWorked : Player . timeWorked ,
tor : SpecialServerIps . hasOwnProperty ( "Darkweb Server" ) ,
workHackExpGain : Player . workHackExpGained ,
workStrExpGain : Player . workStrExpGained ,
workDefExpGain : Player . workDefExpGained ,
workDexExpGain : Player . workDexExpGained ,
workAgiExpGain : Player . workAgiExpGained ,
workChaExpGain : Player . workChaExpGained ,
workRepGain : Player . workRepGained ,
workMoneyGain : Player . workMoneyGained ,
hackingExp : Player . hacking _exp ,
strengthExp : Player . strength _exp ,
defenseExp : Player . defense _exp ,
dexterityExp : Player . dexterity _exp ,
agilityExp : Player . agility _exp ,
charismaExp : Player . charisma _exp ,
} ;
} ,
getPlayer : function ( ) {
updateDynamicRam ( "getPlayer" , getRamCost ( "getPlayer" ) ) ;
const data = {
hacking _skill : Player . hacking _skill ,
hp : Player . hp ,
max _hp : Player . max _hp ,
strength : Player . strength ,
defense : Player . defense ,
dexterity : Player . dexterity ,
agility : Player . agility ,
charisma : Player . charisma ,
intelligence : Player . intelligence ,
hacking _chance _mult : Player . hacking _chance _mult ,
hacking _speed _mult : Player . hacking _speed _mult ,
hacking _money _mult : Player . hacking _money _mult ,
hacking _grow _mult : Player . hacking _grow _mult ,
hacking _exp : Player . hacking _exp ,
strength _exp : Player . strength _exp ,
defense _exp : Player . defense _exp ,
dexterity _exp : Player . dexterity _exp ,
agility _exp : Player . agility _exp ,
charisma _exp : Player . charisma _exp ,
hacking _mult : Player . hacking _mult ,
strength _mult : Player . strength _mult ,
defense _mult : Player . defense _mult ,
dexterity _mult : Player . dexterity _mult ,
agility _mult : Player . agility _mult ,
charisma _mult : Player . charisma _mult ,
hacking _exp _mult : Player . hacking _exp _mult ,
strength _exp _mult : Player . strength _exp _mult ,
defense _exp _mult : Player . defense _exp _mult ,
dexterity _exp _mult : Player . dexterity _exp _mult ,
agility _exp _mult : Player . agility _exp _mult ,
charisma _exp _mult : Player . charisma _exp _mult ,
company _rep _mult : Player . company _rep _mult ,
faction _rep _mult : Player . faction _rep _mult ,
numPeopleKilled : Player . numPeopleKilled ,
money : Player . money . toNumber ( ) ,
city : Player . city ,
location : Player . location ,
2021-09-13 23:11:02 +02:00
companyName : Player . companyName ,
2021-09-05 01:09:30 +02:00
crime _money _mult : Player . crime _money _mult ,
crime _success _mult : Player . crime _success _mult ,
isWorking : Player . isWorking ,
workType : Player . workType ,
currentWorkFactionName : Player . currentWorkFactionName ,
currentWorkFactionDescription : Player . currentWorkFactionDescription ,
workHackExpGainRate : Player . workHackExpGainRate ,
workStrExpGainRate : Player . workStrExpGainRate ,
workDefExpGainRate : Player . workDefExpGainRate ,
workDexExpGainRate : Player . workDexExpGainRate ,
workAgiExpGainRate : Player . workAgiExpGainRate ,
workChaExpGainRate : Player . workChaExpGainRate ,
workRepGainRate : Player . workRepGainRate ,
workMoneyGainRate : Player . workMoneyGainRate ,
workMoneyLossRate : Player . workMoneyLossRate ,
workHackExpGained : Player . workHackExpGained ,
workStrExpGained : Player . workStrExpGained ,
workDefExpGained : Player . workDefExpGained ,
workDexExpGained : Player . workDexExpGained ,
workAgiExpGained : Player . workAgiExpGained ,
workChaExpGained : Player . workChaExpGained ,
workRepGained : Player . workRepGained ,
workMoneyGained : Player . workMoneyGained ,
createProgramName : Player . createProgramName ,
createProgramReqLvl : Player . createProgramReqLvl ,
className : Player . className ,
crimeType : Player . crimeType ,
work _money _mult : Player . work _money _mult ,
hacknet _node _money _mult : Player . hacknet _node _money _mult ,
hacknet _node _purchase _cost _mult : Player . hacknet _node _purchase _cost _mult ,
hacknet _node _ram _cost _mult : Player . hacknet _node _ram _cost _mult ,
hacknet _node _core _cost _mult : Player . hacknet _node _core _cost _mult ,
hacknet _node _level _cost _mult : Player . hacknet _node _level _cost _mult ,
hasWseAccount : Player . hasWseAccount ,
hasTixApiAccess : Player . hasTixApiAccess ,
has4SData : Player . has4SData ,
has4SDataTixApi : Player . has4SDataTixApi ,
bladeburner _max _stamina _mult : Player . bladeburner _max _stamina _mult ,
bladeburner _stamina _gain _mult : Player . bladeburner _stamina _gain _mult ,
bladeburner _analysis _mult : Player . bladeburner _analysis _mult ,
bladeburner _success _chance _mult : Player . bladeburner _success _chance _mult ,
bitNodeN : Player . bitNodeN ,
totalPlaytime : Player . totalPlaytime ,
playtimeSinceLastAug : Player . playtimeSinceLastAug ,
playtimeSinceLastBitnode : Player . playtimeSinceLastBitnode ,
jobs : { } ,
factions : Player . factions . slice ( ) ,
tor : SpecialServerIps . hasOwnProperty ( "Darkweb Server" ) ,
} ;
Object . assign ( data . jobs , Player . jobs ) ;
return data ;
} ,
hospitalize : function ( ) {
updateDynamicRam ( "hospitalize" , getRamCost ( "hospitalize" ) ) ;
checkSingularityAccess ( "hospitalize" , 1 ) ;
return Player . hospitalize ( ) ;
} ,
isBusy : function ( ) {
updateDynamicRam ( "isBusy" , getRamCost ( "isBusy" ) ) ;
checkSingularityAccess ( "isBusy" , 1 ) ;
return Player . isWorking || inMission ;
} ,
stopAction : function ( ) {
updateDynamicRam ( "stopAction" , getRamCost ( "stopAction" ) ) ;
checkSingularityAccess ( "stopAction" , 1 ) ;
if ( Player . isWorking ) {
var txt = Player . singularityStopWork ( ) ;
workerScript . log ( "stopAction" , txt ) ;
return true ;
}
return false ;
} ,
upgradeHomeRam : function ( ) {
updateDynamicRam ( "upgradeHomeRam" , getRamCost ( "upgradeHomeRam" ) ) ;
checkSingularityAccess ( "upgradeHomeRam" , 2 ) ;
// Check if we're at max RAM
const homeComputer = Player . getHomeComputer ( ) ;
if ( homeComputer . maxRam >= CONSTANTS . HomeComputerMaxRam ) {
workerScript . log ( "upgradeHomeRam" , ` Your home computer is at max RAM. ` ) ;
return false ;
}
2018-06-01 23:05:05 +02:00
2021-09-05 01:09:30 +02:00
const cost = Player . getUpgradeHomeRamCost ( ) ;
if ( Player . money . lt ( cost ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "upgradeHomeRam" , ` You don't have enough money. Need ${ numeralWrapper . formatMoney ( cost ) } ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2021-03-24 02:30:15 +01:00
2021-09-05 01:09:30 +02:00
homeComputer . maxRam *= 2 ;
Player . loseMoney ( cost ) ;
Player . gainIntelligenceExp ( CONSTANTS . IntelligenceSingFnBaseExpGain ) ;
workerScript . log (
"upgradeHomeRam" ,
` Purchased additional RAM for home computer! It now has ${ homeComputer . maxRam } GB of RAM. ` ,
) ;
return true ;
} ,
getUpgradeHomeRamCost : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getUpgradeHomeRamCost" , getRamCost ( "getUpgradeHomeRamCost" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getUpgradeHomeRamCost" , 2 ) ;
return Player . getUpgradeHomeRamCost ( ) ;
} ,
workForCompany : function ( companyName ) {
updateDynamicRam ( "workForCompany" , getRamCost ( "workForCompany" ) ) ;
checkSingularityAccess ( "workForCompany" , 2 ) ;
// Sanitize input
if ( companyName == null ) {
companyName = Player . companyName ;
}
2021-03-24 02:30:15 +01:00
2021-09-05 01:09:30 +02:00
// Make sure its a valid company
2021-09-09 05:47:34 +02:00
if ( companyName == null || companyName === "" || ! ( Companies [ companyName ] instanceof Company ) ) {
2021-09-05 01:09:30 +02:00
workerScript . log ( "workForCompany" , ` Invalid company: ' ${ companyName } ' ` ) ;
return false ;
}
2021-03-24 02:30:15 +01:00
2021-09-05 01:09:30 +02:00
// Make sure player is actually employed at the comapny
if ( ! Object . keys ( Player . jobs ) . includes ( companyName ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForCompany" , ` You do not have a job at ' ${ companyName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2021-03-24 02:30:15 +01:00
2021-09-05 01:09:30 +02:00
// Cant work while in a mission
if ( inMission ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForCompany" , "You are in the middle of a mission." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2021-05-07 08:09:30 +02:00
2021-09-05 01:09:30 +02:00
// Check to make sure company position data is valid
const companyPositionName = Player . jobs [ companyName ] ;
const companyPosition = CompanyPositions [ companyPositionName ] ;
2021-09-09 05:47:34 +02:00
if ( companyPositionName === "" || ! ( companyPosition instanceof CompanyPosition ) ) {
2021-09-05 01:09:30 +02:00
workerScript . log ( "workForCompany" , "You do not have a job" ) ;
return false ;
}
2021-05-07 08:09:30 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . isWorking ) {
var txt = Player . singularityStopWork ( ) ;
workerScript . log ( "workForCompany" , txt ) ;
}
2021-05-07 08:09:30 +02:00
2021-09-05 01:09:30 +02:00
if ( companyPosition . isPartTimeJob ( ) ) {
Player . startWorkPartTime ( companyName ) ;
} else {
Player . startWork ( companyName ) ;
}
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForCompany" , ` Began working at ' ${ Player . companyName } ' as a ' ${ companyPositionName } ' ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
} ,
applyToCompany : function ( companyName , field ) {
updateDynamicRam ( "applyToCompany" , getRamCost ( "applyToCompany" ) ) ;
checkSingularityAccess ( "applyToCompany" , 2 ) ;
getCompany ( "applyToCompany" , companyName ) ;
Player . location = companyName ;
var res ;
switch ( field . toLowerCase ( ) ) {
case "software" :
res = Player . applyForSoftwareJob ( true ) ;
break ;
case "software consultant" :
res = Player . applyForSoftwareConsultantJob ( true ) ;
break ;
case "it" :
res = Player . applyForItJob ( true ) ;
break ;
case "security engineer" :
res = Player . applyForSecurityEngineerJob ( true ) ;
break ;
case "network engineer" :
res = Player . applyForNetworkEngineerJob ( true ) ;
break ;
case "business" :
res = Player . applyForBusinessJob ( true ) ;
break ;
case "business consultant" :
res = Player . applyForBusinessConsultantJob ( true ) ;
break ;
case "security" :
res = Player . applyForSecurityJob ( true ) ;
break ;
case "agent" :
res = Player . applyForAgentJob ( true ) ;
break ;
case "employee" :
res = Player . applyForEmployeeJob ( true ) ;
break ;
case "part-time employee" :
res = Player . applyForPartTimeEmployeeJob ( true ) ;
break ;
case "waiter" :
res = Player . applyForWaiterJob ( true ) ;
break ;
case "part-time waiter" :
res = Player . applyForPartTimeWaiterJob ( true ) ;
break ;
default :
workerScript . log ( "applyToCompany" , ` Invalid job: ' ${ field } '. ` ) ;
return false ;
}
// The Player object's applyForJob function can return string with special error messages
if ( isString ( res ) ) {
workerScript . log ( "applyToCompany" , res ) ;
return false ;
}
if ( res ) {
workerScript . log (
"applyToCompany" ,
` You were offered a new job at ' ${ companyName } ' as a ' ${ Player . jobs [ companyName ] } ' ` ,
) ;
} else {
workerScript . log (
"applyToCompany" ,
` You failed to get a new job/promotion at ' ${ companyName } ' in the ' ${ field } ' field. ` ,
) ;
}
return res ;
} ,
getCompanyRep : function ( companyName ) {
updateDynamicRam ( "getCompanyRep" , getRamCost ( "getCompanyRep" ) ) ;
checkSingularityAccess ( "getCompanyRep" , 2 ) ;
const company = getCompany ( "getCompanyRep" , companyName ) ;
return company . playerReputation ;
} ,
getCompanyFavor : function ( companyName ) {
updateDynamicRam ( "getCompanyFavor" , getRamCost ( "getCompanyFavor" ) ) ;
checkSingularityAccess ( "getCompanyFavor" , 2 ) ;
const company = getCompany ( "getCompanyFavor" , companyName ) ;
return company . favor ;
} ,
getCompanyFavorGain : function ( companyName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCompanyFavorGain" , getRamCost ( "getCompanyFavorGain" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getCompanyFavorGain" , 2 ) ;
const company = getCompany ( "getCompanyFavorGain" , companyName ) ;
return company . getFavorGain ( ) [ 0 ] ;
} ,
checkFactionInvitations : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "checkFactionInvitations" , getRamCost ( "checkFactionInvitations" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "checkFactionInvitations" , 2 ) ;
// Make a copy of Player.factionInvitations
return Player . factionInvitations . slice ( ) ;
} ,
joinFaction : function ( name ) {
updateDynamicRam ( "joinFaction" , getRamCost ( "joinFaction" ) ) ;
checkSingularityAccess ( "joinFaction" , 2 ) ;
getFaction ( "joinFaction" , name ) ;
if ( ! Player . factionInvitations . includes ( name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "joinFaction" , ` You have not been invited by faction ' ${ name } ' ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
const fac = Factions [ name ] ;
joinFaction ( fac ) ;
// Update Faction Invitation list to account for joined + banned factions
for ( let i = 0 ; i < Player . factionInvitations . length ; ++ i ) {
2021-09-09 05:47:34 +02:00
if ( Player . factionInvitations [ i ] == name || Factions [ Player . factionInvitations [ i ] ] . isBanned ) {
2021-09-05 01:09:30 +02:00
Player . factionInvitations . splice ( i , 1 ) ;
i -- ;
}
}
Player . gainIntelligenceExp ( CONSTANTS . IntelligenceSingFnBaseExpGain ) ;
workerScript . log ( "joinFaction" , ` Joined the ' ${ name } ' faction. ` ) ;
return true ;
} ,
workForFaction : function ( name , type ) {
updateDynamicRam ( "workForFaction" , getRamCost ( "workForFaction" ) ) ;
checkSingularityAccess ( "workForFaction" , 2 ) ;
getFaction ( "workForFaction" , name ) ;
// if the player is in a gang and the target faction is any of the gang faction, fail
if ( Player . inGang ( ) && AllGangs [ name ] !== undefined ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Faction ' ${ name } ' does not offer work at the moment. ` ) ;
2021-09-05 01:09:30 +02:00
return ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( inMission ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , "You are in the middle of a mission." ) ;
2021-09-05 01:09:30 +02:00
return ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( ! Player . factions . includes ( name ) ) {
workerScript . log ( "workForFaction" , ` You are not a member of ' ${ name } ' ` ) ;
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( Player . isWorking ) {
const txt = Player . singularityStopWork ( ) ;
workerScript . log ( "workForFaction" , txt ) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
var fac = Factions [ name ] ;
// Arrays listing factions that allow each time of work
var hackAvailable = [
"Illuminati" ,
"Daedalus" ,
"The Covenant" ,
"ECorp" ,
"MegaCorp" ,
"Bachman & Associates" ,
"Blade Industries" ,
"NWO" ,
"Clarke Incorporated" ,
"OmniTek Incorporated" ,
"Four Sigma" ,
"KuaiGong International" ,
"Fulcrum Secret Technologies" ,
"BitRunners" ,
"The Black Hand" ,
"NiteSec" ,
"Chongqing" ,
"Sector-12" ,
"New Tokyo" ,
"Aevum" ,
"Ishima" ,
"Volhaven" ,
"Speakers for the Dead" ,
"The Dark Army" ,
"The Syndicate" ,
"Silhouette" ,
"Netburners" ,
"Tian Di Hui" ,
"CyberSec" ,
] ;
var fdWkAvailable = [
"Illuminati" ,
"Daedalus" ,
"The Covenant" ,
"ECorp" ,
"MegaCorp" ,
"Bachman & Associates" ,
"Blade Industries" ,
"NWO" ,
"Clarke Incorporated" ,
"OmniTek Incorporated" ,
"Four Sigma" ,
"KuaiGong International" ,
"The Black Hand" ,
"Chongqing" ,
"Sector-12" ,
"New Tokyo" ,
"Aevum" ,
"Ishima" ,
"Volhaven" ,
"Speakers for the Dead" ,
"The Dark Army" ,
"The Syndicate" ,
"Silhouette" ,
"Tetrads" ,
"Slum Snakes" ,
] ;
var scWkAvailable = [
"ECorp" ,
"MegaCorp" ,
"Bachman & Associates" ,
"Blade Industries" ,
"NWO" ,
"Clarke Incorporated" ,
"OmniTek Incorporated" ,
"Four Sigma" ,
"KuaiGong International" ,
"Fulcrum Secret Technologies" ,
"Chongqing" ,
"Sector-12" ,
"New Tokyo" ,
"Aevum" ,
"Ishima" ,
"Volhaven" ,
"Speakers for the Dead" ,
"The Syndicate" ,
"Tetrads" ,
"Slum Snakes" ,
"Tian Di Hui" ,
] ;
switch ( type . toLowerCase ( ) ) {
case "hacking" :
case "hacking contracts" :
case "hackingcontracts" :
if ( ! hackAvailable . includes ( fac . name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Faction ' ${ fac . name } ' do not need help with hacking contracts. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . startFactionHackWork ( fac ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Started carrying out hacking contracts for ' ${ fac . name } ' ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
case "field" :
case "fieldwork" :
case "field work" :
if ( ! fdWkAvailable . includes ( fac . name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Faction ' ${ fac . name } ' do not need help with field missions. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . startFactionFieldWork ( fac ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Started carrying out field missions for ' ${ fac . name } ' ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
case "security" :
case "securitywork" :
case "security work" :
if ( ! scWkAvailable . includes ( fac . name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Faction ' ${ fac . name } ' do not need help with security work. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . startFactionSecurityWork ( fac ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "workForFaction" , ` Started carrying out security work for ' ${ fac . name } ' ` ) ;
2021-09-05 01:09:30 +02:00
return true ;
default :
workerScript . log ( "workForFaction" , ` Invalid work type: ' ${ type } ` ) ;
}
return true ;
} ,
getFactionRep : function ( name ) {
updateDynamicRam ( "getFactionRep" , getRamCost ( "getFactionRep" ) ) ;
checkSingularityAccess ( "getFactionRep" , 2 ) ;
const faction = getFaction ( "getFactionRep" , name ) ;
return faction . playerReputation ;
} ,
getFactionFavor : function ( name ) {
updateDynamicRam ( "getFactionFavor" , getRamCost ( "getFactionFavor" ) ) ;
checkSingularityAccess ( "getFactionFavor" , 2 ) ;
const faction = getFaction ( "getFactionFavor" , name ) ;
return faction . favor ;
} ,
getFactionFavorGain : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getFactionFavorGain" , getRamCost ( "getFactionFavorGain" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getFactionFavorGain" , 2 ) ;
const faction = getFaction ( "getFactionFavorGain" , name ) ;
return faction . getFavorGain ( ) [ 0 ] ;
} ,
donateToFaction : function ( name , amt ) {
updateDynamicRam ( "donateToFaction" , getRamCost ( "donateToFaction" ) ) ;
checkSingularityAccess ( "donateToFaction" , 3 ) ;
const faction = getFaction ( "donateToFaction" , name ) ;
if ( typeof amt !== "number" || amt <= 0 ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "donateToFaction" , ` Invalid donation amount: ' ${ amt } '. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
if ( Player . money . lt ( amt ) ) {
workerScript . log (
"donateToFaction" ,
2021-09-09 05:47:34 +02:00
` You do not have enough money to donate ${ numeralWrapper . formatMoney ( amt ) } to ' ${ name } ' ` ,
2021-09-05 01:09:30 +02:00
) ;
return false ;
}
2021-09-09 05:47:34 +02:00
const repNeededToDonate = Math . round ( CONSTANTS . BaseFavorToDonate * BitNodeMultipliers . RepToDonateToFaction ) ;
2021-09-05 01:09:30 +02:00
if ( faction . favor < repNeededToDonate ) {
workerScript . log (
"donateToFaction" ,
` You do not have enough favor to donate to this faction. Have ${ faction . favor } , need ${ repNeededToDonate } ` ,
) ;
return false ;
}
2021-09-09 05:47:34 +02:00
const repGain = ( amt / CONSTANTS . DonateMoneyToRepDivisor ) * Player . faction _rep _mult ;
2021-09-05 01:09:30 +02:00
faction . playerReputation += repGain ;
Player . loseMoney ( amt ) ;
workerScript . log (
"donateToFaction" ,
2021-09-09 05:47:34 +02:00
` ${ numeralWrapper . formatMoney ( amt ) } donated to ' ${ name } ' for ${ numeralWrapper . formatReputation (
2021-09-05 01:09:30 +02:00
repGain ,
) } reputation ` ,
) ;
return true ;
} ,
createProgram : function ( name ) {
updateDynamicRam ( "createProgram" , getRamCost ( "createProgram" ) ) ;
checkSingularityAccess ( "createProgram" , 3 ) ;
if ( inMission ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "createProgram" , "You are in the middle of a mission." ) ;
2021-09-05 01:09:30 +02:00
return ;
}
if ( Player . isWorking ) {
var txt = Player . singularityStopWork ( ) ;
workerScript . log ( "createProgram" , txt ) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
name = name . toLowerCase ( ) ;
2019-01-15 04:34:04 +01:00
2021-09-05 01:09:30 +02:00
let p = null ;
for ( const key in Programs ) {
if ( Programs [ key ] . name . toLowerCase ( ) == name ) {
p = Programs [ key ] ;
}
}
2019-01-15 04:34:04 +01:00
2021-09-05 01:09:30 +02:00
if ( p == null ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "createProgram" , ` The specified program does not exist: ' ${ name } ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2019-01-15 04:34:04 +01:00
2021-09-05 01:09:30 +02:00
if ( Player . hasProgram ( p . name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "createProgram" , ` You already have the ' ${ p . name } ' program ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2017-11-01 23:56:30 +01:00
2021-09-05 01:09:30 +02:00
if ( ! p . create . req ( Player ) ) {
workerScript . log (
"createProgram" ,
` Hacking level is too low to create ' ${ p . name } ' (level ${ p . create . level } req) ` ,
) ;
return false ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
Player . startCreateProgramWork ( p . name , p . create . time , p . create . level ) ;
workerScript . log ( "createProgram" , ` Began creating program: ' ${ name } ' ` ) ;
return true ;
} ,
commitCrime : function ( crimeRoughName ) {
updateDynamicRam ( "commitCrime" , getRamCost ( "commitCrime" ) ) ;
checkSingularityAccess ( "commitCrime" , 3 ) ;
if ( inMission ) {
workerScript . log ( "commitCrime" , "You are in the middle of a mission." ) ;
return ;
}
if ( Player . isWorking ) {
const txt = Player . singularityStopWork ( ) ;
workerScript . log ( "commitCrime" , txt ) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
// Set Location to slums
Player . gotoLocation ( LocationName . Slums ) ;
2018-06-10 06:55:25 +02:00
2021-09-05 01:09:30 +02:00
const crime = findCrime ( crimeRoughName . toLowerCase ( ) ) ;
if ( crime == null ) {
// couldn't find crime
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "commitCrime" , ` Invalid crime: ' ${ crimeRoughName } ' ` ) ;
2021-09-05 01:09:30 +02:00
}
workerScript . log ( "commitCrime" , ` Attempting to commit ${ crime . name } ... ` ) ;
return crime . commit ( Player , 1 , { workerscript : workerScript } ) ;
} ,
getCrimeChance : function ( crimeRoughName ) {
updateDynamicRam ( "getCrimeChance" , getRamCost ( "getCrimeChance" ) ) ;
checkSingularityAccess ( "getCrimeChance" , 3 ) ;
const crime = findCrime ( crimeRoughName . toLowerCase ( ) ) ;
if ( crime == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getCrimeChance" , ` Invalid crime: ${ crimeRoughName } ` ) ;
2021-09-05 01:09:30 +02:00
}
2017-11-01 23:56:30 +01:00
2021-09-05 01:09:30 +02:00
return crime . successRate ( Player ) ;
} ,
getCrimeStats : function ( crimeRoughName ) {
updateDynamicRam ( "getCrimeStats" , getRamCost ( "getCrimeStats" ) ) ;
checkSingularityAccess ( "getCrimeStats" , 3 ) ;
const crime = findCrime ( crimeRoughName . toLowerCase ( ) ) ;
if ( crime == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getCrimeStats" , ` Invalid crime: ${ crimeRoughName } ` ) ;
2021-09-05 01:09:30 +02:00
}
2017-08-30 20:36:59 +02:00
2021-09-05 01:09:30 +02:00
return Object . assign ( { } , crime ) ;
} ,
getOwnedAugmentations : function ( purchased = false ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getOwnedAugmentations" , getRamCost ( "getOwnedAugmentations" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getOwnedAugmentations" , 3 ) ;
var res = [ ] ;
for ( var i = 0 ; i < Player . augmentations . length ; ++ i ) {
res . push ( Player . augmentations [ i ] . name ) ;
}
if ( purchased ) {
for ( var i = 0 ; i < Player . queuedAugmentations . length ; ++ i ) {
res . push ( Player . queuedAugmentations [ i ] . name ) ;
}
}
return res ;
} ,
getOwnedSourceFiles : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getOwnedSourceFiles" , getRamCost ( "getOwnedSourceFiles" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getOwnedSourceFiles" , 3 ) ;
let res = [ ] ;
for ( let i = 0 ; i < Player . sourceFiles . length ; ++ i ) {
res . push ( {
n : Player . sourceFiles [ i ] . n ,
lvl : Player . sourceFiles [ i ] . lvl ,
} ) ;
}
return res ;
} ,
getAugmentationsFromFaction : function ( facname ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationsFromFaction" , getRamCost ( "getAugmentationsFromFaction" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getAugmentationsFromFaction" , 3 ) ;
const faction = getFaction ( "getAugmentationsFromFaction" , facname ) ;
// If player has a gang with this faction, return all augmentations.
if ( Player . hasGangWith ( facname ) ) {
const res = [ ] ;
for ( const augName in Augmentations ) {
const aug = Augmentations [ augName ] ;
if ( ! aug . isSpecial ) {
res . push ( augName ) ;
}
}
2017-08-21 18:59:06 +02:00
2021-09-05 01:09:30 +02:00
return res ;
}
2021-03-11 09:02:05 +01:00
2021-09-05 01:09:30 +02:00
return faction . augmentations . slice ( ) ;
} ,
2021-09-08 05:33:34 +02:00
getAugmentationCost : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationCost" , getRamCost ( "getAugmentationCost" ) ) ;
2021-09-08 05:33:34 +02:00
checkSingularityAccess ( "getAugmentationCost" , 3 ) ;
const aug = getAugmentation ( "getAugmentationCost" , name ) ;
return [ aug . baseRepRequirement , aug . baseCost ] ;
} ,
2021-09-05 01:09:30 +02:00
getAugmentationPrereq : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationPrereq" , getRamCost ( "getAugmentationPrereq" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getAugmentationPrereq" , 3 ) ;
const aug = getAugmentation ( "getAugmentationPrereq" , name ) ;
return aug . prereqs . slice ( ) ;
} ,
2021-09-08 05:33:34 +02:00
getAugmentationPrice : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationPrice" , getRamCost ( "getAugmentationPrice" ) ) ;
2021-09-08 05:33:34 +02:00
checkSingularityAccess ( "getAugmentationPrice" , 3 ) ;
const aug = getAugmentation ( "getAugmentationPrice" , name ) ;
return aug . baseCost ;
} ,
getAugmentationRepReq : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationRepReq" , getRamCost ( "getAugmentationRepReq" ) ) ;
2021-09-08 05:33:34 +02:00
checkSingularityAccess ( "getAugmentationRepReq" , 3 ) ;
const aug = getAugmentation ( "getAugmentationRepReq" , name ) ;
return aug . baseRepRequirement ;
2021-09-05 01:09:30 +02:00
} ,
getAugmentationStats : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getAugmentationStats" , getRamCost ( "getAugmentationStats" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "getAugmentationStats" , 3 ) ;
const aug = getAugmentation ( "getAugmentationStats" , name ) ;
return Object . assign ( { } , aug . mults ) ;
} ,
purchaseAugmentation : function ( faction , name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "purchaseAugmentation" , getRamCost ( "purchaseAugmentation" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "purchaseAugmentation" , 3 ) ;
const fac = getFaction ( "purchaseAugmentation" , faction ) ;
const aug = getAugmentation ( "purchaseAugmentation" , name ) ;
let augs = [ ] ;
if ( Player . hasGangWith ( faction ) ) {
for ( const augName in Augmentations ) {
const tempAug = Augmentations [ augName ] ;
if ( ! tempAug . isSpecial ) {
augs . push ( augName ) ;
}
}
} else {
augs = fac . augmentations ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
if ( ! augs . includes ( name ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseAugmentation" , ` Faction ' ${ faction } ' does not have the ' ${ name } ' augmentation. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2018-06-02 01:31:34 +02:00
2021-09-05 01:09:30 +02:00
const isNeuroflux = aug . name === AugmentationNames . NeuroFluxGovernor ;
if ( ! isNeuroflux ) {
for ( let j = 0 ; j < Player . queuedAugmentations . length ; ++ j ) {
if ( Player . queuedAugmentations [ j ] . name === aug . name ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseAugmentation" , ` You already have the ' ${ name } ' augmentation. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
}
for ( let j = 0 ; j < Player . augmentations . length ; ++ j ) {
if ( Player . augmentations [ j ] . name === aug . name ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseAugmentation" , ` You already have the ' ${ name } ' augmentation. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
}
}
2018-06-02 01:31:34 +02:00
2021-09-05 01:09:30 +02:00
if ( fac . playerReputation < aug . baseRepRequirement ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseAugmentation" , ` You do not have enough reputation with ' ${ fac . name } '. ` ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
2018-06-02 01:31:34 +02:00
2021-09-05 01:09:30 +02:00
const res = purchaseAugmentation ( aug , fac , true ) ;
workerScript . log ( "purchaseAugmentation" , res ) ;
if ( isString ( res ) && res . startsWith ( "You purchased" ) ) {
Player . gainIntelligenceExp ( CONSTANTS . IntelligenceSingFnBaseExpGain ) ;
return true ;
} else {
return false ;
}
} ,
softReset : function ( cbScript ) {
updateDynamicRam ( "softReset" , getRamCost ( "softReset" ) ) ;
checkSingularityAccess ( "softReset" , 3 ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "softReset" , "Soft resetting. This will cause this script to be killed" ) ;
2021-09-05 01:09:30 +02:00
setTimeoutRef ( ( ) => {
prestigeAugmentation ( ) ;
runAfterReset ( cbScript ) ;
} , 0 ) ;
// Prevent workerScript from "finishing execution naturally"
workerScript . running = false ;
killWorkerScript ( workerScript ) ;
} ,
installAugmentations : function ( cbScript ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "installAugmentations" , getRamCost ( "installAugmentations" ) ) ;
2021-09-05 01:09:30 +02:00
checkSingularityAccess ( "installAugmentations" , 3 ) ;
if ( Player . queuedAugmentations . length === 0 ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "installAugmentations" , "You do not have any Augmentations to be installed." ) ;
2021-09-05 01:09:30 +02:00
return false ;
}
Player . gainIntelligenceExp ( CONSTANTS . IntelligenceSingFnBaseExpGain ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "installAugmentations" , "Installing Augmentations. This will cause this script to be killed" ) ;
2021-09-05 01:09:30 +02:00
setTimeoutRef ( ( ) => {
installAugmentations ( ) ;
runAfterReset ( cbScript ) ;
} , 0 ) ;
workerScript . running = false ; // Prevent workerScript from "finishing execution naturally"
killWorkerScript ( workerScript ) ;
} ,
// Gang API
gang : {
createGang : function ( faction ) {
updateDynamicRam ( "createGang" , getRamCost ( "gang" , "createGang" ) ) ;
// this list is copied from Faction/ui/Root.tsx
const GangNames = [
"Slum Snakes" ,
"Tetrads" ,
"The Syndicate" ,
"The Dark Army" ,
"Speakers for the Dead" ,
"NiteSec" ,
"The Black Hand" ,
] ;
2021-09-09 05:47:34 +02:00
if ( ! Player . canAccessGang ( ) || ! GangNames . includes ( faction ) ) return false ;
2021-09-05 01:09:30 +02:00
if ( Player . inGang ( ) ) return false ;
if ( ! Player . factions . includes ( faction ) ) return false ;
const isHacking = faction === "NiteSec" || faction === "The Black Hand" ;
Player . startGang ( faction , isHacking ) ;
return true ;
} ,
inGang : function ( ) {
updateDynamicRam ( "inGang" , getRamCost ( "gang" , "inGang" ) ) ;
return Player . inGang ( ) ;
} ,
getMemberNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getMemberNames" , getRamCost ( "gang" , "getMemberNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getMemberNames" ) ;
return Player . gang . members . map ( ( member ) => member . name ) ;
} ,
getGangInformation : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getGangInformation" , getRamCost ( "gang" , "getGangInformation" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getGangInformation" ) ;
return {
faction : Player . gang . facName ,
isHacking : Player . gang . isHackingGang ,
moneyGainRate : Player . gang . moneyGainRate ,
power : Player . gang . getPower ( ) ,
respect : Player . gang . respect ,
respectGainRate : Player . gang . respectGainRate ,
territory : Player . gang . getTerritory ( ) ,
territoryClashChance : Player . gang . territoryClashChance ,
territoryWarfareEngaged : Player . gang . territoryWarfareEngaged ,
wantedLevel : Player . gang . wanted ,
wantedLevelGainRate : Player . gang . wantedGainRate ,
} ;
} ,
getOtherGangInformation : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getOtherGangInformation" , getRamCost ( "gang" , "getOtherGangInformation" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getOtherGangInformation" ) ;
const cpy = { } ;
for ( const gang in AllGangs ) {
cpy [ gang ] = Object . assign ( { } , AllGangs [ gang ] ) ;
}
2018-06-02 01:31:34 +02:00
2021-09-05 01:09:30 +02:00
return cpy ;
} ,
getMemberInformation : function ( name ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getMemberInformation" , getRamCost ( "gang" , "getMemberInformation" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getMemberInformation" ) ;
const member = getGangMember ( "getMemberInformation" , name ) ;
return {
name : member . name ,
task : member . task ,
earnedRespect : member . earnedRespect ,
hack : member . hack ,
str : member . str ,
def : member . def ,
dex : member . dex ,
agi : member . agi ,
cha : member . cha ,
hack _exp : member . hack _exp ,
str _exp : member . str _exp ,
def _exp : member . def _exp ,
dex _exp : member . dex _exp ,
agi _exp : member . agi _exp ,
cha _exp : member . cha _exp ,
hack _mult : member . hack _mult ,
str _mult : member . str _mult ,
def _mult : member . def _mult ,
dex _mult : member . dex _mult ,
agi _mult : member . agi _mult ,
cha _mult : member . cha _mult ,
hack _asc _mult : member . calculateAscensionMult ( member . hack _asc _points ) ,
str _asc _mult : member . calculateAscensionMult ( member . str _asc _points ) ,
def _asc _mult : member . calculateAscensionMult ( member . def _asc _points ) ,
dex _asc _mult : member . calculateAscensionMult ( member . dex _asc _points ) ,
agi _asc _mult : member . calculateAscensionMult ( member . agi _asc _points ) ,
cha _asc _mult : member . calculateAscensionMult ( member . cha _asc _points ) ,
hack _asc _points : member . hack _asc _points ,
str _asc _points : member . str _asc _points ,
def _asc _points : member . def _asc _points ,
dex _asc _points : member . dex _asc _points ,
agi _asc _points : member . agi _asc _points ,
cha _asc _points : member . cha _asc _points ,
upgrades : member . upgrades . slice ( ) ,
augmentations : member . augmentations . slice ( ) ,
} ;
} ,
canRecruitMember : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "canRecruitMember" , getRamCost ( "gang" , "canRecruitMember" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "canRecruitMember" ) ;
return Player . gang . canRecruitMember ( ) ;
} ,
recruitMember : function ( name ) {
updateDynamicRam ( "recruitMember" , getRamCost ( "gang" , "recruitMember" ) ) ;
checkGangApiAccess ( "recruitMember" ) ;
const recruited = Player . gang . recruitMember ( name ) ;
if ( recruited ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "recruitMember" , ` Successfully recruited Gang Member ' ${ name } ' ` ) ;
2021-09-05 01:09:30 +02:00
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "recruitMember" , ` Failed to recruit Gang Member ' ${ name } ' ` ) ;
2021-09-05 01:09:30 +02:00
}
2018-06-02 01:31:34 +02:00
2021-09-05 01:09:30 +02:00
return recruited ;
} ,
getTaskNames : function ( ) {
updateDynamicRam ( "getTaskNames" , getRamCost ( "gang" , "getTaskNames" ) ) ;
checkGangApiAccess ( "getTaskNames" ) ;
const tasks = Player . gang . getAllTaskNames ( ) ;
tasks . unshift ( "Unassigned" ) ;
return tasks ;
} ,
setMemberTask : function ( memberName , taskName ) {
updateDynamicRam ( "setMemberTask" , getRamCost ( "gang" , "setMemberTask" ) ) ;
checkGangApiAccess ( "setMemberTask" ) ;
const member = getGangMember ( "setMemberTask" , memberName ) ;
const success = member . assignToTask ( taskName ) ;
if ( success ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "setMemberTask" , ` Successfully assigned Gang Member ' ${ memberName } ' to ' ${ taskName } ' task ` ) ;
2021-09-05 01:09:30 +02:00
} else {
workerScript . log (
"setMemberTask" ,
` Failed to assign Gang Member ' ${ memberName } ' to ' ${ taskName } ' task. ' ${ memberName } ' is now Unassigned ` ,
) ;
}
2017-10-12 04:00:22 +02:00
2021-09-05 01:09:30 +02:00
return success ;
} ,
getTaskStats : function ( taskName ) {
updateDynamicRam ( "getTaskStats" , getRamCost ( "gang" , "getTaskStats" ) ) ;
checkGangApiAccess ( "getTaskStats" ) ;
const task = getGangTask ( "getTaskStats" , taskName ) ;
const copy = Object . assign ( { } , task ) ;
copy . territory = Object . assign ( { } , task . territory ) ;
return copy ;
} ,
getEquipmentNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getEquipmentNames" , getRamCost ( "gang" , "getEquipmentNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getEquipmentNames" ) ;
return Object . keys ( GangMemberUpgrades ) ;
} ,
getEquipmentCost : function ( equipName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getEquipmentCost" , getRamCost ( "gang" , "getEquipmentCost" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getEquipmentCost" ) ;
const upg = GangMemberUpgrades [ equipName ] ;
if ( upg === null ) return Infinity ;
return Player . gang . getUpgradeCost ( upg ) ;
} ,
getEquipmentType : function ( equipName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getEquipmentType" , getRamCost ( "gang" , "getEquipmentType" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getEquipmentType" ) ;
const upg = GangMemberUpgrades [ equipName ] ;
if ( upg == null ) return "" ;
return upg . getType ( ) ;
} ,
getEquipmentStats : function ( equipName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getEquipmentStats" , getRamCost ( "gang" , "getEquipmentStats" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getEquipmentStats" ) ;
const equipment = GangMemberUpgrades [ equipName ] ;
if ( ! equipment ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "getEquipmentStats" , ` Invalid equipment: ${ equipName } ` ) ;
2021-09-05 01:09:30 +02:00
}
return Object . assign ( { } , equipment . mults ) ;
} ,
purchaseEquipment : function ( memberName , equipName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "purchaseEquipment" , getRamCost ( "gang" , "purchaseEquipment" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "purchaseEquipment" ) ;
const member = getGangMember ( "purchaseEquipment" , memberName ) ;
const equipment = GangMemberUpgrades [ equipName ] ;
if ( ! equipment ) return false ;
const res = member . buyUpgrade ( equipment , Player , Player . gang ) ;
if ( res ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseEquipment" , ` Purchased ' ${ equipName } ' for Gang member ' ${ memberName } ' ` ) ;
2021-09-05 01:09:30 +02:00
} else {
2021-09-09 05:47:34 +02:00
workerScript . log ( "purchaseEquipment" , ` Failed to purchase ' ${ equipName } ' for Gang member ' ${ memberName } ' ` ) ;
2021-09-05 01:09:30 +02:00
}
2017-10-20 23:59:54 +02:00
2021-09-05 01:09:30 +02:00
return res ;
} ,
ascendMember : function ( name ) {
updateDynamicRam ( "ascendMember" , getRamCost ( "gang" , "ascendMember" ) ) ;
checkGangApiAccess ( "ascendMember" ) ;
const member = getGangMember ( "ascendMember" , name ) ;
if ( ! member . canAscend ( ) ) return ;
return Player . gang . ascendMember ( member , workerScript ) ;
} ,
setTerritoryWarfare : function ( engage ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setTerritoryWarfare" , getRamCost ( "gang" , "setTerritoryWarfare" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "setTerritoryWarfare" ) ;
if ( engage ) {
Player . gang . territoryWarfareEngaged = true ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "setTerritoryWarfare" , "Engaging in Gang Territory Warfare" ) ;
2021-09-05 01:09:30 +02:00
} else {
Player . gang . territoryWarfareEngaged = false ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "setTerritoryWarfare" , "Disengaging in Gang Territory Warfare" ) ;
2021-09-05 01:09:30 +02:00
}
} ,
getChanceToWinClash : function ( otherGang ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getChanceToWinClash" , getRamCost ( "gang" , "getChanceToWinClash" ) ) ;
2021-09-05 01:09:30 +02:00
checkGangApiAccess ( "getChanceToWinClash" ) ;
if ( AllGangs [ otherGang ] == null ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( ` gang. ${ getChanceToWinClash } ` , ` Invalid gang: ${ otherGang } ` ) ;
2021-09-05 01:09:30 +02:00
}
2017-10-15 03:55:41 +02:00
2021-09-05 01:09:30 +02:00
const playerPower = AllGangs [ Player . gang . facName ] . power ;
const otherPower = AllGangs [ otherGang ] . power ;
return playerPower / ( otherPower + playerPower ) ;
} ,
getBonusTime : function ( ) {
updateDynamicRam ( "getBonusTime" , getRamCost ( "gang" , "getBonusTime" ) ) ;
checkGangApiAccess ( "getBonusTime" ) ;
return Math . round ( Player . gang . storedCycles / 5 ) ;
} ,
} , // end gang namespace
// Bladeburner API
bladeburner : {
getContractNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getContractNames" , getRamCost ( "bladeburner" , "getContractNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getContractNames" ) ;
return Player . bladeburner . getContractNamesNetscriptFn ( ) ;
} ,
getOperationNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getOperationNames" , getRamCost ( "bladeburner" , "getOperationNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getOperationNames" ) ;
return Player . bladeburner . getOperationNamesNetscriptFn ( ) ;
} ,
getBlackOpNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getBlackOpNames" , getRamCost ( "bladeburner" , "getBlackOpNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getBlackOpNames" ) ;
return Player . bladeburner . getBlackOpNamesNetscriptFn ( ) ;
} ,
getBlackOpRank : function ( name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getBlackOpRank" , getRamCost ( "bladeburner" , "getBlackOpRank" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getBlackOpRank" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "getBlackOpRank" , "blackops" , name ) ;
2021-09-05 01:09:30 +02:00
return action . reqdRank ;
} ,
getGeneralActionNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getGeneralActionNames" , getRamCost ( "bladeburner" , "getGeneralActionNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getGeneralActionNames" ) ;
return Player . bladeburner . getGeneralActionNamesNetscriptFn ( ) ;
} ,
getSkillNames : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSkillNames" , getRamCost ( "bladeburner" , "getSkillNames" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getSkillNames" ) ;
return Player . bladeburner . getSkillNamesNetscriptFn ( ) ;
} ,
startAction : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "startAction" , getRamCost ( "bladeburner" , "startAction" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "startAction" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . startActionNetscriptFn ( Player , type , name , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.startAction" , e ) ;
}
} ,
stopBladeburnerAction : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "stopBladeburnerAction" , getRamCost ( "bladeburner" , "stopBladeburnerAction" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "stopBladeburnerAction" ) ;
return Player . bladeburner . resetAction ( ) ;
} ,
getCurrentAction : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCurrentAction" , getRamCost ( "bladeburner" , "getCurrentAction" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getCurrentAction" ) ;
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getTypeAndNameFromActionId ( Player . bladeburner . action ) ;
2021-09-05 01:09:30 +02:00
} ,
getActionTime : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionTime" , getRamCost ( "bladeburner" , "getActionTime" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionTime" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getActionTimeNetscriptFn ( Player , type , name , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.getActionTime" , e ) ;
}
} ,
getActionEstimatedSuccessChance : function ( type = "" , name = "" ) {
updateDynamicRam (
"getActionEstimatedSuccessChance" ,
getRamCost ( "bladeburner" , "getActionEstimatedSuccessChance" ) ,
) ;
checkBladeburnerAccess ( "getActionEstimatedSuccessChance" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getActionEstimatedSuccessChanceNetscriptFn ( Player , type , name , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "bladeburner.getActionEstimatedSuccessChance" , e ) ;
2021-09-05 01:09:30 +02:00
}
} ,
getActionRepGain : function ( type = "" , name = "" , level ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionRepGain" , getRamCost ( "bladeburner" , "getActionRepGain" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionRepGain" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "getActionRepGain" , type , name ) ;
2021-09-05 01:09:30 +02:00
let rewardMultiplier ;
if ( level == null || isNaN ( level ) ) {
rewardMultiplier = Math . pow ( action . rewardFac , action . level - 1 ) ;
} else {
rewardMultiplier = Math . pow ( action . rewardFac , level - 1 ) ;
}
2018-05-29 22:36:52 +02:00
2021-09-09 05:47:34 +02:00
return action . rankGain * rewardMultiplier * BitNodeMultipliers . BladeburnerRank ;
2021-09-05 01:09:30 +02:00
} ,
getActionCountRemaining : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionCountRemaining" , getRamCost ( "bladeburner" , "getActionCountRemaining" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionCountRemaining" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getActionCountRemainingNetscriptFn ( type , name , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.getActionCountRemaining" , e ) ;
}
} ,
getActionMaxLevel : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionMaxLevel" , getRamCost ( "bladeburner" , "getActionMaxLevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionMaxLevel" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "getActionMaxLevel" , type , name ) ;
2021-09-05 01:09:30 +02:00
return action . maxLevel ;
} ,
getActionCurrentLevel : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionCurrentLevel" , getRamCost ( "bladeburner" , "getActionCurrentLevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionCurrentLevel" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "getActionCurrentLevel" , type , name ) ;
2021-09-05 01:09:30 +02:00
return action . level ;
} ,
getActionAutolevel : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getActionAutolevel" , getRamCost ( "bladeburner" , "getActionAutolevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getActionAutolevel" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "getActionCurrentLevel" , type , name ) ;
2021-09-05 01:09:30 +02:00
return action . autoLevel ;
} ,
setActionAutolevel : function ( type = "" , name = "" , autoLevel = true ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setActionAutolevel" , getRamCost ( "bladeburner" , "setActionAutolevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "setActionAutolevel" ) ;
2021-09-09 05:47:34 +02:00
const action = getBladeburnerActionObject ( "setActionAutolevel" , type , name ) ;
2021-09-05 01:09:30 +02:00
action . autoLevel = autoLevel ;
} ,
setActionLevel : function ( type = "" , name = "" , level = 1 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setActionLevel" , getRamCost ( "bladeburner" , "setActionLevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "setActionLevel" ) ;
const action = getBladeburnerActionObject ( "setActionLevel" , type , name ) ;
if ( level < 1 || level > action . maxLevel ) {
throw makeRuntimeErrorMsg (
"bladeburner.setActionLevel" ,
` Level must be between 1 and ${ action . maxLevel } , is ${ level } ` ,
) ;
}
action . level = level ;
} ,
getRank : function ( ) {
updateDynamicRam ( "getRank" , getRamCost ( "bladeburner" , "getRank" ) ) ;
checkBladeburnerAccess ( "getRank" ) ;
return Player . bladeburner . rank ;
} ,
getSkillPoints : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSkillPoints" , getRamCost ( "bladeburner" , "getSkillPoints" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getSkillPoints" ) ;
return Player . bladeburner . skillPoints ;
} ,
getSkillLevel : function ( skillName = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSkillLevel" , getRamCost ( "bladeburner" , "getSkillLevel" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getSkillLevel" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getSkillLevelNetscriptFn ( skillName , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.getSkillLevel" , e ) ;
}
} ,
getSkillUpgradeCost : function ( skillName = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSkillUpgradeCost" , getRamCost ( "bladeburner" , "getSkillUpgradeCost" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getSkillUpgradeCost" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getSkillUpgradeCostNetscriptFn ( skillName , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.getSkillUpgradeCost" , e ) ;
}
} ,
upgradeSkill : function ( skillName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "upgradeSkill" , getRamCost ( "bladeburner" , "upgradeSkill" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "upgradeSkill" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . upgradeSkillNetscriptFn ( skillName , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.upgradeSkill" , e ) ;
}
} ,
getTeamSize : function ( type = "" , name = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getTeamSize" , getRamCost ( "bladeburner" , "getTeamSize" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getTeamSize" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . getTeamSizeNetscriptFn ( type , name , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.getTeamSize" , e ) ;
}
} ,
setTeamSize : function ( type = "" , name = "" , size ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setTeamSize" , getRamCost ( "bladeburner" , "setTeamSize" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "setTeamSize" ) ;
try {
2021-09-09 05:47:34 +02:00
return Player . bladeburner . setTeamSizeNetscriptFn ( type , name , size , workerScript ) ;
2021-09-05 01:09:30 +02:00
} catch ( e ) {
throw makeRuntimeErrorMsg ( "bladeburner.setTeamSize" , e ) ;
}
} ,
getCityEstimatedPopulation : function ( cityName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCityEstimatedPopulation" , getRamCost ( "bladeburner" , "getCityEstimatedPopulation" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getCityEstimatedPopulation" ) ;
checkBladeburnerCity ( "getCityEstimatedPopulation" , cityName ) ;
return Player . bladeburner . cities [ cityName ] . popEst ;
} ,
getCityEstimatedCommunities : function ( cityName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCityEstimatedCommunities" , getRamCost ( "bladeburner" , "getCityEstimatedCommunities" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getCityEstimatedCommunities" ) ;
checkBladeburnerCity ( "getCityEstimatedCommunities" , cityName ) ;
return Player . bladeburner . cities [ cityName ] . commsEst ;
} ,
getCityChaos : function ( cityName ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getCityChaos" , getRamCost ( "bladeburner" , "getCityChaos" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getCityChaos" ) ;
checkBladeburnerCity ( "getCityChaos" , cityName ) ;
return Player . bladeburner . cities [ cityName ] . chaos ;
} ,
getCity : function ( ) {
updateDynamicRam ( "getCity" , getRamCost ( "bladeburner" , "getCity" ) ) ;
checkBladeburnerAccess ( "getCityChaos" ) ;
return Player . bladeburner . city ;
} ,
switchCity : function ( cityName ) {
updateDynamicRam ( "switchCity" , getRamCost ( "bladeburner" , "switchCity" ) ) ;
checkBladeburnerAccess ( "switchCity" ) ;
checkBladeburnerCity ( "switchCity" , cityName ) ;
return ( Player . bladeburner . city = cityName ) ;
} ,
getStamina : function ( ) {
updateDynamicRam ( "getStamina" , getRamCost ( "bladeburner" , "getStamina" ) ) ;
checkBladeburnerAccess ( "getStamina" ) ;
return [ Player . bladeburner . stamina , Player . bladeburner . maxStamina ] ;
} ,
joinBladeburnerFaction : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "joinBladeburnerFaction" , getRamCost ( "bladeburner" , "joinBladeburnerFaction" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "joinBladeburnerFaction" , true ) ;
2021-09-09 05:47:34 +02:00
return Player . bladeburner . joinBladeburnerFactionNetscriptFn ( workerScript ) ;
2021-09-05 01:09:30 +02:00
} ,
joinBladeburnerDivision : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "joinBladeburnerDivision" , getRamCost ( "bladeburner" , "joinBladeburnerDivision" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "joinBladeburnerDivision" , true ) ;
if ( Player . bitNodeN === 7 || SourceFileFlags [ 7 ] > 0 ) {
if ( Player . bitNodeN === 8 ) {
return false ;
}
if ( Player . bladeburner instanceof Bladeburner ) {
return true ; // Already member
} else if (
Player . strength >= 100 &&
Player . defense >= 100 &&
Player . dexterity >= 100 &&
Player . agility >= 100
) {
Player . bladeburner = new Bladeburner ( Player ) ;
2021-09-09 05:47:34 +02:00
workerScript . log ( "joinBladeburnerDivision" , "You have been accepted into the Bladeburner division" ) ;
2021-03-08 04:22:23 +01:00
2021-09-05 01:09:30 +02:00
const worldHeader = document . getElementById ( "world-menu-header" ) ;
if ( worldHeader instanceof HTMLElement ) {
worldHeader . click ( ) ;
worldHeader . click ( ) ;
2021-03-08 04:22:23 +01:00
}
2021-09-05 01:09:30 +02:00
return true ;
} else {
workerScript . log (
"joinBladeburnerDivision" ,
"You do not meet the requirements for joining the Bladeburner division" ,
) ;
return false ;
}
}
} ,
getBonusTime : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getBonusTime" , getRamCost ( "bladeburner" , "getBonusTime" ) ) ;
2021-09-05 01:09:30 +02:00
checkBladeburnerAccess ( "getBonusTime" ) ;
return Math . round ( Player . bladeburner . storedCycles / 5 ) ;
} ,
} , // End Bladeburner
2021-09-10 08:17:55 +02:00
// Hi, if you're reading this you're a bit nosy.
// There's a corporation API but it's very imbalanced right now.
// It's here so players can test with if they want.
corporation : {
expandIndustry : function ( industryName , divisionName ) {
NewIndustry ( Player . corporation , industryName , divisionName ) ;
} ,
expandCity : function ( divisionName , cityName ) {
const division = getDivision ( divisionName ) ;
NewCity ( Player . corporation , division , cityName ) ;
} ,
unlockUpgrade : function ( upgradeName ) {
const upgrade = Object . values ( CorporationUnlockUpgrades ) . find ( ( upgrade ) => upgrade [ 2 ] === upgradeName ) ;
2021-09-13 00:03:07 +02:00
if ( upgrade === undefined ) throw new Error ( ` No upgrade named ' ${ upgradeName } ' ` ) ;
2021-09-10 08:17:55 +02:00
UnlockUpgrade ( Player . corporation , upgrade ) ;
} ,
levelUpgrade : function ( upgradeName ) {
const upgrade = Object . values ( CorporationUpgrades ) . find ( ( upgrade ) => upgrade [ 4 ] === upgradeName ) ;
2021-09-13 00:03:07 +02:00
if ( upgrade === undefined ) throw new Error ( ` No upgrade named ' ${ upgradeName } ' ` ) ;
2021-09-10 08:17:55 +02:00
LevelUpgrade ( Player . corporation , upgrade ) ;
} ,
issueDividends : function ( percent ) {
IssueDividends ( Player . corporation , percent ) ;
} ,
sellMaterial : function ( divisionName , cityName , materialName , amt , price ) {
const material = getMaterial ( divisionName , cityName , materialName ) ;
SellMaterial ( material , amt , price ) ;
} ,
sellProduct : function ( divisionName , cityName , productName , amt , price , all ) {
const product = getProduct ( divisionName , productName ) ;
SellProduct ( product , cityName , amt , price , all ) ;
} ,
discontinueProduct : function ( divisionName , productName ) {
getDivision ( divisionName ) . discontinueProduct ( getProduct ( divisionName , productName ) ) ;
} ,
setSmartSupply : function ( divisionName , cityName , enabled ) {
const warehouse = getWarehouse ( divisionName , cityName ) ;
SetSmartSupply ( warehouse , enabled ) ;
} ,
setSmartSupplyUseLeftovers : function ( ) { } ,
buyMaterial : function ( divisionName , cityName , materialName , amt ) {
const material = getMaterial ( divisionName , cityName , materialName ) ;
BuyMaterial ( material , amt ) ;
} ,
employees : function ( divisionName , cityName ) {
const office = getOffice ( divisionName , cityName ) ;
return office . employees . map ( ( e ) => Object . assign ( { } , e ) ) ;
} ,
assignJob : function ( divisionName , cityName , employeeName , job ) {
const employee = getEmployee ( divisionName , cityName , employeeName ) ;
AssignJob ( employee , job ) ;
} ,
hireEmployee : function ( divisionName , cityName ) {
const office = getOffice ( divisionName , cityName ) ;
office . hireRandomEmployee ( ) ;
} ,
upgradeOfficeSize : function ( divisionName , cityName , size ) {
const office = getOffice ( divisionName , cityName ) ;
UpgradeOfficeSize ( Player . corporation , office , size ) ;
} ,
throwParty : function ( divisionName , cityName , costPerEmployee ) {
const office = getOffice ( divisionName , cityName ) ;
ThrowParty ( Player . corporation , office , costPerEmployee ) ;
} ,
purchaseWarehouse : function ( divisionName , cityName ) {
PurchaseWarehouse ( Player . corporation , getDivision ( divisionName ) , cityName ) ;
} ,
upgradeWarehouse : function ( divisionName , cityName ) {
UpgradeWarehouse ( Player . corporation , getDivision ( divisionName ) , getWarehouse ( divisionName , cityName ) ) ;
} ,
buyCoffee : function ( divisionName , cityName ) {
BuyCoffee ( Player . corporation , getDivision ( divisionName ) , getOffice ( divisionName , cityName ) ) ;
} ,
hireAdVert : function ( divisionName ) {
HireAdVert ( Player . corporation , getDivision ( divisionName ) , getOffice ( divisionName , "Sector-12" ) ) ;
} ,
makeProduct : function ( divisionName , cityName , productName , designInvest , marketingInvest ) {
MakeProduct (
Player . corporation ,
getDivision ( divisionName ) ,
cityName ,
productName ,
designInvest ,
marketingInvest ,
) ;
} ,
research : function ( divisionName , researchName ) {
Research ( getDivision ( divisionName ) , researchName ) ;
} ,
exportMaterial : function ( sourceDivision , sourceCity , targetDivision , targetCity , materialName , amt ) {
ExportMaterial ( targetDivision , targetCity , getMaterial ( sourceDivision , sourceCity , materialName ) , amt + "" ) ;
} ,
cancelExportMaterial : function ( sourceDivision , sourceCity , targetDivision , targetCity , materialName , amt ) {
CancelExportMaterial (
targetDivision ,
targetCity ,
getMaterial ( sourceDivision , sourceCity , materialName ) ,
amt + "" ,
) ;
} ,
setMaterialMarketTA1 : function ( divisionName , cityName , materialName , on ) {
SetMaterialMarketTA1 ( getMaterial ( divisionName , cityName , materialName ) , on ) ;
} ,
setMaterialMarketTA2 : function ( divisionName , cityName , materialName , on ) {
SetMaterialMarketTA2 ( getMaterial ( divisionName , cityName , materialName ) , on ) ;
} ,
setProductMarketTA1 : function ( divisionName , productName , on ) {
SetProductMarketTA1 ( getProduct ( divisionName , productName ) , on ) ;
} ,
setProductMarketTA2 : function ( divisionName , productName , on ) {
SetProductMarketTA2 ( getProduct ( divisionName , productName ) , on ) ;
} ,
// If you modify these objects you will affect them for real, it's not
// copies.
getDivision : function ( divisionName ) {
return getDivision ( divisionName ) ;
} ,
getOffice : function ( divisionName , cityName ) {
return getOffice ( divisionName , cityName ) ;
} ,
getWarehouse : function ( divisionName , cityName ) {
return getWarehouse ( divisionName , cityName ) ;
} ,
getMaterial : function ( divisionName , cityName , materialName ) {
return getMaterial ( divisionName , cityName , materialName ) ;
} ,
getProduct : function ( divisionName , productName ) {
return getProduct ( divisionName , productName ) ;
} ,
getEmployee : function ( divisionName , cityName , employeeName ) {
return getEmployee ( divisionName , cityName , employeeName ) ;
} ,
} , // End Corporation API
2021-09-05 01:09:30 +02:00
// Coding Contract API
codingcontract : {
2021-09-09 05:47:34 +02:00
attempt : function ( answer , fn , ip = workerScript . serverIp , { returnReward } = { } ) {
2021-09-05 01:09:30 +02:00
updateDynamicRam ( "attempt" , getRamCost ( "codingcontract" , "attempt" ) ) ;
const contract = getCodingContract ( "attempt" , ip , fn ) ;
// Convert answer to string. If the answer is a 2D array, then we have to
// manually add brackets for the inner arrays
if ( is2DArray ( answer ) ) {
let answerComponents = [ ] ;
for ( let i = 0 ; i < answer . length ; ++ i ) {
answerComponents . push ( [ "[" , answer [ i ] . toString ( ) , "]" ] . join ( "" ) ) ;
}
2019-05-02 00:20:14 +02:00
2021-09-05 01:09:30 +02:00
answer = answerComponents . join ( "," ) ;
} else {
answer = String ( answer ) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
const serv = safeGetServer ( ip , "codingcontract.attempt" ) ;
if ( contract . isSolution ( answer ) ) {
2021-09-09 05:47:34 +02:00
const reward = Player . gainCodingContractReward ( contract . reward , contract . getDifficulty ( ) ) ;
workerScript . log ( "attempt" , ` Successfully completed Coding Contract ' ${ fn } '. Reward: ${ reward } ` ) ;
2021-09-05 01:09:30 +02:00
serv . removeContract ( fn ) ;
return returnReward ? reward : true ;
} else {
++ contract . tries ;
if ( contract . tries >= contract . getMaxNumTries ( ) ) {
2021-09-09 05:47:34 +02:00
workerScript . log ( "attempt" , ` Coding Contract attempt ' ${ fn } ' failed. Contract is now self-destructing ` ) ;
2021-09-05 01:09:30 +02:00
serv . removeContract ( fn ) ;
} else {
workerScript . log (
"attempt" ,
` Coding Contract attempt ' ${ fn } ' failed. ${
contract . getMaxNumTries ( ) - contract . tries
} attempts remaining . ` ,
) ;
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
return returnReward ? "" : false ;
}
} ,
getContractType : function ( fn , ip = workerScript . serverIp ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getContractType" , getRamCost ( "codingcontract" , "getContractType" ) ) ;
2021-09-05 01:09:30 +02:00
const contract = getCodingContract ( "getContractType" , ip , fn ) ;
return contract . getType ( ) ;
} ,
getData : function ( fn , ip = workerScript . serverIp ) {
updateDynamicRam ( "getData" , getRamCost ( "codingcontract" , "getData" ) ) ;
const contract = getCodingContract ( "getData" , ip , fn ) ;
const data = contract . getData ( ) ;
if ( data . constructor === Array ) {
// For two dimensional arrays, we have to copy the internal arrays using
// slice() as well. As of right now, no contract has arrays that have
// more than two dimensions
const copy = data . slice ( ) ;
for ( let i = 0 ; i < copy . length ; ++ i ) {
if ( data [ i ] . constructor === Array ) {
copy [ i ] = data [ i ] . slice ( ) ;
2017-08-30 19:44:29 +02:00
}
2021-09-05 01:09:30 +02:00
}
2017-08-30 19:44:29 +02:00
2021-09-05 01:09:30 +02:00
return copy ;
} else {
return data ;
}
} ,
getDescription : function ( fn , ip = workerScript . serverIp ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getDescription" , getRamCost ( "codingcontract" , "getDescription" ) ) ;
2021-09-05 01:09:30 +02:00
const contract = getCodingContract ( "getDescription" , ip , fn ) ;
return contract . getDescription ( ) ;
} ,
getNumTriesRemaining : function ( fn , ip = workerScript . serverIp ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getNumTriesRemaining" , getRamCost ( "codingcontract" , "getNumTriesRemaining" ) ) ;
2021-09-05 01:09:30 +02:00
const contract = getCodingContract ( "getNumTriesRemaining" , ip , fn ) ;
return contract . getMaxNumTries ( ) - contract . tries ;
} ,
} , // End coding contracts
// Duplicate Sleeve API
sleeve : {
getNumSleeves : function ( ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getNumSleeves" , getRamCost ( "sleeve" , "getNumSleeves" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "getNumSleeves" ) ;
return Player . sleeves . length ;
} ,
setToShockRecovery : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setToShockRecovery" , getRamCost ( "sleeve" , "setToShockRecovery" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToShockRecovery" ) ;
checkSleeveNumber ( "setToShockRecovery" , sleeveNumber ) ;
return Player . sleeves [ sleeveNumber ] . shockRecovery ( Player ) ;
} ,
setToSynchronize : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setToSynchronize" , getRamCost ( "sleeve" , "setToSynchronize" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToSynchronize" ) ;
checkSleeveNumber ( "setToSynchronize" , sleeveNumber ) ;
return Player . sleeves [ sleeveNumber ] . synchronize ( Player ) ;
} ,
setToCommitCrime : function ( sleeveNumber = 0 , crimeName = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setToCommitCrime" , getRamCost ( "sleeve" , "setToCommitCrime" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToCommitCrime" ) ;
checkSleeveNumber ( "setToCommitCrime" , sleeveNumber ) ;
return Player . sleeves [ sleeveNumber ] . commitCrime ( Player , crimeName ) ;
} ,
2021-09-09 05:47:34 +02:00
setToUniversityCourse : function ( sleeveNumber = 0 , universityName = "" , className = "" ) {
updateDynamicRam ( "setToUniversityCourse" , getRamCost ( "sleeve" , "setToUniversityCourse" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToUniversityCourse" ) ;
checkSleeveNumber ( "setToUniversityCourse" , sleeveNumber ) ;
2021-09-09 05:47:34 +02:00
return Player . sleeves [ sleeveNumber ] . takeUniversityCourse ( Player , universityName , className ) ;
2021-09-05 01:09:30 +02:00
} ,
travel : function ( sleeveNumber = 0 , cityName = "" ) {
updateDynamicRam ( "travel" , getRamCost ( "sleeve" , "travel" ) ) ;
checkSleeveAPIAccess ( "travel" ) ;
checkSleeveNumber ( "travel" , sleeveNumber ) ;
return Player . sleeves [ sleeveNumber ] . travel ( Player , cityName ) ;
} ,
setToCompanyWork : function ( sleeveNumber = 0 , companyName = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setToCompanyWork" , getRamCost ( "sleeve" , "setToCompanyWork" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToCompanyWork" ) ;
checkSleeveNumber ( "setToCompanyWork" , sleeveNumber ) ;
// Cannot work at the same company that another sleeve is working at
for ( let i = 0 ; i < Player . sleeves . length ; ++ i ) {
if ( i === sleeveNumber ) {
continue ;
}
const other = Player . sleeves [ i ] ;
2021-09-09 05:47:34 +02:00
if ( other . currentTask === SleeveTaskType . Company && other . currentTaskLocation === companyName ) {
2021-09-05 01:09:30 +02:00
throw makeRuntimeErrorMsg (
"sleeve.setToFactionWork" ,
` Sleeve ${ sleeveNumber } cannot work for company ${ companyName } because Sleeve ${ i } is already working for them. ` ,
) ;
}
}
2017-08-30 20:36:59 +02:00
2021-09-05 01:09:30 +02:00
return Player . sleeves [ sleeveNumber ] . workForCompany ( Player , companyName ) ;
} ,
2021-09-09 05:47:34 +02:00
setToFactionWork : function ( sleeveNumber = 0 , factionName = "" , workType = "" ) {
updateDynamicRam ( "setToFactionWork" , getRamCost ( "sleeve" , "setToFactionWork" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToFactionWork" ) ;
checkSleeveNumber ( "setToFactionWork" , sleeveNumber ) ;
// Cannot work at the same faction that another sleeve is working at
for ( let i = 0 ; i < Player . sleeves . length ; ++ i ) {
if ( i === sleeveNumber ) {
continue ;
}
const other = Player . sleeves [ i ] ;
2021-09-09 05:47:34 +02:00
if ( other . currentTask === SleeveTaskType . Faction && other . currentTaskLocation === factionName ) {
2021-09-05 01:09:30 +02:00
throw makeRuntimeErrorMsg (
"sleeve.setToFactionWork" ,
` Sleeve ${ sleeveNumber } cannot work for faction ${ factionName } because Sleeve ${ i } is already working for them. ` ,
) ;
}
}
2017-08-30 19:44:29 +02:00
2021-09-09 05:47:34 +02:00
return Player . sleeves [ sleeveNumber ] . workForFaction ( Player , factionName , workType ) ;
2021-09-05 01:09:30 +02:00
} ,
setToGymWorkout : function ( sleeveNumber = 0 , gymName = "" , stat = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "setToGymWorkout" , getRamCost ( "sleeve" , "setToGymWorkout" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "setToGymWorkout" ) ;
checkSleeveNumber ( "setToGymWorkout" , sleeveNumber ) ;
return Player . sleeves [ sleeveNumber ] . workoutAtGym ( Player , gymName , stat ) ;
} ,
getSleeveStats : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSleeveStats" , getRamCost ( "sleeve" , "getSleeveStats" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "getSleeveStats" ) ;
checkSleeveNumber ( "getSleeveStats" , sleeveNumber ) ;
const sl = Player . sleeves [ sleeveNumber ] ;
return {
shock : 100 - sl . shock ,
sync : sl . sync ,
hacking _skill : sl . hacking _skill ,
strength : sl . strength ,
defense : sl . defense ,
dexterity : sl . dexterity ,
agility : sl . agility ,
charisma : sl . charisma ,
} ;
} ,
getTask : function ( sleeveNumber = 0 ) {
updateDynamicRam ( "getTask" , getRamCost ( "sleeve" , "getTask" ) ) ;
checkSleeveAPIAccess ( "getTask" ) ;
checkSleeveNumber ( "getTask" , sleeveNumber ) ;
const sl = Player . sleeves [ sleeveNumber ] ;
return {
task : SleeveTaskType [ sl . currentTask ] ,
crime : sl . crimeType ,
location : sl . currentTaskLocation ,
gymStatType : sl . gymStatType ,
factionWorkType : FactionWorkType [ sl . factionWorkType ] ,
} ;
} ,
getInformation : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getInformation" , getRamCost ( "sleeve" , "getInformation" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "getInformation" ) ;
checkSleeveNumber ( "getInformation" , sleeveNumber ) ;
const sl = Player . sleeves [ sleeveNumber ] ;
return {
city : sl . city ,
hp : sl . hp ,
jobs : Object . keys ( Player . jobs ) , // technically sleeves have the same jobs as the player.
jobTitle : Object . values ( Player . jobs ) ,
maxHp : sl . max _hp ,
tor : SpecialServerIps . hasOwnProperty ( "Darkweb Server" ) , // There's no reason not to give that infomation here as well. Worst case scenario it isn't used.
mult : {
agility : sl . agility _mult ,
agilityExp : sl . agility _exp _mult ,
companyRep : sl . company _rep _mult ,
crimeMoney : sl . crime _money _mult ,
crimeSuccess : sl . crime _success _mult ,
defense : sl . defense _mult ,
defenseExp : sl . defense _exp _mult ,
dexterity : sl . dexterity _mult ,
dexterityExp : sl . dexterity _exp _mult ,
factionRep : sl . faction _rep _mult ,
hacking : sl . hacking _mult ,
hackingExp : sl . hacking _exp _mult ,
strength : sl . strength _mult ,
strengthExp : sl . strength _exp _mult ,
workMoney : sl . work _money _mult ,
} ,
timeWorked : sl . currentTaskTime ,
earningsForSleeves : {
workHackExpGain : sl . earningsForSleeves . hack ,
workStrExpGain : sl . earningsForSleeves . str ,
workDefExpGain : sl . earningsForSleeves . def ,
workDexExpGain : sl . earningsForSleeves . dex ,
workAgiExpGain : sl . earningsForSleeves . agi ,
workChaExpGain : sl . earningsForSleeves . cha ,
workMoneyGain : sl . earningsForSleeves . money ,
} ,
earningsForPlayer : {
workHackExpGain : sl . earningsForPlayer . hack ,
workStrExpGain : sl . earningsForPlayer . str ,
workDefExpGain : sl . earningsForPlayer . def ,
workDexExpGain : sl . earningsForPlayer . dex ,
workAgiExpGain : sl . earningsForPlayer . agi ,
workChaExpGain : sl . earningsForPlayer . cha ,
workMoneyGain : sl . earningsForPlayer . money ,
} ,
earningsForTask : {
workHackExpGain : sl . earningsForTask . hack ,
workStrExpGain : sl . earningsForTask . str ,
workDefExpGain : sl . earningsForTask . def ,
workDexExpGain : sl . earningsForTask . dex ,
workAgiExpGain : sl . earningsForTask . agi ,
workChaExpGain : sl . earningsForTask . cha ,
workMoneyGain : sl . earningsForTask . money ,
} ,
workRepGain : sl . getRepGain ( Player ) ,
} ;
} ,
getSleeveAugmentations : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSleeveAugmentations" , getRamCost ( "sleeve" , "getSleeveAugmentations" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "getSleeveAugmentations" ) ;
checkSleeveNumber ( "getSleeveAugmentations" , sleeveNumber ) ;
const augs = [ ] ;
2021-09-09 05:47:34 +02:00
for ( let i = 0 ; i < Player . sleeves [ sleeveNumber ] . augmentations . length ; i ++ ) {
2021-09-05 01:09:30 +02:00
augs . push ( Player . sleeves [ sleeveNumber ] . augmentations [ i ] . name ) ;
}
return augs ;
} ,
getSleevePurchasableAugs : function ( sleeveNumber = 0 ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "getSleevePurchasableAugs" , getRamCost ( "sleeve" , "getSleevePurchasableAugs" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "getSleevePurchasableAugs" ) ;
checkSleeveNumber ( "getSleevePurchasableAugs" , sleeveNumber ) ;
2021-09-09 05:47:34 +02:00
const purchasableAugs = findSleevePurchasableAugs ( Player . sleeves [ sleeveNumber ] , Player ) ;
2021-09-05 01:09:30 +02:00
const augs = [ ] ;
for ( let i = 0 ; i < purchasableAugs . length ; i ++ ) {
const aug = purchasableAugs [ i ] ;
augs . push ( {
name : aug . name ,
cost : aug . startingCost ,
} ) ;
}
2018-05-23 02:09:04 +02:00
2021-09-05 01:09:30 +02:00
return augs ;
} ,
purchaseSleeveAug : function ( sleeveNumber = 0 , augName = "" ) {
2021-09-09 05:47:34 +02:00
updateDynamicRam ( "purchaseSleeveAug" , getRamCost ( "sleeve" , "purchaseSleeveAug" ) ) ;
2021-09-05 01:09:30 +02:00
checkSleeveAPIAccess ( "purchaseSleeveAug" ) ;
checkSleeveNumber ( "purchaseSleeveAug" , sleeveNumber ) ;
const aug = Augmentations [ augName ] ;
if ( ! aug ) {
2021-09-09 05:47:34 +02:00
throw makeRuntimeErrorMsg ( "sleeve.purchaseSleeveAug" , ` Invalid aug: ${ augName } ` ) ;
2021-09-05 01:09:30 +02:00
}
2021-05-12 21:10:36 +02:00
2021-09-05 01:09:30 +02:00
return Player . sleeves [ sleeveNumber ] . tryBuyAugmentation ( Player , aug ) ;
} ,
} , // End sleeve
formulas : {
basic : {
calculateSkill : function ( exp , mult = 1 ) {
checkFormulasAccess ( "basic.calculateSkill" , 5 ) ;
return calculateSkill ( exp , mult ) ;
} ,
calculateExp : function ( skill , mult = 1 ) {
checkFormulasAccess ( "basic.calculateExp" , 5 ) ;
return calculateExp ( skill , mult ) ;
} ,
hackChance : function ( server , player ) {
checkFormulasAccess ( "basic.hackChance" , 5 ) ;
return calculateHackingChance ( server , player ) ;
} ,
hackExp : function ( server , player ) {
checkFormulasAccess ( "basic.hackExp" , 5 ) ;
return calculateHackingExpGain ( server , player ) ;
} ,
hackPercent : function ( server , player ) {
checkFormulasAccess ( "basic.hackPercent" , 5 ) ;
return calculatePercentMoneyHacked ( server , player ) ;
} ,
growPercent : function ( server , threads , player , cores = 1 ) {
checkFormulasAccess ( "basic.growPercent" , 5 ) ;
return calculateServerGrowth ( server , threads , player , cores ) ;
} ,
hackTime : function ( server , player ) {
checkFormulasAccess ( "basic.hackTime" , 5 ) ;
return calculateHackingTime ( server , player ) ;
} ,
growTime : function ( server , player ) {
checkFormulasAccess ( "basic.growTime" , 5 ) ;
return calculateGrowTime ( server , player ) ;
} ,
weakenTime : function ( server , player ) {
checkFormulasAccess ( "basic.weakenTime" , 5 ) ;
return calculateWeakenTime ( server , player ) ;
} ,
} ,
hacknetNodes : {
moneyGainRate : function ( level , ram , cores , mult = 1 ) {
checkFormulasAccess ( "hacknetNodes.moneyGainRate" , 5 ) ;
return calculateMoneyGainRate ( level , ram , cores , mult ) ;
} ,
2021-09-09 05:47:34 +02:00
levelUpgradeCost : function ( startingLevel , extraLevels = 1 , costMult = 1 ) {
2021-09-05 01:09:30 +02:00
checkFormulasAccess ( "hacknetNodes.levelUpgradeCost" , 5 ) ;
2021-09-09 05:47:34 +02:00
return calculateLevelUpgradeCost ( startingLevel , extraLevels , costMult ) ;
2021-09-05 01:09:30 +02:00
} ,
ramUpgradeCost : function ( startingRam , extraLevels = 1 , costMult = 1 ) {
checkFormulasAccess ( "hacknetNodes.ramUpgradeCost" , 5 ) ;
return calculateRamUpgradeCost ( startingRam , extraLevels , costMult ) ;
} ,
coreUpgradeCost : function ( startingCore , extraCores = 1 , costMult = 1 ) {
checkFormulasAccess ( "hacknetNodes.coreUpgradeCost" , 5 ) ;
return calculateCoreUpgradeCost ( startingCore , extraCores , costMult ) ;
} ,
hacknetNodeCost : function ( n , mult ) {
checkFormulasAccess ( "hacknetNodes.hacknetNodeCost" , 5 ) ;
return calculateNodeCost ( n , mult ) ;
} ,
constants : function ( ) {
checkFormulasAccess ( "hacknetNodes.constants" , 5 ) ;
return Object . assign ( { } , HacknetNodeConstants ) ;
} ,
} ,
hacknetServers : {
hashGainRate : function ( level , ramUsed , maxRam , cores , mult = 1 ) {
checkFormulasAccess ( "hacknetServers.hashGainRate" , 9 ) ;
return HScalculateHashGainRate ( level , ramUsed , maxRam , cores , mult ) ;
} ,
2021-09-09 05:47:34 +02:00
levelUpgradeCost : function ( startingLevel , extraLevels = 1 , costMult = 1 ) {
2021-09-05 01:09:30 +02:00
checkFormulasAccess ( "hacknetServers.levelUpgradeCost" , 9 ) ;
2021-09-09 05:47:34 +02:00
return HScalculateLevelUpgradeCost ( startingLevel , extraLevels , costMult ) ;
2021-09-05 01:09:30 +02:00
} ,
ramUpgradeCost : function ( startingRam , extraLevels = 1 , costMult = 1 ) {
checkFormulasAccess ( "hacknetServers.ramUpgradeCost" , 9 ) ;
return HScalculateRamUpgradeCost ( startingRam , extraLevels , costMult ) ;
} ,
coreUpgradeCost : function ( startingCore , extraCores = 1 , costMult = 1 ) {
checkFormulasAccess ( "hacknetServers.coreUpgradeCost" , 9 ) ;
return HScalculateCoreUpgradeCost ( startingCore , extraCores , costMult ) ;
} ,
2021-09-09 05:47:34 +02:00
cacheUpgradeCost : function ( startingCache , extraCache = 1 , costMult = 1 ) {
2021-09-05 01:09:30 +02:00
checkFormulasAccess ( "hacknetServers.cacheUpgradeCost" , 9 ) ;
2021-09-09 05:47:34 +02:00
return HScalculateCacheUpgradeCost ( startingCache , extraCache , costMult ) ;
2021-09-05 01:09:30 +02:00
} ,
hashUpgradeCost : function ( upgName , level ) {
checkFormulasAccess ( "hacknetServers.hashUpgradeCost" , 9 ) ;
const upg = Player . hashManager . getUpgrade ( upgName ) ;
if ( ! upg ) {
throw makeRuntimeErrorMsg (
"formulas.hacknetServers.calculateHashUpgradeCost" ,
` Invalid Hash Upgrade: ${ upgName } ` ,
) ;
}
return upg . getCost ( level ) ;
} ,
hacknetServerCost : function ( n , mult ) {
checkFormulasAccess ( "hacknetServers.hacknetServerCost" , 9 ) ;
return HScalculateServerCost ( n , mult ) ;
} ,
constants : function ( ) {
checkFormulasAccess ( "hacknetServers.constants" , 9 ) ;
return Object . assign ( { } , HacknetServerConstants ) ;
} ,
} ,
} , // end formulas
heart : {
// Easter egg function
break : function ( ) {
return Player . karma ;
} ,
} ,
exploit : function ( ) {
Player . giveExploit ( Exploit . UndocumentedFunctionCall ) ;
} ,
bypass : function ( doc ) {
// reset both fields first
doc . completely _unused _field = undefined ;
document . completely _unused _field = undefined ;
// set one to true and check that it affected the other.
document . completely _unused _field = true ;
if ( doc . completely _unused _field && workerScript . ramUsage === 1.6 ) {
Player . giveExploit ( Exploit . Bypass ) ;
}
doc . completely _unused _field = undefined ;
document . completely _unused _field = undefined ;
} ,
flags : function ( data ) {
data = toNative ( data ) ;
// We always want the help flag.
const args = { } ;
for ( const d of data ) {
let t = String ;
if ( typeof d [ 1 ] === "number" ) {
t = Number ;
} else if ( typeof d [ 1 ] === "boolean" ) {
t = Boolean ;
} else if ( Array . isArray ( d [ 1 ] ) ) {
t = [ String ] ;
2021-05-12 21:10:36 +02:00
}
2021-09-05 01:09:30 +02:00
const numDashes = d [ 0 ] . length > 1 ? 2 : 1 ;
args [ "-" . repeat ( numDashes ) + d [ 0 ] ] = t ;
}
const ret = libarg ( args , { argv : workerScript . args } ) ;
for ( const d of data ) {
2021-09-09 05:47:34 +02:00
if ( ! ret . hasOwnProperty ( "--" + d [ 0 ] ) || ! ret . hasOwnProperty ( "-" + d [ 0 ] ) ) ret [ d [ 0 ] ] = d [ 1 ] ;
2021-09-05 01:09:30 +02:00
}
for ( const key of Object . keys ( ret ) ) {
if ( ! key . startsWith ( "-" ) ) continue ;
const value = ret [ key ] ;
delete ret [ key ] ;
const numDashes = key . length === 2 ? 1 : 2 ;
ret [ key . slice ( numDashes ) ] = value ;
}
return ret ;
} ,
} ;
function getFunctionNames ( obj ) {
const functionNames = [ ] ;
for ( const [ key , value ] of Object . entries ( obj ) ) {
if ( typeof value == "function" ) {
functionNames . push ( key ) ;
} else if ( typeof value == "object" ) {
functionNames . push ( ... getFunctionNames ( value ) ) ;
}
2021-05-12 21:10:36 +02:00
}
2021-09-05 01:09:30 +02:00
return functionNames ;
}
2021-05-12 21:10:36 +02:00
2021-09-09 05:47:34 +02:00
const possibleLogs = Object . fromEntries ( [ ... getFunctionNames ( functions ) ] . map ( ( a ) => [ a , true ] ) ) ;
2021-05-12 21:10:36 +02:00
2021-09-05 01:09:30 +02:00
return functions ;
2019-04-13 03:22:46 +02:00
} // End NetscriptFunction()
2017-08-30 19:44:29 +02:00
2021-08-25 02:08:29 +02:00
export { NetscriptFunctions } ;