bitburner-src/dist/bitburner.d.ts

4805 lines
177 KiB
TypeScript
Raw Normal View History

2021-10-30 18:34:14 +02:00
/**
2021-10-30 21:46:34 +02:00
* Data representing the internal values of an Augmentation.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface AugmentationStats {
/** Multipler to hacking skill */
hacking_mult?: number;
/** Multipler to strength skill */
strength_mult?: number;
/** Multipler to defense skill */
defense_mult?: number;
/** Multipler to dexterity skill */
dexterity_mult?: number;
/** Multipler to agility skill */
agility_mult?: number;
/** Multipler to charisma skill */
charisma_mult?: number;
/** Multipler to hacking experience gain rate */
hacking_exp_mult?: number;
/** Multipler to strength experience gain rate */
strength_exp_mult?: number;
/** Multipler to defense experience gain rate */
defense_exp_mult?: number;
/** Multipler to dexterity experience gain rate */
dexterity_exp_mult?: number;
/** Multipler to agility experience gain rate */
agility_exp_mult?: number;
/** Multipler to charisma experience gain rate */
charisma_exp_mult?: number;
/** Multipler to chance of successfully performing a hack */
hacking_chance_mult?: number;
/** Multipler to hacking speed */
hacking_speed_mult?: number;
/** Multipler to amount of money the player gains from hacking */
hacking_money_mult?: number;
/** Multipler to amount of money injected into servers using grow */
hacking_grow_mult?: number;
/** Multipler to amount of reputation gained when working */
company_rep_mult?: number;
/** Multipler to amount of reputation gained when working */
faction_rep_mult?: number;
/** Multipler to amount of money gained from crimes */
crime_money_mult?: number;
/** Multipler to crime success rate */
crime_success_mult?: number;
/** Multipler to amount of money gained from working */
work_money_mult?: number;
/** Multipler to amount of money produced by Hacknet Nodes */
hacknet_node_money_mult?: number;
/** Multipler to cost of purchasing a Hacknet Node */
hacknet_node_purchase_cost_mult?: number;
/** Multipler to cost of ram for a Hacknet Node */
hacknet_node_ram_cost_mult?: number;
/** Multipler to cost of core for a Hacknet Node */
hacknet_node_core_cost_mult?: number;
/** Multipler to cost of leveling up a Hacknet Node */
hacknet_node_level_cost_mult?: number;
/** Multipler to Bladeburner max stamina */
bladeburner_max_stamina_mult?: number;
/** Multipler to Bladeburner stamina gain rate */
bladeburner_stamina_gain_mult?: number;
/** Multipler to effectiveness in Bladeburner Field Analysis */
bladeburner_analysis_mult?: number;
/** Multipler to success chance in Bladeburner contracts/operations */
bladeburner_success_chance_mult?: number;
}
/**
2021-10-30 21:46:34 +02:00
* All augmentation names.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type AugmentName =
| "Augmented Targeting I"
| "Augmented Targeting II"
| "Augmented Targeting III"
| "Synthetic Heart"
| "Synfibril Muscle"
| "Combat Rib I"
| "Combat Rib II"
| "Combat Rib III"
| "Nanofiber Weave"
| "NEMEAN Subdermal Weave"
| "Wired Reflexes"
| "Graphene Bone Lacings"
| "Bionic Spine"
| "Graphene Bionic Spine Upgrade"
| "Bionic Legs"
| "Graphene Bionic Legs Upgrade"
| "Speech Processor Implant"
| "TITN-41 Gene-Modification Injection"
| "Enhanced Social Interaction Implant"
| "BitWire"
| "Artificial Bio-neural Network Implant"
| "Artificial Synaptic Potentiation"
| "Enhanced Myelin Sheathing"
| "Synaptic Enhancement Implant"
| "Neural-Retention Enhancement"
| "DataJack"
| "Embedded Netburner Module"
| "Embedded Netburner Module Core Implant"
| "Embedded Netburner Module Core V2 Upgrade"
| "Embedded Netburner Module Core V3 Upgrade"
| "Embedded Netburner Module Analyze Engine"
| "Embedded Netburner Module Direct Memory Access Upgrade"
| "Neuralstimulator"
| "Neural Accelerator"
| "Cranial Signal Processors - Gen I"
| "Cranial Signal Processors - Gen II"
| "Cranial Signal Processors - Gen III"
| "Cranial Signal Processors - Gen IV"
| "Cranial Signal Processors - Gen V"
| "Neuronal Densification"
| "Nuoptimal Nootropic Injector Implant"
| "Speech Enhancement"
| "FocusWire"
| "PC Direct-Neural Interface"
| "PC Direct-Neural Interface Optimization Submodule"
| "PC Direct-Neural Interface NeuroNet Injector"
| "ADR-V1 Pheromone Gene"
| "ADR-V2 Pheromone Gene"
| "The Shadow's Simulacrum"
| "Hacknet Node CPU Architecture Neural-Upload"
| "Hacknet Node Cache Architecture Neural-Upload"
| "Hacknet Node NIC Architecture Neural-Upload"
| "Hacknet Node Kernel Direct-Neural Interface"
| "Hacknet Node Core Direct-Neural Interface"
| "NeuroFlux Governor"
| "Neurotrainer I"
| "Neurotrainer II"
| "Neurotrainer III"
| "HyperSight Corneal Implant"
| "LuminCloaking-V1 Skin Implant"
| "LuminCloaking-V2 Skin Implant"
| "HemoRecirculator"
| "SmartSonar Implant"
| "Power Recirculation Core"
| "QLink"
| "The Red Pill"
| "SPTN-97 Gene Modification"
| "ECorp HVMind Implant"
| "CordiARC Fusion Reactor"
| "SmartJaw"
| "Neotra"
| "Xanipher"
| "nextSENS Gene Modification"
| "OmniTek InfoLoad"
| "Photosynthetic Cells"
| "BitRunners Neurolink"
| "The Black Hand"
| "CRTX42-AA Gene Modification"
| "Neuregen Gene Modification"
| "CashRoot Starter Kit"
| "NutriGen Implant"
| "INFRARET Enhancement"
| "DermaForce Particle Barrier"
| "Graphene BranchiBlades Upgrade"
| "Graphene Bionic Arms Upgrade"
| "BrachiBlades"
| "Bionic Arms"
| "Social Negotiation Assistant (S.N.A)"
| "EsperTech Bladeburner Eyewear"
| "EMS-4 Recombination"
| "ORION-MKIV Shoulder"
| "Hyperion Plasma Cannon V1"
| "Hyperion Plasma Cannon V2"
| "GOLEM Serum"
| "Vangelis Virus"
| "Vangelis Virus 3.0"
| "I.N.T.E.R.L.I.N.K.E.D"
| "Blade's Runners"
| "BLADE-51b Tesla Armor"
| "BLADE-51b Tesla Armor: Power Cells Upgrade"
| "BLADE-51b Tesla Armor: Energy Shielding Upgrade"
| "BLADE-51b Tesla Armor: Unibeam Upgrade"
| "BLADE-51b Tesla Armor: Omnibeam Upgrade"
| "BLADE-51b Tesla Armor: IPU Upgrade"
| "The Blade's Simulacrum";
/**
2021-10-30 21:46:34 +02:00
* Return value of {@link Sleeve.getSleevePurchasableAugs | getSleevePurchasableAugs}
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface AugmentPair {
/** augmentation name */
name: AugmentName;
/** augmentation cost */
cost: number;
}
/**
2021-10-30 21:46:34 +02:00
* Options to affect the behavior of {@link NS.hack | hack}, {@link NS.grow | grow}, and {@link NS.weaken | weaken}.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface BasicHGWOptions {
/** Number of threads to use for this function. Must be less than or equal to the number of threads the script is running with. */
threads: number;
2021-10-30 21:46:34 +02:00
/** Set to true this action will affect the stock market. */
stock?: boolean;
2021-10-30 18:34:14 +02:00
}
/**
2021-10-30 21:46:34 +02:00
* All multipliers affecting the difficulty of the current challenge.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface BitNodeMultipliers {
/** Influences how quickly the player's agility level (not exp) scales */
AgilityLevelMultiplier: number;
/** Influences the base cost to purchase an augmentation. */
AugmentationMoneyCost: number;
/** Influences the base rep the player must have with a faction to purchase an augmentation. */
AugmentationRepCost: number;
/** Influences how quickly the player can gain rank within Bladeburner. */
BladeburnerRank: number;
/** Influences the cost of skill levels from Bladeburner. */
BladeburnerSkillCost: number;
/** Influences how quickly the player's charisma level (not exp) scales */
CharismaLevelMultiplier: number;
/** Influences the experience gained for each ability when a player completes a class. */
ClassGymExpGain: number;
/** Influences the amount of money gained from completing Coding Contracts */
CodingContractMoney: number;
/** Influences the experience gained for each ability when the player completes working their job. */
CompanyWorkExpGain: number;
/** Influences how much money the player earns when completing working their job. */
CompanyWorkMoney: number;
/** Influences the valuation of corporations created by the player. */
CorporationValuation: number;
/** Influences the base experience gained for each ability when the player commits a crime. */
CrimeExpGain: number;
/** Influences the base money gained when the player commits a crime. */
CrimeMoney: number;
/** Influences how many Augmentations you need in order to get invited to the Daedalus faction */
DaedalusAugsRequirement: number;
/** Influences how quickly the player's defense level (not exp) scales */
DefenseLevelMultiplier: number;
/** Influences how quickly the player's dexterity level (not exp) scales */
DexterityLevelMultiplier: number;
/** Influences how much rep the player gains in each faction simply by being a member. */
FactionPassiveRepGain: number;
/** Influences the experience gained for each ability when the player completes work for a Faction. */
FactionWorkExpGain: number;
/** Influences how much rep the player gains when performing work for a faction. */
FactionWorkRepGain: number;
/** Influences how much it costs to unlock the stock market's 4S Market Data API */
FourSigmaMarketDataApiCost: number;
/** Influences how much it costs to unlock the stock market's 4S Market Data (NOT API) */
FourSigmaMarketDataCost: number;
/** Influences the experienced gained when hacking a server. */
HackExpGain: number;
/** Influences how quickly the player's hacking level (not experience) scales */
HackingLevelMultiplier: number;
/** Influences how much money is produced by Hacknet Nodes and the hash rate of Hacknet Servers (unlocked in BitNode-9) */
HacknetNodeMoney: number;
/** Influences how much money it costs to upgrade your home computer's RAM */
HomeComputerRamCost: number;
/** Influences how much money is gained when the player infiltrates a company. */
InfiltrationMoney: number;
/** Influences how much rep the player can gain from factions when selling stolen documents and secrets */
InfiltrationRep: number;
/** Influences how much money can be stolen from a server when the player performs a hack against it through the Terminal. */
ManualHackMoney: number;
/** Influence how much it costs to purchase a server */
PurchasedServerCost: number;
/** Influences the maximum number of purchased servers you can have */
PurchasedServerLimit: number;
/** Influences the maximum allowed RAM for a purchased server */
PurchasedServerMaxRam: number;
/** Influences the minimum favor the player must have with a faction before they can donate to gain rep. */
RepToDonateToFaction: number;
/** Influences how much money can be stolen from a server when a script performs a hack against it. */
ScriptHackMoney: number;
/** Influences the growth percentage per cycle against a server. */
ServerGrowthRate: number;
/** Influences the maxmimum money that a server can grow to. */
ServerMaxMoney: number;
/** Influences the initial money that a server starts with. */
ServerStartingMoney: number;
/** Influences the initial security level (hackDifficulty) of a server. */
ServerStartingSecurity: number;
/** Influences the weaken amount per invocation against a server. */
ServerWeakenRate: number;
/** Influences how quickly the player's strength level (not exp) scales */
StrengthLevelMultiplier: number;
}
/**
* @public
*/
export declare interface Bladeburner {
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array of strings containing the names of all Bladeburner contracts.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.4 GB
2021-10-30 18:34:14 +02:00
* @returns Array of strings containing the names of all Bladeburner contracts.
*/
getContractNames(): BladeburnerContracts[];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array of strings containing the names of all Bladeburner operations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.4 GB
2021-10-30 18:34:14 +02:00
* @returns Array of strings containing the names of all Bladeburner operations.
*/
getOperationNames(): BladeburnerOperations[];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array of strings containing the names of all Bladeburner Black Ops.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.4 GB
2021-10-30 18:34:14 +02:00
* @returns Array of strings containing the names of all Bladeburner Black Ops.
*/
getBlackOpNames(): BladeburnerBlackOps[];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array of strings containing the names of all general Bladeburner actions.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.4 GB
2021-10-30 18:34:14 +02:00
* @returns Array of strings containing the names of all general Bladeburner actions.
*/
getGeneralActionNames(): BladeburnerGenActions[];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array of strings containing the names of all general Bladeburner skills.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.4 GB
2021-10-30 18:34:14 +02:00
* @returns Array of strings containing the names of all general Bladeburner skills.
*/
getSkillNames(): BladeburnerSkills[];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Attempts to start the specified Bladeburner action.
* Returns true if the action was started successfully, and false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match
* @returns True if the action was started successfully, and false otherwise.
*/
startAction(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Stops the current Bladeburner action.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
*/
stopBladeburnerAction(): void;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an object that represents the players current Bladeburner action.
* If the player is not performing an action, the function will return an object with the type property set to Idle.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @returns Object that represents the players current Bladeburner action.
*/
getCurrentAction(): BladeburnerCurAction;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the number of seconds it takes to complete the specified action
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Number of seconds it takes to complete the specified action.
*/
getActionTime(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the estimated success chance for the specified action.
* This chance is returned as a decimal value, NOT a percentage
* (e.g. if you have an estimated success chance of 80%, then this function will return 0.80, NOT 80).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Estimated success chance for the specified action.
*/
getActionEstimatedSuccessChance(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the average Bladeburner reputation gain for successfully
* completing the specified action.
* Note that this value is an average and the real reputation gain may vary slightly from this value.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @param level - Optional action level at which to calculate the gain
* @returns Average Bladeburner reputation gain for successfully completing the specified action.
*/
getActionRepGain(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
level: number,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the remaining count of the specified action.
*
* Note that this is meant to be used for Contracts and Operations.
* This function will return Infinity for actions such as Training and Field Analysis.
* This function will return 1 for BlackOps not yet completed regardless of wether
* the player has the required rank to attempt the mission or not.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Remaining count of the specified action.
*/
getActionCountRemaining(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the maximum level for this action.
*
* Returns -1 if an invalid action is specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Maximum level of the specified action.
*/
getActionMaxLevel(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the current level of this action.
*
* Returns -1 if an invalid action is specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Current level of the specified action.
*/
getActionCurrentLevel(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Return a boolean indicating whether or not this action is currently set to autolevel.
*
* Returns false if an invalid action is specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns True if the action is set to autolevel, and false otherwise.
*/
getActionAutolevel(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Enable/disable autoleveling for the specified action.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @param autoLevel - Whether or not to autolevel this action
*/
setActionAutolevel(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
autoLevel: boolean,
): void;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Set the level for the specified action.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @param level - Level to set this action to.
*/
setActionLevel(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
level: number,
): void;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the players Bladeburner Rank.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Players Bladeburner Rank.
*/
getRank(): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the rank required to complete this BlackOp.
*
* Returns -1 if an invalid action is specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param name - Name of BlackOp. Must be an exact match.
* @returns Rank required to complete this BlackOp.
*/
getBlackOpRank(name: BladeburnerBlackOps): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the number of Bladeburner skill points you have.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Number of Bladeburner skill points you have.
*/
getSkillPoints(): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* This function returns your level in the specified skill.
*
* The function returns -1 if an invalid skill name is passed in.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param skillName - Name of skill. Case-sensitive and must be an exact match
* @returns Level in the specified skill.
*/
getSkillLevel(name: BladeburnerSkills): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* This function returns the number of skill points needed to upgrade the specified skill.
*
* The function returns -1 if an invalid skill name is passed in.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param skillName - Name of skill. Case-sensitive and must be an exact match
* @returns Number of skill points needed to upgrade the specified skill.
*/
getSkillUpgradeCost(name: BladeburnerSkills): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Attempts to upgrade the specified Bladeburner skill.
*
* Returns true if the skill is successfully upgraded, and false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param skillName - Name of skill to be upgraded. Case-sensitive and must be an exact match
* @returns true if the skill is successfully upgraded, and false otherwise.
*/
upgradeSkill(name: BladeburnerSkills): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the number of Bladeburner team members you have assigned to the specified action.
*
* Setting a team is only applicable for Operations and BlackOps. This function will return 0 for other action types.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @returns Number of Bladeburner team members that were assigned to the specified action.
*/
getTeamSize(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Set the team size for the specified Bladeburner action.
*
* Returns the team size that was set, or -1 if the function failed.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param type - Type of action.
* @param name - Name of action. Must be an exact match.
* @param size - Number of team members to set. Will be converted using Math.round().
* @returns Number of Bladeburner team members you assigned to the specified action.
*/
setTeamSize(
type: BladeburnerActTypes,
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps,
size: number,
): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the estimated number of Synthoids in the specified city,
* or -1 if an invalid city was specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param cityName - Name of city. Case-sensitive
* @returns Estimated number of Synthoids in the specified city.
*/
getCityEstimatedPopulation(name: City): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the estimated number of Synthoid communities in the specified city,
* or -1 if an invalid city was specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param cityName - Name of city. Case-sensitive
* @returns Number of Synthoids communities in the specified city.
*/
getCityCommunities(name: City): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the chaos in the specified city,
* or -1 if an invalid city was specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param cityName - Name of city. Case-sensitive
* @returns Chaos in the specified city.
*/
getCityChaos(name: City): number;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the city that the player is currently in (for Bladeburner).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns City that the player is currently in (for Bladeburner).
*/
getCity(): City;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Attempts to switch to the specified city (for Bladeburner only).
*
* Returns true if successful, and false otherwise
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param cityName - Name of city. Case-sensitive
* @returns true if successful, and false otherwise
*/
switchCity(name: City): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns an array with two elements:
* * [Current stamina, Max stamina]
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* function getStaminaPercentage() {
* let res = bladeburner.getStamina();
* return res[0] / res[1];
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Array containing current stamina and max stamina.
*/
getStamina(): [number, number];
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Attempts to join the Bladeburner faction.
*
* Returns true if you successfully join the Bladeburner faction, or if you are already a member.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns True if you successfully join the Bladeburner faction, or if you are already a member, false otherwise.
*/
joinBladeburnerFaction(): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Attempts to join the Bladeburner division.
*
* Returns true if you successfully join the Bladeburner division, or if you are already a member.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns True if you successfully join the Bladeburner division, or if you are already a member, false otherwise.
*/
joinBladeburnerDivision(): boolean;
/**
* You have to be employed in the Bladeburner division and be in BitNode-7
* or have Source-File 7 in order to use this function.
*
* Returns the amount of accumulated bonus time (seconds) for the Bladeburner mechanic.
*
* Bonus time is accumulated when the game is offline or if the game is inactive in the browser.
*
* Bonus time makes the game progress faster, up to 5x the normal speed.
* For example, if an action takes 30 seconds to complete but youve accumulated over
* 30 seconds in bonus time, then the action will only take 6 seconds in real life to complete.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns Amount of accumulated bonus time (seconds) for the Bladeburner mechanic.
*/
getBonusTime(): number;
}
/**
2021-10-30 21:46:34 +02:00
* All Bladeburner action types.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type BladeburnerActTypes = "contracts" | "operations" | "black ops" | "general";
/**
2021-10-30 21:46:34 +02:00
* All Bladeburner black ops.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type BladeburnerBlackOps =
| "Operation Typhoon"
| "Operation Zero"
| "Operation X"
| "Operation Titan"
| "Operation Ares"
| "Operation Archangel"
| "Operation Juggernaut"
| "Operation Red Dragon"
| "Operation K"
| "Operation Deckard"
| "Operation Tyrell"
| "Operation Wallace"
| "Operation Shoulder of Orion"
| "Operation Hyron"
| "Operation Morpheus"
| "Operation Ion Storm"
| "Operation Annihilus"
| "Operation Ultron"
| "Operation Centurion"
| "Operation Vindictus"
| "Operation Daedalus";
/**
* @public
*/
export declare type BladeburnerContracts = "Tracking" | "Bounty Hunter" | "Retirement";
/**
2021-10-30 21:46:34 +02:00
* Bladeburner current action.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface BladeburnerCurAction {
/** Type of Action */
type: BladeburnerActTypes | "Idle";
/** Name of Action */
name: BladeburnerGenActions | BladeburnerContracts | BladeburnerOperations | BladeburnerBlackOps;
}
/**
2021-10-30 21:46:34 +02:00
* All Bladeburner General Actions.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type BladeburnerGenActions =
| "Training"
| "Field Analysis"
| "Recruitment"
| "Diplomacy"
| "Hyperbolic Regeneration Chamber";
/**
2021-10-30 21:46:34 +02:00
* All Bladeburner Ops.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type BladeburnerOperations =
| "Investigation"
| "Undercover Operation"
| "Sting Operation"
| "Raid"
| "Stealth Retirement Operation"
| "Assassination";
/**
2021-10-30 21:46:34 +02:00
* All Bladeburner Skills.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type BladeburnerSkills =
| "Blade's Intuition"
| "Cloak"
| "Marksman"
| "Weapon Proficiency"
| "Short-Circuit"
| "Digital Observer"
| "Tracer"
| "Overclock"
| "Reaper"
| "Evasive System"
| "Datamancer"
| "Cyber's Edge"
| "Hands of Midas"
| "Hyperdrive";
/**
* @public
*/
export declare interface CharacterInfo {
/** Current BitNode number */
bitnode: number;
/** Name of city you are currently in */
city: City;
/** Array of factions you are currently a member of */
factions: FactionName[];
/** Current health points */
hp: number;
/** Array of all companies at which you have jobs */
company: CompanyName[];
/** Array of job positions for all companies you are employed at. Same order as 'jobs' */
jobTitle: CompanyField[];
/** Maximum health points */
maxHp: number;
/** Boolean indicating whether or not you have a tor router */
tor: boolean;
/** Object with many of the player's multipliers from Augmentations/Source Files */
mult: CharacterMult;
/** Timed worked in ms */
timeWorked: number;
/** Hacking experience earned so far from work */
workHackExpGain: number;
/** Str experience earned so far from work */
workStrExpGain: number;
/** Def experience earned so far from work */
workDefExpGain: number;
/** Dex experience earned so far from work */
workDexExpGain: number;
/** Agi experience earned so far from work */
workAgiExpGain: number;
/** Cha experience earned so far from work */
workChaExpGain: number;
/** Reputation earned so far from work, if applicable */
workRepGain: number;
/** Money earned so far from work, if applicable */
workMoneyGain: number;
}
/**
* @public
*/
export declare interface CharacterMult {
/** Agility stat */
agility: number;
/** Agility exp */
agilityExp: number;
/** Company reputation */
companyRep: number;
/** Money earned from crimes */
crimeMoney: number;
/** Crime success chance */
crimeSuccess: number;
/** Defense stat */
defense: number;
/** Defense exp */
defenseExp: number;
/** Dexterity stat */
dexterity: number;
/** Dexterity exp */
dexterityExp: number;
/** Faction reputation */
factionRep: number;
/** Hacking stat */
hacking: number;
/** Hacking exp */
hackingExp: number;
/** Strength stat */
strength: number;
/** Strength exp */
strengthExp: number;
/** Money earned from jobs */
workMoney: number;
}
/**
2021-10-30 21:46:34 +02:00
* All cities.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type City = "Aevum" | "Chongqing" | "Sector-12" | "New Tokyo" | "Ishima" | "Volhaven";
/**
2021-10-30 21:46:34 +02:00
* Options to affect the behavior of {@link CodingContract} attempt.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface CodingAttemptOptions {
/** If truthy, then the function will return a string that states the contracts reward when it is successfully solved. */
returnReward: boolean;
}
/**
2021-10-30 21:46:34 +02:00
* Coding Contact API
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface CodingContract {
/**
* Attempts to solve the Coding Contract with the provided solution.
*
* @remarks 10 GB
* @param answer - Solution for the contract.
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @returns True if the solution was correct, false otherwise.
*/
2021-10-30 21:46:34 +02:00
attempt(answer: string | string[] | number, fn: string, host?: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Attempts to solve the Coding Contract with the provided solution.
*
* @remarks 10 GB
* @param answer - Solution for the contract.
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @param opts - Optional parameters for configuring function behavior.
* @returns True if the solution was correct, false otherwise. If the returnReward option is configured, then the function will instead return a string. If the contract is successfully solved, the string will contain a description of the contracts reward. Otherwise, it will be an empty string.
*/
2021-10-30 21:46:34 +02:00
attempt(answer: string | string[] | number, fn: string, host?: string, opts?: CodingAttemptOptions): boolean | string;
2021-10-30 18:34:14 +02:00
/**
* Returns a name describing the type of problem posed by the Coding Contract.
* (e.g. Find Largest Prime Factor, Total Ways to Sum, etc.)
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @returns Name describing the type of problem posed by the Coding Contract.
*/
2021-10-30 21:46:34 +02:00
getContractType(fn: string, host?: string): CodingContractTypes;
2021-10-30 18:34:14 +02:00
/**
* Get the full text description for the problem posed by the Coding Contract.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @returns Contracts text description.
*/
2021-10-30 21:46:34 +02:00
getDescription(fn: string, host?: string): string;
2021-10-30 18:34:14 +02:00
/**
* Get the data associated with the specific Coding Contract.
* Note that this is not the same as the contracts description.
* This is just the data that the contract wants you to act on in order to solve
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @returns The specified contracts data;
*/
2021-10-30 21:46:34 +02:00
getData(fn: string, host?: string): string;
2021-10-30 18:34:14 +02:00
/**
* Get the number of tries remaining on the contract before it self-destructs.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param fn - Filename of the contract.
* @param host - Host or IP of the server containing the contract. Optional. Defaults to current server if not provided.
* @returns How many attempts are remaining for the contract;
*/
2021-10-30 21:46:34 +02:00
getNumTriesRemaining(fn: string, host?: string): number;
2021-10-30 18:34:14 +02:00
}
/**
2021-10-30 21:46:34 +02:00
* All Coding contract types.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type CodingContractTypes =
| "Find Largest Prime Factor"
| "Subarray with Maximum Sum"
| "Total Ways to Sum"
| "Spiralize Matrix"
| "Array Jumping Game"
| "Merge Overlapping Intervals"
| "Generate IP Addresses"
| "Algorithmic Stock Trader I"
| "Algorithmic Stock Trader II"
| "Algorithmic Stock Trader III"
| "Algorithmic Stock Trader IV"
| "Minimum Path Sum in a Triangle"
| "Unique Paths in a Grid I"
| "Unique Paths in a Grid II"
| "Sanitize Parentheses in Expression"
| "Find All Valid Math Expressions";
/**
2021-10-30 21:46:34 +02:00
* All company work fields.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type CompanyField =
| "software"
| "software consultant"
| "it"
| "security engineer"
| "network engineer"
| "business"
| "business consultant"
| "security"
| "agent"
| "employee"
| "part-time employee"
| "waiter"
| "part-time waiter";
/**
2021-10-30 21:46:34 +02:00
* All companies.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type CompanyName =
// Sector-12
| "MegaCorp"
| "BladeIndustries"
| "FourSigma"
| "IcarusMicrosystems"
| "UniversalEnergy"
| "DeltaOne"
| "CIA"
| "NSA"
| "AlphaEnterprises"
| "CarmichaelSecurity"
| "FoodNStuff"
| "JoesGuns"
// Aevum
| "ECorp"
| "BachmanAndAssociates"
| "ClarkeIncorporated"
| "OmniTekIncorporated"
| "FulcrumTechnologies"
| "GalacticCybersystems"
| "AeroCorp"
| "WatchdogSecurity"
| "RhoConstruction"
| "AevumPolice"
| "NetLinkTechnologies"
// Volhaven
| "NWO"
| "HeliosLabs"
| "OmniaCybersystems"
| "LexoCorp"
| "SysCoreSecurities"
| "CompuTek"
// Chongqing
| "KuaiGongInternational"
| "SolarisSpaceSystems"
// Ishima
| "StormTechnologies"
| "NovaMedical"
| "OmegaSoftware"
// New Tokyo
| "DefComm"
| "VitaLife"
| "GlobalPharmaceuticals"
| "NoodleBar";
/**
2021-10-30 21:46:34 +02:00
* All crimes.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type Crime =
| "shoplift"
| "rob store"
| "mug"
| "larceny"
| "deal drugs"
| "bond forgery"
| "traffick arms"
| "homicide"
| "grand theft auto"
| "kidnap"
| "assassinate"
| "heist";
/**
2021-10-30 21:46:34 +02:00
* Data representing the internal values of a crime.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface CrimeStats {
/** Number representing the difficulty of the crime. Used for success chance calculations */
difficulty: number;
2021-10-30 21:46:34 +02:00
/** Amount of karma lost for successfully committing this crime */
2021-10-30 18:34:14 +02:00
karma: number;
/** How many people die as a result of this crime */
kills: number;
/** How much money is given */
money: number;
/** Name of crime */
name: number;
/** Milliseconds it takes to attempt the crime */
time: number;
/** Description of the crime activity */
type: string;
/** hacking level impact on success change of the crime */
hacking_success_weight: number;
/** strength level impact on success change of the crime */
strength_success_weight: number;
/** defense level impact on success change of the crime */
defense_success_weight: number;
/** dexterity level impact on success change of the crime */
dexterity_success_weight: number;
/** agility level impact on success change of the crime */
agility_success_weight: number;
/** charisma level impact on success change of the crime */
charisma_success_weight: number;
/** hacking exp gained from crime */
hacking_exp: number;
/** strength exp gained from crime */
strength_exp: number;
/** defense exp gained from crime */
defense_exp: number;
/** dexterity exp gained from crime */
dexterity_exp: number;
/** agility exp gained from crime */
agility_exp: number;
/** charisma exp gained from crime */
charisma_exp: number;
/** intelligence exp gained from crime */
intelligence_exp: number;
}
/**
2021-10-30 21:46:34 +02:00
* All factions.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type FactionName =
| "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"
| "Aevum"
| "Chongqing"
| "Ishima"
| "New Tokyo"
| "Sector-12"
| "Volhaven"
| "Speakers for the Dead"
| "The Dark Army"
| "The Syndicate"
| "Silhouette"
| "Tetrads"
| "Slum Snakes"
| "Netburners"
| "Tian Di Hui"
| "CyberSec"
| "Bladeburners";
/**
2021-10-30 21:46:34 +02:00
* All faction work types.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type FactionWork = "hacking" | "field" | "security";
/**
2021-10-30 21:46:34 +02:00
* Gang API
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface Gang {
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the names of all Gang members
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @returns Names of all Gang members.
*/
getMemberNames(): string[];
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get general information about the gang.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @returns Object containing general information about the gang.
*/
getGangInformation(): GangGenInfo;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get territory and power information about all gangs.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @returns Object containing territory and power information about all gangs.
*/
getOtherGangInformation(): GangOtherInfo;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get stat and equipment-related information about a Gang Member
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param name - Name of member.
* @returns Object containing stat and equipment-related information about a Gang Member.
*/
getMemberInformation(name: string): GangMemberInfo;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Returns boolean indicating whether a member can currently be recruited
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @returns True if a member can currently be recruited, false otherwise.
*/
canRecruitMember(): boolean;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Attempt to recruit a new gang member.
*
* Possible reasons for failure:
* * Cannot currently recruit a new member
* * There already exists a member with the specified name
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param name - Name of member to recruit.
* @returns True if the member was successfully recruited, false otherwise.
*/
recruitMember(name: string): boolean;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the name of all valid tasks that Gang members can be assigned to.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @returns All valid tasks that Gang members can be assigned to.
*/
getTaskNames(): GangTasks[];
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Attempts to assign the specified Gang Member to the specified task.
* If an invalid task is specified, the Gang member will be set to idle (Unassigned).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param memberName - Name of Gang member to assign.
* @param taskName - Task to assign.
* @returns True if the Gang Member was successfully assigned to the task, false otherwise.
*/
setMemberTask(memberName: string, taskName: GangTasks): boolean;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the stats of a gang task stats. This is typically used to evaluate which action should be executed next.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param name - Name of the task.
* @returns Detailed stats of a task.
*/
getTaskStats(name: GangTasks): GangTasksStats;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the name of all possible equipment/upgrades you can purchase for your Gang Members.
* This includes Augmentations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @returns Names of all Equpiment/Augmentations.
*/
getEquipmentNames(): (GangEquipment | GangAugmentations)[];
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the amount of money it takes to purchase a piece of Equipment or an Augmentation.
* If an invalid Equipment/Augmentation is specified, this function will return Infinity.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param equipName - Name of equipment.
* @returns Cost to purchase the specified Equipment/Augmentation (number). Infinity for invalid arguments
*/
getEquipmentCost(equipName: GangEquipment | GangAugmentations): number;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the specified equipment type.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param equipName - Name of equipment.
* @returns Type of the equipment.
*/
getEquipmentType(equipName: GangEquipment | GangAugmentations): GangEquipmentType;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Get the specified equipment stats.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param equipName - Name of equipment.
* @returns A dictionary containing the stats of the equipment.
*/
getEquipmentStats(equipName: GangEquipment | GangAugmentations): GangEquipmentStats;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Attempt to purchase the specified Equipment/Augmentation for the specified Gang member.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param memberName - Name of Gang member to purchase the equipment for.
* @param equipName - Name of Equipment/Augmentation to purchase.
* @returns True if the equipment was successfully purchased. False otherwise
*/
purchaseEquipment(memberName: string, equipName: GangEquipment | GangAugmentations): boolean;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Ascend the specified Gang Member.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param memberName - Name of member to ascend.
* @returns Object with info about the ascension results.
*/
ascendMember(memberName: string): GangMemberAscension;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Set whether or not the gang should engage in territory warfare
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param engage - Whether or not to engage in territory warfare.
*/
setTerritoryWarfare(engage: boolean): void;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Returns the chance you have to win a clash with the specified gang. The chance is returned in decimal form, not percentage
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param gangName - Target gang
* @returns Chance you have to win a clash with the specified gang.
*/
getChanceToWinClash(gangName: GangName): number;
/**
* If you are not in BitNode-2, then you must have Source-File 2 in order to use this function.
*
* Returns the amount of accumulated bonus time (seconds) for the Gang mechanic.
*
* Bonus time is accumulated when the game is offline or if the game is inactive in the browser.
*
* Bonus time makes the game progress faster, up to 10x the normal speed.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns Bonus time for the Gang mechanic in seconds.
*/
getBonusTime(): number;
}
/**
2021-10-30 21:46:34 +02:00
* All Gang augmentations.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GangAugmentations =
| "Bionic Arms"
| "Bionic Legs"
| "Bionic Spine"
| "BrachiBlades"
| "Nanofiber Weave"
| "Synthetic Heart"
| "Synfibril Muscle"
| "BitWire"
| "Neuralstimulator"
| "DataJack"
| "Graphene Bone Lacings";
/**
2021-10-30 21:46:34 +02:00
* All Gang equipment.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GangEquipment =
| "Baseball Bat"
| "Katana"
| "Glock 18C"
| "P90C"
| "Steyr AUG"
| "AK-47"
| "M15A10 Assault Rifle"
| "AWM Sniper Rifle"
| "Bulletproof Vest"
| "Full Body Armor"
| "Liquid Body Armor"
| "Graphene Plating Armor"
| "Ford Flex V20"
| "ATX1070 Superbike"
| "Mercedes-Benz S9001"
| "White Ferrari"
| "NUKE Rootkit"
| "Soulstealer Rootkit"
| "Demon Rootkit"
| "Hmap Node"
| "Jack the Ripper";
/**
2021-10-30 21:46:34 +02:00
* Object representing data representing a gang member equipment.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface GangEquipmentStats {
/** Strength multiplier */
str: number;
/** Defense multiplier */
def: number;
/** Dexterity multiplier */
dex: number;
/** Agility multiplier */
agi: number;
/** Charisma multiplier */
cha: number;
/** Hacking multiplier */
hack: number;
}
/**
2021-10-30 21:46:34 +02:00
* All Gang equipment type.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GangEquipmentType = "Weapon" | "Armor" | "Vehicle" | "Rootkit" | "Augmentation";
/**
2021-10-30 21:46:34 +02:00
* Gang general info.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface GangGenInfo {
/** Name of faction that the gang belongs to ("Slum Snakes", etc.) */
faction: GangName;
/** Boolean indicating whether or not its a hacking gang */
isHacking: boolean;
/** Money earned per second */
moneyGainRate: number;
/** Gang's power for territory warfare */
power: number;
/** Gang's respect */
respect: number;
/** Respect earned per second */
respectGainRate: number;
/** Amount of territory held. Returned in decimal form, not percentage */
territory: number;
/** Clash chance. Returned in decimal form, not percentage */
territoryClashChance: number;
/** Gang's wanted level */
wantedLevel: number;
/** Wanted level gained/lost per second (negative for losses) */
wantedLevelGainRate: number;
}
/**
* @public
*/
export declare interface GangMemberAscension {
/** Amount of respect lost from ascending */
respect: number;
2021-10-30 21:46:34 +02:00
/** Hacking multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
hack: number;
2021-10-30 21:46:34 +02:00
/** Strength multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
str: number;
2021-10-30 21:46:34 +02:00
/** Defense multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
def: number;
2021-10-30 21:46:34 +02:00
/** Dexterity multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
dex: number;
2021-10-30 21:46:34 +02:00
/** Agility multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
agi: number;
2021-10-30 21:46:34 +02:00
/** Charisma multiplier gained from ascending.*/
2021-10-30 18:34:14 +02:00
cha: number;
}
/**
* @public
*/
export declare interface GangMemberInfo {
/** Agility stat */
agility: number;
2021-10-30 21:46:34 +02:00
/** Agility multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
agilityEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Agility multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
agilityAscensionMult: number;
/** Array of names of all owned Augmentations */
augmentations: GangAugmentations[];
/** Charisma stat */
charisma: number;
2021-10-30 21:46:34 +02:00
/** Charisma multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
charismaEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Charisma multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
charismaAscensionMult: number;
/** Defense stat */
defense: number;
2021-10-30 21:46:34 +02:00
/** Defense multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
defenseEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Defense multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
defenseAscensionMult: number;
/** Dexterity stat */
dexterity: number;
2021-10-30 21:46:34 +02:00
/** Dexterity multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
dexterityEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Dexterity multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
dexterityAscensionMult: number;
/** Array of names of all owned Non-Augmentation Equipment */
equipment: GangEquipment[];
/** Hacking stat */
hacking: number;
2021-10-30 21:46:34 +02:00
/** Hacking multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
hackingEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Hacking multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
hackingAscensionMult: number;
/** Strength stat */
strength: number;
2021-10-30 21:46:34 +02:00
/** Strength multiplier from equipment.*/
2021-10-30 18:34:14 +02:00
strengthEquipMult: number;
2021-10-30 21:46:34 +02:00
/** Strength multiplier from ascension.*/
2021-10-30 18:34:14 +02:00
strengthAscensionMult: number;
/** Name of currently assigned task */
task: GangTasks;
}
/**
2021-10-30 21:46:34 +02:00
* All factions that can have a gang.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GangName =
| "Slum Snakes"
| "Tetrads"
| "The Syndicate"
| "The Dark Army"
| "Speakers for the Dead"
| "NiteSec"
| "The Black Hand";
/**
* @public
*/
export declare type GangOtherInfo = {
/** Stock Symbol */
[key in GangName]: GangOtherInfoObject[];
};
/**
* @public
*/
export declare interface GangOtherInfoObject {
/** Gang power */
power: number;
/** Gang territory, in decimal form */
territory: number;
}
/**
2021-10-30 21:46:34 +02:00
* All Gang tasks.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GangTasks =
| "Unassigned"
| "Ransomware"
| "Phishing"
| "Identity Theft"
| "DDoS Attacks"
| "Plant Virus"
| "Fraud & Counterfeiting"
| "Money Laundering"
| "Cyberterrorism"
| "Ethical Hacking"
| "Mug People"
| "Deal Drugs"
| "Strongarm Civilians"
| "Run a Con"
| "Armed Robbery"
| "Traffick Illegal Arms"
| "Threaten & Blackmail"
| "Human Trafficking"
| "Terrorism"
| "Vigilante Justice"
| "Train Combat"
| "Train Hacking"
| "Train Charisma"
| "Territory Warfare";
/**
2021-10-30 21:46:34 +02:00
* Object representing data representing a gang member task.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface GangTasksStats {
/** Task name */
name: GangTasks;
/** Task Description */
desc: string;
/** Is a task of a hacking gang */
isHacking: boolean;
/** Is a task of a combat gang */
isCombat: boolean;
/** Base respect earned */
baseRespect: number;
/** Base wanted earned */
baseWanted: number;
/** Base money earned */
baseMoney: number;
/** Hacking skill impact on task scaling */
hackWeight: number;
/** Stength skill impact on task scaling */
strWeight: number;
/** Defense skill impact on task scaling */
defWeight: number;
/** Dexterity skill impact on task scaling */
dexWeight: number;
/** Agility skill impact on task scaling */
agiWeight: number;
/** Charisma skill impact on task scaling */
chaWeight: number;
/** Number representing the difficulty of the task */
difficulty: number;
/** Territory impact on task scaling */
territory: GangTasksTerritory;
}
/**
* @public
*/
export declare interface GangTasksTerritory {
/** Money gain impact on task scaling */
money: number;
/** Respect gain impact on task scaling */
respect: number;
/** Wanted gain impact on task scaling */
wanted: number;
}
/**
2021-10-30 21:46:34 +02:00
* All gyms.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type Gym = "Crush Fitness Gym" | "Snap Fitness Gym" | "Iron Gym" | "Powerhouse Gym" | "Millenium Fitness Gym";
/**
2021-10-30 21:46:34 +02:00
* All stats that can be trained at gyms.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type GymStat = "str" | "def" | "dex" | "agi";
/**
2021-10-30 21:46:34 +02:00
* Hack related multipliers.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface HackingMultipliers {
/** Player's hacking chance multiplier. */
chance: number;
/** Player's hacking speed multiplier. */
speed: number;
/** Player's hacking money stolen multiplier. */
money: number;
/** Player's hacking growth multiplier */
growth: number;
}
/**
2021-10-30 21:46:34 +02:00
* Hacknet API
2021-10-30 18:34:14 +02:00
* @public
*/
2021-10-30 21:46:34 +02:00
export declare interface Hacknet {
2021-10-30 18:34:14 +02:00
/**
* Returns the number of Hacknet Nodes you own.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns number of hacknet nodes.
*/
numNodes(): number;
/**
* Purchases a new Hacknet Node. Returns a number with the index of the
* Hacknet Node. This index is equivalent to the number at the end of
2021-10-30 21:46:34 +02:00
* the Hacknet Nodes name (e.g The Hacknet Node named `hacknet-node-4`
2021-10-30 18:34:14 +02:00
* will have an index of 4).
*
* If the player cannot afford to purchase a new Hacknet Node then the function will return -1.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns The index of the Hacknet Node or if the player cannot afford to purchase a new Hacknet Node the function will return -1.
*/
purchaseNode(): number;
/**
* Returns the cost of purchasing a new Hacknet Node.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns Cost of purchasing a new Hacknet Node.
*/
getPurchaseNodeCost(): number;
/**
* Returns an object containing a variety of stats about the specified Hacknet Node.
*
* Note that for Hacknet Nodes, production refers to the amount of money the node generates.
* For Hacknet Servers (the upgraded version of Hacknet Nodes), production refers to the
* amount of hashes the node generates.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node
* @returns Object containing a variety of stats about the specified Hacknet Node.
*/
getNodeStats(index: number): NodeStats;
/**
* Tries to upgrade the level of the specified Hacknet Node by n.
*
* Returns true if the Hacknet Nodes level is successfully upgraded by n
* or if it is upgraded by some positive amount and the Node reaches its max level.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of levels to purchase. Must be positive. Rounded to nearest integer.
* @returns True if the Hacknet Nodes level is successfully upgraded, false otherwise.
*/
upgradeLevel(index: number, n: number): boolean;
/**
* Tries to upgrade the specified Hacknet Nodes RAM n times.
* Note that each upgrade doubles the Nodes RAM.
* So this is equivalent to multiplying the Nodes RAM by 2 n.
*
* Returns true if the Hacknet Nodes RAM is successfully upgraded n times
* or if it is upgraded some positive number of times and the Node reaches it max RAM.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of times to upgrade RAM. Must be positive. Rounded to nearest integer.
* @returns True if the Hacknet Nodes ram is successfully upgraded, false otherwise.
*/
upgradeRam(index: number, n: number): boolean;
/**
* Tries to purchase n cores for the specified Hacknet Node.
*
* Returns true if it successfully purchases n cores for the Hacknet Node
* or if it purchases some positive amount and the Node reaches its max number of cores.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of cores to purchase. Must be positive. Rounded to nearest integer.
* @returns True if the Hacknet Nodes cores are successfully purchased, false otherwise.
*/
upgradeCore(index: number, n: number): boolean;
/**
* This function is only applicable for Hacknet Servers (the upgraded version of a Hacknet Node).
*
* Tries to upgrade the specified Hacknet Servers cache n times.
*
* Returns true if it successfully upgrades the Servers cache n times,
* or if it purchases some positive amount and the Server reaches its max cache level.
*
* Returns false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of cache levels to purchase. Must be positive. Rounded to nearest integer.
* @returns True if the Hacknet Nodes cores are successfully purchased, false otherwise.
*/
upgradeCache(index: number, n: number): boolean;
/**
* Returns the cost of upgrading the specified Hacknet Node by n levels.
*
* If an invalid value for n is provided, then this function returns 0.
* If the specified Hacknet Node is already at max level, then Infinity is returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of levels to upgrade. Must be positive. Rounded to nearest integer.
* @returns Cost of upgrading the specified Hacknet Node.
*/
getLevelUpgradeCost(index: number, n: number): number;
/**
* Returns the cost of upgrading the RAM of the specified Hacknet Node n times.
*
* If an invalid value for n is provided, then this function returns 0.
* If the specified Hacknet Node is already at max level, then Infinity is returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of times to upgrade RAM. Must be positive. Rounded to nearest integer.
* @returns Cost of upgrading the specified Hacknet Node's ram.
*/
getRamUpgradeCost(index: number, n: number): number;
/**
* Returns the cost of upgrading the number of cores of the specified Hacknet Node by n.
*
* If an invalid value for n is provided, then this function returns 0.
* If the specified Hacknet Node is already at max level, then Infinity is returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of times to upgrade cores. Must be positive. Rounded to nearest integer.
* @returns Cost of upgrading the specified Hacknet Node's number of cores.
*/
getCoreUpgradeCost(index: number, n: number): number;
/**
* This function is only applicable for Hacknet Servers (the upgraded version of a Hacknet Node).
*
* Returns the cost of upgrading the cache level of the specified Hacknet Server by n.
*
* If an invalid value for n is provided, then this function returns 0.
* If the specified Hacknet Node is already at max level, then Infinity is returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param index - Index/Identifier of Hacknet Node.
* @param n - Number of times to upgrade cache. Must be positive. Rounded to nearest integer.
* @returns Cost of upgrading the specified Hacknet Node's cache.
*/
getCacheUpgradeCost(index: number, n: number): number;
/**
* This function is only applicable for Hacknet Servers (the upgraded version of a Hacknet Node).
*
* Returns the number of hashes you have.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns Number of hashes you have.
*/
numHashes(): number;
/**
* This function is only applicable for Hacknet Servers (the upgraded version of a Hacknet Node).
*
* Returns the number of hashes required for the specified upgrade. The name of the upgrade must be an exact match.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* var upgradeName = "Sell for Corporation Funds";
* if (hacknet.numHashes() > hacknet.hashCost(upgradeName)) {
* hacknet.spendHashes(upgName);
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param upgName - Name of the upgrade of Hacknet Node.
* @returns Number of hashes required for the specified upgrade.
*/
hashCost(upgName: HashUpgrades): number;
/**
* This function is only applicable for Hacknet Servers (the upgraded version of a Hacknet Node).
*
* Spend the hashes generated by your Hacknet Servers on an upgrade.
* Returns a boolean value - true if the upgrade is successfully purchased, and false otherwise.
*
* The name of the upgrade must be an exact match.
2021-10-30 21:46:34 +02:00
* The `upgTarget` argument is used for upgrades such as `Reduce Minimum Security`, which applies to a specific server.
* In this case, the `upgTarget` argument must be the hostname of the server.
2021-10-30 18:34:14 +02:00
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* hacknet.spendHashes("Sell for Corporation Funds");
* hacknet.spendHashes("Increase Maximum Money", "foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param upgName - Name of the upgrade of Hacknet Node.
* @param upgTarget - Object to which upgrade applies. Required for certain upgrades.
* @returns True if the upgrade is successfully purchased, and false otherwise..
*/
2021-10-30 21:46:34 +02:00
spendHashes(upgName: HashUpgrades, upgTarget?: string): boolean;
2021-10-30 18:34:14 +02:00
}
/**
2021-10-30 21:46:34 +02:00
* Hacknet related multipliers.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface HacknetMultipliers {
/** Player's hacknet production multiplier */
production: number;
/** Player's hacknet purchase cost multiplier */
purchaseCost: number;
/** Player's hacknet ram cost multiplier */
ramCost: number;
/** Player's hacknet core cost multiplier */
coreCost: number;
/** Player's hacknet level cost multiplier */
levelCost: number;
}
/**
* @public
*/
export declare type Handle = string | Port;
/**
2021-10-30 21:46:34 +02:00
* All Hash upgrade names.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type HashUpgrades =
| "Sell for Money"
| "Sell for Corporation Funds"
| "Reduce Minimum Security"
| "Increase Maximum Money"
| "Improve Studying"
| "Improve Gym Training"
| "Exchange for Corporation Research"
| "Exchange for Bladeburner Rank"
| "Exchange for Bladeburner SP"
| "Generate Coding Contract";
/**
2021-10-30 21:46:34 +02:00
* Object representing all the values related to a hacknet node.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface NodeStats {
2021-10-30 21:46:34 +02:00
/** Node's name */
2021-10-30 18:34:14 +02:00
name: string;
/** Node's level */
level: number;
/** Node's RAM */
ram: number;
/** Node's number of cores */
cores: number;
/** Cache level. Only applicable for Hacknet Servers */
cache: number;
/** Hash Capacity provided by this Node. Only applicable for Hacknet Servers */
hashCapacity: number;
/** Node's production per second */
production: number;
/** Number of seconds since Node has been purchased */
timeOnline: number;
/** Total number of money Node has produced */
totalProduction: number;
}
/**
2021-10-30 21:46:34 +02:00
* Collection of all functions passed to scripts
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface NS extends Singularity {
/**
2021-10-30 21:46:34 +02:00
* Namespace for hacknet related functions.
* @remarks
2021-10-30 18:34:14 +02:00
* Not all functions in the Hacknet Node API are immediately available.
*
* Note that none of these functions will write to the scripts logs.
*
* If you want to see what your script is doing you will have to print to the logs yourself.
*
2021-10-30 21:46:34 +02:00
* 4 GB
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
readonly hacknet: Hacknet;
2021-10-30 18:34:14 +02:00
/**
2021-10-30 21:46:34 +02:00
*
* Namespace for bladeburner related functions.
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
readonly bladeburner: Bladeburner;
/**
2021-10-30 21:46:34 +02:00
*
* Namespace for codingcontract related functions.
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
readonly codingcontract: CodingContract;
/**
2021-10-30 21:46:34 +02:00
*
* Namespace for gang related functions.
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
readonly gang: Gang;
/**
2021-10-30 21:46:34 +02:00
*
* Namespace for sleeve related functions.
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
readonly sleeve: Sleeve;
/**
2021-10-30 21:46:34 +02:00
*
* Namespace for stock related functions.
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
readonly stock: TIX;
/**
2021-10-30 21:46:34 +02:00
* Arguments passed into the script.
*
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* Arguments passed into a script can be accessed using a normal
* array using the [] operator (args[0], args[1], etc).
*
2021-10-30 21:46:34 +02:00
* It is also possible to get the number of arguments that was passed into a script using: 'args.length'
2021-10-30 18:34:14 +02:00
* WARNING: Do not try to modify the args array. This will break the game.
*/
2021-10-30 21:46:34 +02:00
readonly args: (string | number)[];
2021-10-30 18:34:14 +02:00
/**
* Function that is used to try and hack servers to steal money and gain hacking experience.
* The runtime for this command depends on your hacking level and the target servers
* security level. In order to hack a server you must first gain root access to that server
* and also have the required hacking level.
*
* A script can hack a server from anywhere. It does not need to be running on the same
2021-10-30 21:46:34 +02:00
* server to hack that server. For example, you can create a script that hacks the `foodnstuff`
2021-10-30 18:34:14 +02:00
* server and run that script on any server in the game.
*
2021-10-30 21:46:34 +02:00
* A successful `hack()` on a server will raise that servers security level by 0.002.
2021-10-30 18:34:14 +02:00
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* hack("foodnstuff");
* hack("10.1.2.3");
* hack("foodnstuff", { threads: 5 }); // Only use 5 threads to hack
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
* @param host - Hostname of the target server to hack.
2021-10-30 18:34:14 +02:00
* @param opts - Optional parameters for configuring function behavior.
* @returns The amount of money stolen if the hack is successful, and zero otherwise.
*/
2021-10-30 21:46:34 +02:00
hack(host: string, opts?: BasicHGWOptions): Promise<number>;
2021-10-30 18:34:14 +02:00
/**
* Use your hacking skills to increase the amount of money available on a server.
* The runtime for this command depends on your hacking level and the target servers
2021-10-30 21:46:34 +02:00
* security level. When `grow` completes, the money available on a target server will
2021-10-30 18:34:14 +02:00
* be increased by a certain, fixed percentage. This percentage is determined by the
* target servers growth rate (which varies between servers) and security level. Generally,
* higher-level servers have higher growth rates. The getServerGrowth() function can be used
* to obtain a servers growth rate.
*
2021-10-30 21:46:34 +02:00
* Like hack, `grow` can be called on any server, regardless of where the script is running.
2021-10-30 18:34:14 +02:00
* The grow() command requires root access to the target server, but there is no required hacking
* level to run the command. It also raises the security level of the target server by 0.004.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* grow("foodnstuff");
* grow("foodnstuff", { threads: 5 }); // Only use 5 threads to grow
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.15 GB
* @param host - Hostname of the target server to grow.
2021-10-30 18:34:14 +02:00
* @param opts - Optional parameters for configuring function behavior.
* @returns The number by which the money on the server was multiplied for the growth.
*/
2021-10-30 21:46:34 +02:00
grow(host: string, opts?: BasicHGWOptions): Promise<number>;
2021-10-30 18:34:14 +02:00
/**
* Use your hacking skills to attack a servers security, lowering the servers security level.
* The runtime for this command depends on your hacking level and the target servers security
* level. This function lowers the security level of the target server by 0.05.
*
2021-10-30 21:46:34 +02:00
* Like hack and grow, `weaken` can be called on any server, regardless of
2021-10-30 18:34:14 +02:00
* where the script is running. This command requires root access to the target server, but
* there is no required hacking level to run the command.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* weaken("foodnstuff");
* weaken("foodnstuff", { threads: 5 }); // Only use 5 threads to weaken
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.15 GB
* @param host - Hostname of the target server to weaken.
2021-10-30 18:34:14 +02:00
* @param opts - Optional parameters for configuring function behavior.
* @returns The amount by which the target servers security level was decreased. This is equivalent to 0.05 multiplied by the number of script threads.
*/
2021-10-30 21:46:34 +02:00
weaken(host: string, opts?: BasicHGWOptions): Promise<number>;
2021-10-30 18:34:14 +02:00
/**
* Returns the security decrease that would occur if a weaken with this many threads happened.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param threads - Amount of threads that will be used.
* @param cores - Optional. The number of cores of the server that would run weaken.
* @returns The security decrease.
*/
weakenAnalyze(threads: number, cores?: number): number;
/**
* This function returns the number of script threads you need when running the hack command
* to steal the specified amount of money from the target server.
* If hackAmount is less than zero or greater than the amount of money available on the server,
* then this function returns -1.
*
* Warning: The value returned by this function isnt necessarily a whole number.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //For example, lets say the foodnstuff server has $10m and you run:
* hackAnalyzeThreads("foodnstuff", 1e6);
* //If this function returns 50, this means that if your next hack call is run on a script with 50 threads, it will steal $1m from the foodnstuff server.
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
* @param host - Hostname of the target server to analyze.
2021-10-30 18:34:14 +02:00
* @param hackAmount - Amount of money you want to hack from the server.
* @returns The number of threads needed to hack the server for hackAmount money.
*/
2021-10-30 21:46:34 +02:00
hackAnalyzeThreads(host: string, hackAmount: number): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the percentage of the specified servers money you will steal with a single hack.
* This value is returned in percentage form, not decimal
* (Netscript functions typically return in decimal form, but not this one).
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //For example, assume the following returns 1:
* hackAnalyzePercent("foodnstuff");
* //This means that if hack the foodnstuff server, then you will steal 1% of its total money. If you hack using N threads, then you will steal N% of its total money.
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
* @returns The percentage of money you will steal from the target server with a single hack.
*/
2021-10-30 21:46:34 +02:00
hackAnalyzePercent(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the security increase that would occur if a hack with this many threads happened.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param threads - Amount of threads that will be used.
* @returns The security increase.
*/
hackAnalyzeSecurity(threads: number): number;
/**
* Returns the chance you have of successfully hacking the specified server.
*
* This returned value is in decimal form, not percentage.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
* @returns The chance you have of successfully hacking the target server.
*/
2021-10-30 21:46:34 +02:00
hackChance(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* This function returns the number of growths needed in order to increase
* the amount of money available on the specified server by the specified amount.
* The specified amount is multiplicative and is in decimal form, not percentage.
*
* Warning: The value returned by this function isnt necessarily a whole number.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //For example, if you want to determine how many grow calls you need to double the amount of money on foodnstuff, you would use:
* growthAnalyze("foodnstuff", 2);
* //If this returns 100, then this means you need to call grow 100 times in order to double the money (or once with 100 threads).
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
* @param growthAmount - Multiplicative factor by which the server is grown. Decimal form..
* @returns The amount of grow calls needed to grow the specified server by the specified amount
*/
2021-10-30 21:46:34 +02:00
growthAnalyze(host: string, growthAmount: number): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the security increase that would occur if a grow with this many threads happened.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param threads - Amount of threads that will be used.
* @returns The security increase.
*/
growthAnalyzeSecurity(threads: number): number;
/**
* Suspends the script for n milliseconds.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param millis - Number of milliseconds to sleep.
* @returns
*/
sleep(millis: number): Promise<void>;
/**
* Prints a value or a variable to the scripts logs.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param msg - Value to be printed.
*/
2021-10-30 21:46:34 +02:00
print(msg: any): void;
2021-10-30 18:34:14 +02:00
/**
* Prints a value or a variable to the Terminal.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param msg - Value to be printed.
*/
2021-10-30 21:46:34 +02:00
tprint(msg: any): void;
2021-10-30 18:34:14 +02:00
/**
* Clears the scripts logs.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
clearLog(): void;
/**
2021-10-30 21:46:34 +02:00
* Disables logging for the given function.
* @remarks
* RAM cost: 0 GB
* Logging can be disabled for all functions by passing `ALL` as the argument.
2021-10-30 18:34:14 +02:00
*
* Note that this does not completely remove all logging functionality.
* This only stops a function from logging when the function is successful.
* If the function fails, it will still log the reason for failure.
*
* Notable functions that cannot have their logs disabled: run,
* exec, exit.
*
* @param fn - Name of function for which to disable logging.
*/
disableLog(fn: string): void;
/**
2021-10-30 21:46:34 +02:00
* Re-enables logging for the given function. If `ALL` is passed into this
* function as an argument, then it will revert the effects of disableLog(`ALL`).
2021-10-30 18:34:14 +02:00
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param fn - Name of function for which to enable logging.
*/
enableLog(fn: string): void;
/**
* Checks the status of the logging for the given function.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param fn - Name of function to check.
2021-10-30 21:46:34 +02:00
* @returns Returns a boolean indicating whether or not logging is enabled for that function (or `ALL`)
2021-10-30 18:34:14 +02:00
*/
isLogEnabled(fn: string): boolean;
/**
* Returns a scripts logs. The logs are returned as an array, where each line is an element in the array.
* The most recently logged line is at the end of the array.
* Note that there is a maximum number of lines that a script stores in its logs. This is configurable in the games options.
* If the function is called with no arguments, it will return the current scripts logs.
*
* Otherwise, the fn, hostname/ip, and args arguments can be used to get the logs from another script.
* Remember that scripts are uniquely identified by both their names and arguments.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Get logs from foo.script on the current server that was run with no args
* getScriptLogs("foo.script");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Open logs from foo.script on the foodnstuff server that was run with no args
* getScriptLogs("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Open logs from foo.script on the foodnstuff server that was run with the arguments [1, "test"]
* getScriptLogs("foo.script", "foodnstuff", 1, "test");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param fn - Optional. Filename of script to get logs from.
2021-10-30 21:46:34 +02:00
* @param host - Optional. Hostname of the server that the script is on.
2021-10-30 18:34:14 +02:00
* @param args - Arguments to identify which scripts to get logs for.
* @returns Returns an string array, where each line is an element in the array. The most recently logged line is at the end of the array.
*/
2021-10-30 21:46:34 +02:00
getScriptLogs(fn?: string, host?: string, ...args: any[]): string[];
2021-10-30 18:34:14 +02:00
/**
* Opens a scripts logs. This is functionally the same as the tail Terminal command.
*
* If the function is called with no arguments, it will open the current scripts logs.
*
* Otherwise, the fn, hostname/ip, and args arguments can be used to get the logs from another script.
* Remember that scripts are uniquely identified by both their names and arguments.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Open logs from foo.script on the current server that was run with no args
* tail("foo.script");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Get logs from foo.script on the foodnstuff server that was run with no args
* tail("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Get logs from foo.script on the foodnstuff server that was run with the arguments [1, "test"]
* tail("foo.script", "foodnstuff", 1, "test");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param fn - Optional. Filename of the script being tailed. If omitted, the current script is tailed.
2021-10-30 21:46:34 +02:00
* @param host - Optional. Hostname of the script being tailed. Defaults to the server this script is running on. If args are specified, this is not optional.
2021-10-30 18:34:14 +02:00
* @param args - Arguments for the script being tailed.
*/
2021-10-30 21:46:34 +02:00
tail(fn?: string, host?: string, ...args: any[]): void;
2021-10-30 18:34:14 +02:00
/**
* Returns an array containing the hostnames or IPs of all servers that are one
* node way from the specified target server. The hostnames/IPs in the returned
* array are strings.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.2 GB
* @param host - Hostname of the server to scan.
2021-10-30 18:34:14 +02:00
* @param hostnames - Optional boolean specifying whether the function should output hostnames (if true) or IP addresses (if false).
* @returns Returns an string of hostnames or IP.
*/
2021-10-30 21:46:34 +02:00
scan(host: string, hostnames?: boolean): string[];
2021-10-30 18:34:14 +02:00
/**
* Runs the NUKE.exe program on the target server. NUKE.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* nuke("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
nuke(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Runs the BruteSSH.exe program on the target server. BruteSSH.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* brutessh("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
brutessh(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Runs the FTPCrack.exe program on the target server. FTPCrack.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* ftpcrack("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
ftpcrack(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Runs the relaySMTP.exe program on the target server. relaySMTP.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* relaysmtp("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
relaysmtp(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Runs the HTTPWorm.exe program on the target server. HTTPWorm.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* httpworm("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
httpworm(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Runs the SQLInject.exe program on the target server. SQLInject.exe must exist on your home computer.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* sqlinject("foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
* @param host - Hostname of the target server.
2021-10-30 18:34:14 +02:00
*/
2021-10-30 21:46:34 +02:00
sqlinject(host: string): void;
2021-10-30 18:34:14 +02:00
/**
* Run a script as a separate process. This function can only be used to run scripts located on the
* current server (the server running the script that calls this function). Requires a significant
* amount of RAM to run this command.
*
* If the script was successfully started, then this functions returns the PID of that script.
* Otherwise, it returns 0.
*
* PID stands for Process ID. The PID is a unique identifier for each script.
* The PID will always be a positive integer.
*
* Running this function with a numThreads argument of 0 will return 0 without running the script.
* However, running this function with a negative numThreads argument will cause a runtime error.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The simplest way to use the run command is to call it with just the script name. The following example will run foo.script single-threaded with no arguments:
* run("foo.script");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following example will run foo.script but with 5 threads instead of single-threaded:
* run("foo.script", 5);
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //This next example will run foo.script single-threaded, and will pass the string foodnstuff into the script as an argument:
* run("foo.script", 1, 'foodnstuff');
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to run.
* @param numThreads - Optional thread count for new script. Set to 1 by default. Will be rounded to nearest integer.
* @param args - Additional arguments to pass into the new script that is being run. Note that if any arguments are being passed into the new script, then the second argument numThreads must be filled in with a value.
* @returns Returns the PID of a successfully started script, and 0 otherwise.
*/
2021-10-30 21:46:34 +02:00
run(script: string, numThreads?: number, ...args: string[]): number;
2021-10-30 18:34:14 +02:00
/**
* Run a script as a separate process on a specified server. This is similar to the run function
* except that it can be used to run a script on any server, instead of just the current server.
*
* If the script was successfully started, then this functions returns the PID of that script.
* Otherwise, it returns 0.
*
* PID stands for Process ID. The PID is a unique identifier for each script.
* The PID will always be a positive integer.
*
* Running this function with a numThreads argument of 0 will return 0 without running the script.
* However, running this function with a negative numThreads argument will cause a runtime error.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The simplest way to use the exec command is to call it with just the script name and the target server. The following example will try to run generic-hack.script on the foodnstuff server:
* exec("generic-hack.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following example will try to run the script generic-hack.script on the joesguns server with 10 threads:
* exec("generic-hack.script", "joesguns", 10);
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //This last example will try to run the script foo.script on the foodnstuff server with 5 threads. It will also pass the number 1 and the string “test” in as arguments to the script:
* exec("foo.script", "foodnstuff", 5, 1, "test");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1.3 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to execute.
2021-10-30 21:46:34 +02:00
* @param host - Hostname of the `target server` on which to execute the script.
2021-10-30 18:34:14 +02:00
* @param numThreads - Optional thread count for new script. Set to 1 by default. Will be rounded to nearest integer.
* @param args - Additional arguments to pass into the new script that is being run. Note that if any arguments are being passed into the new script, then the third argument numThreads must be filled in with a value.
* @returns Returns the PID of a successfully started script, and 0 otherwise.
*/
2021-10-30 21:46:34 +02:00
exec(script: string, host: string, numThreads?: number, ...args: string[]): number;
2021-10-30 18:34:14 +02:00
/**
* Terminates the current script, and then after a delay of about 10 seconds it will execute the
* newly-specified script. The purpose of this function is to execute a new script without being
* constrained by the RAM usage of the current one. This function can only be used to run scripts
* on the local server.
*
* Because this function immediately terminates the script, it does not have a return value.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following example will execute the script foo.script with 10 threads and the arguments foodnstuff and 90:
* spawn('foo.script', 10, 'foodnstuff', 90);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to execute.
* @param numThreads - Number of threads to spawn new script with. Will be rounded to nearest integer.
* @param args - Additional arguments to pass into the new script that is being run.
*/
2021-10-30 21:46:34 +02:00
spawn(script: string, numThreads?: number, ...args: string[]): void;
2021-10-30 18:34:14 +02:00
/**
* Kills the script on the target server specified by the scripts name and arguments.
* Remember that scripts are uniquely identified by both their name and arguments.
2021-10-30 21:46:34 +02:00
* For example, if `foo.script` is run with the argument 1, then this is not the same as
* `foo.script` run with the argument 2, even though they have the same code.
2021-10-30 18:34:14 +02:00
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following example will try to kill a script named foo.script on the foodnstuff server that was ran with no arguments:
* kill("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following will try to kill a script named foo.script on the current server that was ran with no arguments:
* kill("foo.script", getHostname());
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The following will try to kill a script named foo.script on the current server that was ran with the arguments 1 and “foodnstuff”:
* kill("foo.script", getHostname(), 1, "foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of the script to kill
2021-10-30 21:46:34 +02:00
* @param host - Hostname of the server on which to kill the script.
2021-10-30 18:34:14 +02:00
* @param args - Arguments to identify which script to kill.
* @returns True if the script is successfully killed, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
kill(script: string, host: string, ...args: string[]): boolean;
2021-10-30 18:34:14 +02:00
/**
* Kills the script with the specified PID.
* Killing a script by its PID will typically have better performance,
* especially if you have many scripts running.
* If this function successfully kills the specified script, then it will return true.
* Otherwise, it will return false.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* if (kill(10)) {
* print("Killed script with PID 10!");
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @param scriptPid - PID of the script to kill
* @returns True if the script is successfully killed, and false otherwise.
*/
kill(scriptPid: number): boolean;
/**
* Kills all running scripts on the specified server. This function returns true
* if any scripts were killed, and false otherwise. In other words, it will return
* true if there are any scripts running on the target server.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @param host - IP or hostname of the server on which to kill all scripts.
* @returns True if any scripts were killed, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
killall(host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Terminates the current script immediately.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
*/
exit(): void;
/**
* Copies a script or literature (.lit) file(s) to another server. The files argument can be either a string
* specifying a single file to copy, or an array of strings specifying multiple files to copy.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Copies hack-template.script from the current server to foodnstuff:
* scp("hack-template.script", "foodnstuff");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.6 GB
2021-10-30 18:34:14 +02:00
* @param files - Filename or an array of filenames of script/literature files to copy.
* @param destination - Host or IP of the destination server, which is the server to which the file will be copied.
* @returns True if the script/literature file is successfully copied over and false otherwise. If the files argument is an array then this function will return true if at least one of the files in the array is successfully copied.
*/
2021-10-30 21:46:34 +02:00
scp(files: string | ReadonlyArray<string>, destination: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Copies a script or literature (.lit) file(s) to another server. The files argument can be either a string
* specifying a single file to copy, or an array of strings specifying multiple files to copy.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Copies foo.lit from the helios server to the home computer:
* scp("foo.lit", "helios", "home");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Tries to copy three files from rothman-uni to home computer:
* files = ["foo1.lit", "foo2.script", "foo3.script"];
* scp(files, "rothman-uni", "home");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.6 GB
2021-10-30 18:34:14 +02:00
* @param files - Filename or an array of filenames of script/literature files to copy.
* @param source - Host or IP of the source server, which is the server from which the file will be copied. This argument is optional and if its omitted the source will be the current server.
* @param destination - Host or IP of the destination server, which is the server to which the file will be copied.
* @returns True if the script/literature file is successfully copied over and false otherwise. If the files argument is an array then this function will return true if at least one of the files in the array is successfully copied.
*/
scp(
files: string | ReadonlyArray<string>,
2021-10-30 21:46:34 +02:00
source: string,
2021-10-30 18:34:14 +02:00
// tslint:disable-next-line:unified-signatures
2021-10-30 21:46:34 +02:00
destination: string,
2021-10-30 18:34:14 +02:00
): boolean;
/**
* Returns an array with the filenames of all files on the specified server
* (as strings). The returned array is sorted in alphabetic order.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.2 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of the target server.
* @param grep - A substring to search for in the filename.
* @returns Array with the filenames of all files on the specified server.
*/
2021-10-30 21:46:34 +02:00
ls(host: string, grep?: string): string[];
2021-10-30 18:34:14 +02:00
/**
* Returns an array with general information about all scripts running on the specified target server.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //(using NetscriptJS (Netscript 2.0))
* export async function main(ns) {
* const ps = ns.ps("home");
* for (let i = 0; i < ps.length; ++i) {
* ns.tprint(ps[i].filename + ' ' + ps[i].threads);
* ns.tprint(ps[i].args);
* }
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.2 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP address of the target server. If not specified, it will be the current servers IP by default.
* @returns Array with general information about all scripts running on the specified target server.
*/
2021-10-30 21:46:34 +02:00
ps(host?: string): ProcessInfo[];
2021-10-30 18:34:14 +02:00
/**
* Returns a boolean indicating whether or not the player has root access to the specified target server.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* if (hasRootAccess("foodnstuff") == false) {
* nuke("foodnstuff");
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of the target server
* @returns True if player has root access to the specified target server, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
hasRootAccess(host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns a string with the hostname of the server that the script is running on.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @returns Hostname of the server that the script is on.
*/
2021-10-30 21:46:34 +02:00
getHostname(): string;
2021-10-30 18:34:14 +02:00
/**
* Returns the players current hacking level.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @returns Players current hacking level
*/
getHackingLevel(): number;
/**
* Returns an object containing the Players hacking related multipliers.
* These multipliers are returned in fractional forms, not percentages
* (e.g. 1.5 instead of 150%).
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Example of how this can be used:
* mults = getHackingMultipliers();
* print(mults.chance);
* print(mults.growth);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Object containing the Players hacking related multipliers.
*/
getHackingMultipliers(): HackingMultipliers;
/**
* Returns an object containing the Players hacknet related multipliers.
* These multipliers are returned in fractional forms, not percentages
* (e.g. 1.5 instead of 150%).
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //Example of how this can be used:
* mults = getHacknetMultipliers();
* print(mults.production);
* print(mults.purchaseCost);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Object containing the Players hacknet related multipliers.
*/
getHacknetMultipliers(): HacknetMultipliers;
/**
* Returns a server object for the given server. Defaults to the running script's server if host is not specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
* @param host - Optional. Hostname for the requested server object.
2021-10-30 18:34:14 +02:00
* @returns The requested server object.
*/
2021-10-30 21:46:34 +02:00
getServer(host?: string): Server;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of money available on a server.
* Running this function on the home computer will return the players money.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* getServerMoneyAvailable("foodnstuff");
* getServerMoneyAvailable("home"); //Returns player's money
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server
* @returns Amount of money available on the server.
*/
2021-10-30 21:46:34 +02:00
getServerMoneyAvailable(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the maximum amount of money that can be available on a server.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Maximum amount of money available on the server.
*/
2021-10-30 21:46:34 +02:00
getServerMaxMoney(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the servers instrinsic growth parameter. This growth
* parameter is a number between 1 and 100 that represents how
* quickly the servers money grows. This parameter affects the
* percentage by which the servers money is increased when using the
* grow function. A higher growth parameter will result in a
* higher percentage increase from grow.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Parameter that affects the percentage by which the servers money is increased when using the grow function.
*/
2021-10-30 21:46:34 +02:00
getServerGrowth(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the security level of the target server. A servers security
* level is denoted by a number, typically between 1 and 100
* (but it can go above 100).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Security level of the target server.
*/
2021-10-30 21:46:34 +02:00
getServerSecurityLevel(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the base security level of the target server. This is the security
* level that the server starts out with. This is different than
* getServerSecurityLevel because getServerSecurityLevel returns
* the current security level of a server, which can constantly change due to
* hack, grow, and weaken, calls on that server.
* The base security level will stay the same until you reset by
* installing an Augmentation(s).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Base security level of the target server.
*/
2021-10-30 21:46:34 +02:00
getServerBaseSecurityLevel(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the minimum security level of the target server.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Minimum security level of the target server.
*/
2021-10-30 21:46:34 +02:00
getServerMinSecurityLevel(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the required hacking level of the target server.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns The required hacking level of the target server.
*/
2021-10-30 21:46:34 +02:00
getServerRequiredHackingLevel(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the number of open ports required to successfully run NUKE.exe on the specified server.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns The number of open ports required to successfully run NUKE.exe on the specified server.
*/
2021-10-30 21:46:34 +02:00
getServerNumPortsRequired(host: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns an array with two elements that gives information about a servers memory (RAM).
* The first element in the array is the amount of RAM that the server has total (in GB).
* The second element in the array is the amount of RAM that is currently being used on
* the server (in GB).
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* res = getServerRam("helios");
* totalRam = res[0];
* ramUsed = res[1];
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns Array with total and used memory on the specified server.
*/
2021-10-30 21:46:34 +02:00
getServerRam(host: string): [number, number];
2021-10-30 18:34:14 +02:00
/**
* Returns a boolean denoting whether or not the specified server exists.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @returns True if specified server exists, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
serverExists(host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns a boolean indicating whether the specified file exists on the target server.
* The filename for scripts is case-sensitive, but for other types of files it is not.
* For example, fileExists(brutessh.exe) will work fine, even though the actual program
* is named 'BruteSSH.exe'.
*
* If the hostname/ip argument is omitted, then the function will search through the current
* server (the server running the script that calls this function) for the file.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if the script named foo.script exists on the foodnstuff server, and false otherwise.
* fileExists("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if the current server contains the FTPCrack.exe program, and false otherwise.
* fileExists("ftpcrack.exe");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param filename - Filename of file to check.
* @param host - Host or IP of target server. This is optional. If it is not specified then the function will use the current server as the target server.
* @returns True if specified file exists, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
fileExists(filename: string, host?: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns a boolean indicating whether the specified script is running on the target server.
* Remember that a script is uniquely identified by both its name and its arguments.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if there is a script named foo.script with no arguments running on the foodnstuff server, and false otherwise:
* isRunning("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if there is a script named foo.script with no arguments running on the current server, and false otherwise:
* isRunning("foo.script", getHostname());
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if there is a script named foo.script running with the arguments 1, 5, and “test” (in that order) on the joesguns server, and false otherwise:
* isRunning("foo.script", "joesguns", 1, 5, "test");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to check. This is case-sensitive.
* @param host - Host or IP of target server.
* @param args - Arguments to specify/identify which scripts to search for.
* @returns True if specified script is running on the target server, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
isRunning(script: string, host: string, ...args: string[]): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns the cost to purchase a server with the specified amount of ram.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* for (i = 1; i <= 20; i++) {
* tprint(i + " -- " + getPurchasedServerCost(Math.pow(2, i)));
* }
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.25 GB
2021-10-30 18:34:14 +02:00
* @param ram - Amount of RAM of a potential purchased server. Must be a power of 2 (2, 4, 8, 16, etc.). Maximum value of 1048576 (2^20).
* @returns The cost to purchase a server with the specified amount of ram.
*/
getPurchasedServerCost(ram: number): number;
/**
* Purchased a server with the specified hostname and amount of RAM.
*
* The hostname argument can be any data type, but it will be converted to a string
* and have whitespace removed. Anything that resolves to an empty string will cause
* the function to fail. If there is already a server with the specified hostname,
* then the function will automatically append a number at the end of the hostname
* argument value until it finds a unique hostname. For example, if the script calls
2021-10-30 21:46:34 +02:00
* `purchaseServer(“foo”, 4)` but a server named foo already exists, the it will
* automatically change the hostname to `foo-0`. If there is already a server with the
* hostname `foo-0`, then it will change the hostname to `foo-1`, and so on.
2021-10-30 18:34:14 +02:00
*
* Note that there is a maximum limit to the amount of servers you can purchase.
*
* Returns the hostname of the newly purchased server as a string. If the function
* fails to purchase a server, then it will return an empty string. The function will
* fail if the arguments passed in are invalid, if the player does not have enough
* money to purchase the specified server, or if the player has exceeded the maximum
* amount of servers.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* ram = 64;
* hn = "pserv-";
* for (i = 0; i < 5; ++i) {
* purchaseServer(hn + i, ram);
* }
* ```
* @remarks 2.25 GB
* @param hostname - Host of the purchased server.
* @param ram - Amount of RAM of the purchased server. Must be a power of 2 (2, 4, 8, 16, etc.). Maximum value of 1048576 (2^20).
* @returns The hostname of the newly purchased server.
*/
2021-10-30 21:46:34 +02:00
purchaseServer(hostname: string, ram: number): string | "";
2021-10-30 18:34:14 +02:00
/**
* Deletes one of your purchased servers, which is specified by its hostname.
*
* The hostname argument can be any data type, but it will be converted to a string.
* Whitespace is automatically removed from the string. This function will not delete a
* server that still has scripts running on it.
*
* @remarks 2.25 GB
* @param host - Host of the server to delete.
* @returns True if successful, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
deleteServer(host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns an array with either the hostnames or IPs of all of the servers you have purchased.
*
* @remarks 2.25 GB
* @param hostnameMode -] Optional. Defaults to true. Returns hostnames if true, and IPs if false.
* @returns Returns an array with either the hostnames or IPs of all of the servers you have purchased.
*/
2021-10-30 21:46:34 +02:00
getPurchasedServers(hostnameMode?: boolean): string[];
2021-10-30 18:34:14 +02:00
/**
* Returns the maximum number of servers you can purchase.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @returns Returns the maximum number of servers you can purchase.
*/
getPurchasedServerLimit(): number;
/**
* Returns the maximum RAM that a purchased server can have.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @returns Returns the maximum RAM that a purchased server can have.
*/
getPurchasedServerMaxRam(): number;
/**
* This function can be used to either write data to a port or to a text file (.txt).
*
* If the first argument is a number between 1 and 20, then it specifies a port and this
* function will write data to that port. The third argument, mode, is not used when writing
* to a port.
*
* If the first argument is a string, then it specifies the name of a text file (.txt) and
* this function will write data to that text file. If the specified text file does not exist,
* then it will be created. The third argument mode, defines how the data will be written to
* the text file. If *mode is set to w, then the data is written in write mode which means
* that it will overwrite all existing data on the text file. If mode is set to any other value
* then the data will be written in append mode which means that the data will be added at the
* end of the text file.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param handle - Port or text file that will be written to.
* @param data - Data to write.
* @param mode - Defines the write mode. Only valid when writing to text files.
*/
write(handle: Handle, data?: string | string[] | number, mode?: "w" | "a"): void;
/**
* Attempts to write data to the specified Netscript Port.
* If the port is full, the data will not be written.
* Otherwise, the data will be written normally.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param port - Port or text file that will be written to.
* @param data - Data to write.
* @returns True if the data is successfully written to the port, and false otherwise.
*/
tryWrite(port: Handle, data: string | string[] | number): boolean;
/**
* This function is used to read data from a port or from a text file (.txt).
*
* If the argument port/fn is a number between 1 and 20, then it specifies a
* port and it will read data from that port. A port is a serialized queue.
* This function will remove the first element from that queue and return it.
* If the queue is empty, then the string NULL PORT DATA will be returned.
*
* If the argument port/fn is a string, then it specifies the name of a text
* file (.txt) and this function will return the data in the specified text
* file. If the text file does not exist, an empty string will be returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param handle - Port or text file to read from.
* @returns Data in the specified text file or port.
*/
read(handle: Handle): string | number | object;
/**
* This function is used to peek at the data from a port. It returns the
* first element in the specified port without removing that element. If
* the port is empty, the string NULL PORT DATA will be returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param port - Port to peek. Must be an integer between 1 and 20.
* @returns Data in the specified port.
*/
peek(port: Port): string | number | object;
/**
* This function is used to clear data in a Netscript Ports or a text file.
*
* If the port/fn argument is a number between 1 and 20, then it specifies a
* port and will clear it (deleting all data from the underlying queue).
*
* If the port/fn argument is a string, then it specifies the name of a
* text file (.txt) and will delete all data from that text file.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param handle - Port or text file to clear.
*/
clear(handle: Handle): void;
/**
* Get a handle to a Netscript Port.
*
* WARNING: Port Handles only work in NetscriptJS (Netscript 2.0). They will not work in Netscript 1.0.
*
* @see https://bitburner.readthedocs.io/en/latest/netscript/netscriptmisc.html#netscript-ports
* @remarks 10 GB
* @param port - Port number. Must be an integer between 1 and 20.
* @returns Data in the specified port.
*/
getPortHandle(port: Port): any[];
/**
* Removes the specified file from the current server. This function works for every file
* type except message (.msg) files.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param name - Filename of file to remove. Must include the extension.
* @param host - Host or IP Address of the server on which to delete the file. Optional. Defaults to current server.
* @returns True if it successfully deletes the file, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
rm(name: string, host?: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns a boolean indicating whether any instance of the specified script is running
* on the target server, regardless of its arguments.
*
* This is different than the isRunning function because it does not try to
* identify a specific instance of a running script by its arguments.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if there is any script named foo.script running on the foodnstuff server, and false otherwise:
* scriptRunning("foo.script", "foodnstuff");
* ```
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //The function call will return true if there is any script named “foo.script” running on the current server, and false otherwise:
* scriptRunning("foo.script", getHostname());
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to check. This is case-sensitive.
* @param host - Host or IP of target server.
* @returns True if the specified script is running, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
scriptRunning(script: string, host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Kills all scripts with the specified filename on the target server specified by hostname/ip,
* regardless of arguments.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script to kill. This is case-sensitive.
* @param host - Host or IP of target server.
* @returns true if one or more scripts were successfully killed, and false if none were.
*/
2021-10-30 21:46:34 +02:00
scriptKill(script: string, host: string): boolean;
2021-10-30 18:34:14 +02:00
/**
* Returns the current script name.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @returns Current script name.
*/
getScriptName(): string;
/**
* Returns the amount of RAM required to run the specified script on the target server.
* Returns 0 if the script does not exist.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script. This is case-sensitive.
* @param host - Host or IP of target server the script is located on. This is optional, If it is not specified then the function will se the current server as the target server.
* @returns Amount of RAM required to run the specified script on the target server, and 0 if the script does not exist.
*/
2021-10-30 21:46:34 +02:00
getScriptRam(script: string, host?: string): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of time in seconds it takes to execute the hack Netscript function on the target server.
* The function takes in an optional hackLvl parameter that can be specified to see what the hack time would be at different hacking levels.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @param hackLvl - Optional hacking level for the calculation. Defaults to players current hacking level.
* @param intLvl - Optional intelligence level for the calculation. Defaults to players current intelligence level. (Intelligence is unlocked after obtaining Source-File 5).
* @returns Returns the amount of time in seconds it takes to execute the hack Netscript function. Returns Infinity if called on a Hacknet Server.
*/
2021-10-30 21:46:34 +02:00
getHackTime(host: string, hackLvl?: number, intLvl?: number): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of time in seconds it takes to execute the grow Netscript function on the target server.
* The function takes in an optional hackLvl parameter that can be specified to see what the grow time would be at different hacking levels.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @param hackLvl - Optional hacking level for the calculation. Defaults to players current hacking level.
* @param intLvl - Optional intelligence level for the calculation. Defaults to players current intelligence level. (Intelligence is unlocked after obtaining Source-File 5).
* @returns Returns the amount of time in seconds it takes to execute the grow Netscript function. Returns Infinity if called on a Hacknet Server.
*/
2021-10-30 21:46:34 +02:00
getGrowTime(host: string, hackLvl?: number, intLvl?: number): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of time in seconds it takes to execute the weaken() Netscript function on the target server.
* The function takes in an optional hackLvl parameter that can be specified to see what the weaken time would be at different hacking levels.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @param host - Host or IP of target server.
* @param hackLvl - Optional hacking level for the calculation. Defaults to players current hacking level.
* @param intLvl - Optional intelligence level for the calculation. Defaults to players current intelligence level. (Intelligence is unlocked after obtaining Source-File 5).
* @returns Returns the amount of time in seconds it takes to execute the grow Netscript function. Returns Infinity if called on a Hacknet Server.
*/
2021-10-30 21:46:34 +02:00
getWeakenTime(host: string, hackLvl?: number, intLvl?: number): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of income the specified script generates while online
* (when the game is open, does not apply for offline income). Remember that
* a script is uniquely identified by both its name and its arguments. So for
* example if you ran a script with the arguments foodnstuff and 5 then
* in order to use this function to get that scripts income you must specify
* those same arguments in the same order in this function call.
*
* This function can also be called with no arguments.
* If called with no arguments, then this function will return an array of two values.
2021-10-30 21:46:34 +02:00
* The first value is the total income (dollar / second) of all of your active scripts
2021-10-30 18:34:14 +02:00
* (scripts that are currently running on any server).
2021-10-30 21:46:34 +02:00
* The second value is the total income (dollar / second) that youve earned from scripts
2021-10-30 18:34:14 +02:00
* since you last installed Augmentations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script.
* @param host - Server on which script is running.
* @param args - Arguments that the script is running with.
* @returns Amount of income the specified script generates while online.
*/
2021-10-30 21:46:34 +02:00
getScriptIncome(script: string, host: string, ...args: string[]): number | [number, number];
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of hacking experience the specified script generates while online
* (when the game is open, does not apply for offline experience gains). Remember that a
* script is uniquely identified by both its name and its arguments.
*
* This function can also return the total experience gain rate of all of your active
* scripts by running the function with no arguments.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @param script - Filename of script.
* @param host - Server on which script is running.
* @param args - Arguments that the script is running with.
* @returns Amount of hacking experience the specified script generates while online.
*/
2021-10-30 21:46:34 +02:00
getScriptExpGain(script: string, host: string, ...args: string[]): number;
2021-10-30 18:34:14 +02:00
/**
* Returns the amount of time in milliseconds that have passed since you last installed Augmentations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.05 GB
2021-10-30 18:34:14 +02:00
* @returns Time in milliseconds that have passed since you last installed Augmentations.
*/
getTimeSinceLastAug(): number;
/**
* Complete open source JavaScript sprintf implementation
*
* @see https://github.com/alexei/sprintf.js
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param format - String to format.
* @param args - Formating arguments.
* @returns Formated text.
*/
sprintf(format: string, ...args: string[]): string;
/**
* Complete open source JavaScript sprintf implementation
*
* @see https://github.com/alexei/sprintf.js
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param format - String to format.
* @param args - Formating arguments.
* @returns Formated text.
*/
vsprintf(format: string, args: string[]): string;
/**
* Converts a number into a string with the specified formatter.
* This uses the numeraljs library, so the formatters must be compatible with that.
* This is the same function that the game itself uses to display numbers.
*
* @see http://numeraljs.com/
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param n - Number to format.
* @param format - Formatter.
* @returns Formated number.
*/
nFormat(n: number, format: string): number;
/**
* Prompts the player with a dialog box with two options: Yes and No.
* This function will return true if the player click Yes and false if
* the player clicks No. The scripts execution is halted until the player
* selects one of the options.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param txt - Text to appear in the prompt dialog box.
* @returns True if the player click Yes and false if the player clicks No.
*/
prompt(txt: string): Promise<boolean>;
/**
* Retrieves data from a URL and downloads it to a file on the specified server.
* The data can only be downloaded to a script (.script, .ns, .js) or a text file (.txt).
* If the file already exists, it will be overwritten by this command.
* Note that it will not be possible to download data from many websites because they
* do not allow cross-origin resource sharing (CORS).
*
* IMPORTANT: This is an asynchronous function that returns a Promise.
* The Promises resolved value will be a boolean indicating whether or not the data was
* successfully retrieved from the URL. Because the function is async and returns a Promise,
* it is recommended you use wget in NetscriptJS (Netscript 2.0).
*
* In NetscriptJS, you must preface any call to wget with the await keyword (like you would hack or sleep).
* wget will still work in Netscript 1.0, but the functions execution will not be synchronous
* (i.e. it may not execute when you expect/want it to).
* Furthermore, since Promises are not supported in ES5,
* you will not be able to process the returned value of wget in Netscript 1.0.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* wget("https://raw.githubusercontent.com/danielyxie/bitburner/master/README.md", "game_readme.txt");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0 GB
2021-10-30 18:34:14 +02:00
* @param url - URL to pull data from.
* @param target - Filename to write data to. Must be script or text file.
* @param host - Optional hostname/ip of server for target file.
* @returns True if the data was successfully retrieved from the URL, false otherwise.
*/
wget(url: string, target: string, host?: string): Promise<boolean>;
/**
* Returns the amount of Faction favor required to be able to donate to a faction.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.1 GB
2021-10-30 18:34:14 +02:00
* @returns Amount of Faction favor required to be able to donate to a faction.
*/
getFavorToDonate(): number;
/**
* Returns an object containing the current BitNode multipliers.
* This function requires Source-File 5 in order to run.
* The multipliers are returned in decimal forms (e.g. 1.5 instead of 150%).
* The multipliers represent the difference between the current BitNode and
* the original BitNode (BitNode-1).
*
* For example, if the CrimeMoney multiplier has a value of 0.1, then that means
* that committing crimes in the current BitNode will only give 10% of the money
* you would have received in BitNode-1.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* mults = getBitNodeMultipliers();
* print(mults.ServerMaxMoney);
* print(mults.HackExpGain);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns Object containing the current BitNode multipliers.
*/
2021-10-30 21:46:34 +02:00
getBitNodeMultipliers(): BitNodeMultipliers;
2021-10-30 18:34:14 +02:00
}
/**
2021-10-30 21:46:34 +02:00
* All possible stock market order positions.
2021-10-30 18:34:14 +02:00
* @public
*/
2021-10-30 21:46:34 +02:00
export declare type OrderPosition = "long" | "short";
2021-10-30 18:34:14 +02:00
/**
2021-10-30 21:46:34 +02:00
* All possible stock market order type.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type OrderType = "limitbuy" | "limitsell" | "stopbuy" | "stopsell";
/**
2021-10-30 21:46:34 +02:00
* Short summary of the players skills.
2021-10-30 18:34:14 +02:00
* @public
*/
2021-10-30 21:46:34 +02:00
export declare interface PlayerSkills {
2021-10-30 18:34:14 +02:00
/** Hacking level */
hacking: number;
/** Strength level */
strength: number;
/** Defense level */
defense: number;
/** Dexterity level */
dexterity: number;
/** Agility level */
agility: number;
/** Chraisma level */
charisma: number;
/** Intelligence level */
intelligence: number;
}
/**
2021-10-30 21:46:34 +02:00
* Queue used to send and receive messages.
* @remarks
2021-10-30 18:34:14 +02:00
* A port is implemented as a sort of serialized queue,
* where you can only write and read one element at a time from the port.
* When you read data from a port, the element that is read is removed from the port.
*
* IMPORTANT: The data inside ports are not saved!
* This means if you close and re-open the game, or reload the page
* then you will lose all of the data in the ports!
* @public
*/
export declare type Port = 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20;
/**
2021-10-30 21:46:34 +02:00
* A single process on a server.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface ProcessInfo {
/** Script name. */
2021-10-30 21:46:34 +02:00
filename: string;
2021-10-30 18:34:14 +02:00
/** Number of threads script is running with */
threads: number;
/** Script's arguments */
args: string[];
}
/**
2021-10-30 21:46:34 +02:00
* All programs.
2021-10-30 18:34:14 +02:00
* @public
*/
2021-10-30 21:46:34 +02:00
export declare type Programs =
| "autolink.exe"
2021-10-30 18:34:14 +02:00
| "brutessh.exe"
| "deepscanv1.exe"
| "deepscanv2.exe"
2021-10-30 21:46:34 +02:00
| "ftpcrack.exe"
| "httpworm.exe"
| "relaysmtp.exe"
| "serverprofiler.exe"
| "sqlinject.exe";
2021-10-30 18:34:14 +02:00
/**
2021-10-30 21:46:34 +02:00
* A single server.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface Server {
2021-10-30 21:46:34 +02:00
/**
* How many CPU cores this server has. Maximum of 8.
* Affects magnitude of grow and weaken.
*/
2021-10-30 18:34:14 +02:00
cpuCores: number;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether the FTP port is open */
2021-10-30 18:34:14 +02:00
ftpPortOpen: boolean;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether player has admin/root access to this server */
2021-10-30 18:34:14 +02:00
hasAdminRights: boolean;
2021-10-30 21:46:34 +02:00
/** Hostname. Must be unique */
2021-10-30 18:34:14 +02:00
hostname: string;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether HTTP Port is open */
2021-10-30 18:34:14 +02:00
httpPortOpen: boolean;
2021-10-30 21:46:34 +02:00
/** IP Address. Must be unique */
2021-10-30 18:34:14 +02:00
ip: string;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether player is curently connected to this server */
2021-10-30 18:34:14 +02:00
isConnectedTo: boolean;
2021-10-30 21:46:34 +02:00
/** RAM (GB) available on this server */
2021-10-30 18:34:14 +02:00
maxRam: number;
2021-10-30 21:46:34 +02:00
/**
* Name of company/faction/etc. that this server belongs to.
* Optional, not applicable to all Servers
*/
2021-10-30 18:34:14 +02:00
organizationName: string;
2021-10-30 21:46:34 +02:00
/** RAM (GB) used. i.e. unavailable RAM */
2021-10-30 18:34:14 +02:00
ramUsed: number;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether SMTP Port is open */
2021-10-30 18:34:14 +02:00
smtpPortOpen: boolean;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether SQL Port is open */
2021-10-30 18:34:14 +02:00
sqlPortOpen: boolean;
2021-10-30 21:46:34 +02:00
/** Flag indicating whether the SSH Port is open */
2021-10-30 18:34:14 +02:00
sshPortOpen: boolean;
}
/**
2021-10-30 21:46:34 +02:00
* Singularity API
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface Singularity {
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically set you to start taking a course at a university.
* If you are already in the middle of some working action (such as working at a
* company, for a faction, or on a program), then running this function will automatically
* cancel that action and give you your earnings.
*
* The cost and experience gains for all of these universities and classes are the same as
* if you were to manually visit and take these classes.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @param universityName - Name of university. You must be in the correct city for whatever university you specify.
* @param courseName - Name of course.
* @returns True if actions is successfully started, false otherwise.
*/
universityCourse(universityName: University, courseName: UniversityCourse): boolean;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically set you to start working out at a gym to train
* a particular stat. If you are already in the middle of some working action
* (such as working at a company, for a faction, or on a program), then running
* this function will automatically cancel that action and give you your earnings.
*
* The cost and experience gains for all of these gyms are the same as if you were
* to manually visit these gyms and train
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @param gymName - Name of gym. You must be in the correct city for whatever gym you specify.
* @param stat - The stat you want to train.
* @returns True if actions is successfully started, false otherwise.
*/
gymWorkout(gymName: Gym, stat: GymStat): boolean;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function allows the player to travel to any city. The cost for using this
* function is the same as the cost for traveling through the Travel Agency.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @param city - City to travel to.
* @returns True if actions is successful, false otherwise.
*/
travelToCity(city: City): boolean;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function allows you to automatically purchase a TOR router. The cost for
* purchasing a TOR router using this function is the same as if you were to
* manually purchase one.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @returns True if actions is successful, false otherwise.
*/
purchaseTor(): boolean;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function allows you to automatically purchase programs. You MUST have a
* TOR router in order to use this function. The cost of purchasing programs
* using this function is the same as if you were purchasing them through the Dark
* Web using the Terminal buy command.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* purchaseProgram("brutessh.exe");
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @param programName - Name of program to purchase.
* @returns True if the specified program is purchased, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
purchaseProgram(programName: Programs): boolean;
2021-10-30 18:34:14 +02:00
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns an object with the Players stats.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* res = getStats();
* print('My charisma level is: ' + res.charisma);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @returns Object with the Players stats.
*/
2021-10-30 21:46:34 +02:00
getStats(): PlayerSkills;
2021-10-30 18:34:14 +02:00
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns an object with various information about your character.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @returns Object with various information about your character.
*/
getCharacterInformation(): CharacterInfo;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns a boolean indicating whether or not the player is currently performing an
* action. These actions include working for a company/faction, studying at a univeristy,
* working out at a gym, creating a program, committing a crime, or carrying out a Hacking Mission.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @returns True if the player is currently performing an action, false otherwise.
*/
isBusy(): boolean;
/**
* If you are not in BitNode-4, then you must have Level 1 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function is used to end whatever action the player is currently performing.
* The player will receive whatever money/experience/etc. he has earned from that action.
*
* The actions that can be stopped with this function are:
*
* * Studying at a university
* * Working for a company/faction
* * Creating a program
* * Committing a Crime
*
* This function will return true if the players action was ended.
* It will return false if the player was not performing an action when this function was called.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 1
* @returns True if the players action was ended, false if the player was not performing an action.
*/
stopAction(): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will upgrade amount of RAM on the players home computer. The cost is
* the same as if you were to do it manually.
*
* This function will return true if the players home computer RAM is successfully upgraded, and false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @returns True if the players home computer RAM is successfully upgraded, and false otherwise.
*/
upgradeHomeRam(): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns the cost of upgrading the players home computer RAM.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1.5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @returns Cost of upgrading the players home computer RAM.
*/
getUpgradeHomeRamCost(): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically set you to start working at the company
* at which you are employed. If you are already in the middle of some working
* action (such as working for a faction, training at a gym, or creating a program),
* then running this function will automatically cancel that action and give you
* your earnings.
*
* This function will return true if the player starts working, and false otherwise.
*
* Note that when you are working for a company, you will not actually receive your earnings (reputation, money, experience) until you FINISH the action.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //If you only want to work until you get 100,000 company reputation. One small hack to get around this is to continuously restart the action to receive your earnings:
* while (getCompanyRep(COMPANY HERE) < VALUE) {
* workForCompany();
* sleep(60000);
* }
* //This way, your company reputation will be updated every minute.
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param companyName - Name of company to work for. Must be an exact match. Optional. If not specified, this argument defaults to the last job that you worked
* @returns True if the player starts working, and false otherwise.
*/
workForCompany(companyName?: CompanyName): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically try to apply to the specified company
* for a position in the specified field. This function can also be used to
* apply for promotions by specifying the company and field you are already
* employed at.
*
* This function will return true if you successfully get a job/promotion,
* and false otherwise. Note that if you are trying to use this function to
* apply for a promotion and you dont get one, it will return false.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param companyName - Name of company to apply to.
* @param field - Field to which you want to apply.
* @returns True if the player successfully get a job/promotion, and false otherwise.
*/
applyToCompany(companyName: CompanyName, field: CompanyField): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will return the amount of reputation you have at the specified company.
* If the company passed in as an argument is invalid, -1 will be returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param companyName - Name of the company.
* @returns Amount of reputation you have at the specified company.
*/
getCompanyRep(companyName: CompanyName): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will return the amount of favor you have at the specified company.
* If the company passed in as an argument is invalid, -1 will be returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param companyName - Name of the company.
* @returns Amount of favor you have at the specified company.
*/
getCompanyFavor(companyName: CompanyName): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will return the amount of favor you will gain for the specified
* company when you reset by installing Augmentations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.75 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param companyName - Name of the company.
* @returns Amount of favor you gain at the specified company when you reset by installing Augmentations.
*/
getCompanyFavorGain(companyName: CompanyName): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns an array with the name of all Factions you currently have oustanding invitations from.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @returns Array with the name of all Factions you currently have oustanding invitations from.
*/
checkFactionInvitations(): FactionName[];
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically accept an invitation from a faction and join it.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param faction - Name of faction to join.
* @returns True if player joined the faction, and false otherwise.
*/
joinFaction(faction: FactionName): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically set you to start working for the specified faction.
* Obviously, you must be a member of the faction or else this function will fail. If
* you are already in the middle of some working action (such as working for a company,
* training at a gym, or creating a program), then running this function will automatically
* cancel that action and give you your earnings.
*
* This function will return true if you successfully start working for the specified faction, and false otherwise.
*
* Note that when you are working for a faction, you will not actually receive your earnings (reputation, experience) until you FINISH the action.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* //If you only want to work until you get 100,000 faction reputation. One small hack to get around this is to continuously restart the action to receive your earnings:
* while (getFactionRep(FACTION NAME) < VALUE) {
* workForFaction(FACNAME, WORKTYPE);
* sleep(60000);
* }
* //This way, your faction reputation will be updated every minute.
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 3 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param faction - Name of faction to work for.
* @param workType - Type of work to perform for the faction.
* @returns True if the player starts working, and false otherwise.
*/
workForFaction(faction: FactionName, workType: FactionWork): boolean;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns the amount of reputation you have for the specified faction.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param faction - Name of faction to work for.
* @returns Amount of reputation you have for the specified faction.
*/
getFactionRep(faction: FactionName): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns the amount of favor you have for the specified faction.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 1 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param faction - Name of faction.
* @returns Amount of favor you have for the specified faction.
*/
getFactionFavor(faction: FactionName): number;
/**
* If you are not in BitNode-4, then you must have Level 2 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns the amount of favor you will gain for the specified
* faction when you reset by installing Augmentations.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 0.75 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 2
* @param faction - Name of faction.
* @returns Amount of favor you will gain for the specified faction when you reset by installing Augmentations.
*/
getFactionFavorGain(faction: FactionName): number;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Attempts to donate money to the specified faction in exchange for reputation.
* Returns true if you successfully donate the money, and false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param faction - Name of faction to donate to.
* @param amount - Amount of money to donate.
* @returns True if the money was donated, and false otherwise.
*/
donateToFaction(faction: FactionName, amount: number): boolean;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically set you to start working on creating the
* specified program. If you are already in the middle of some working action
* (such as working for a company, training at a gym, or taking a course), then
* running this function will automatically cancel that action and give you your
* earnings.
*
* This function returns true if you successfully start working on the specified program, and false otherwise.
*
* Note that creating a program using this function has the same hacking level requirements as it normally would. These level requirements are:
* * BruteSSH.exe: 50
* * FTPCrack.exe: 100
* * relaySMTP.exe: 250
* * HTTPWorm.exe: 500
* * SQLInject.exe: 750
* * DeepscanV1.exe: 75
* * DeepscanV2.exe: 400
* * ServerProfiler.exe: 75
* * AutoLink.exe: 25
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* createProgram(relaysmtp.exe);
* ```
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param program - Name of program to create.
* @returns True if you successfully start working on the specified program, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
createProgram(program: Programs): boolean;
2021-10-30 18:34:14 +02:00
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function is used to automatically attempt to commit crimes.
* If you are already in the middle of some working action (such
* as working for a company or training at a gym), then running this
* function will automatically cancel that action and give you your
* earnings.
*
* This function returns the number of seconds it takes to attempt the specified
* crime (e.g It takes 60 seconds to attempt the Rob Store crime, so running
2021-10-30 21:46:34 +02:00
* `commitCrime('rob store')` will return 60).
2021-10-30 18:34:14 +02:00
*
* Warning: I do not recommend using the time returned from this function to try
* and schedule your crime attempts. Instead, I would use the isBusy Singularity
* function to check whether you have finished attempting a crime. This is because
* although the game sets a certain crime to be X amount of seconds, there is no
* guarantee that your browser will follow that time limit.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param crime - Name of crime to attempt.
* @returns True if you successfully start working on the specified program, and false otherwise.
*/
commitCrime(crime: Crime): number;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns your chance of success at commiting the specified crime.
* The chance is returned as a decimal (i.e. 60% would be returned as 0.6).
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param crime - Name of crime.
* @returns Chance of success at commiting the specified crime as a decimal.
*/
getCrimeChance(crime: Crime): number;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns the stats of the crime.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param crime - Name of crime. Not case-sensitive
* @returns The stats of the crime.
*/
getCrimeStats(crime: Crime): CrimeStats;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns an array containing the names (as strings) of all Augmentations you have.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param purchased - Specifies whether the returned array should include Augmentations you have purchased but not yet installed. By default, this argument is false which means that the return value will NOT have the purchased Augmentations.
* @returns Array containing the names (as strings) of all Augmentations you have.
*/
getOwnedAugmentations(purchased?: boolean): AugmentName[];
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns an array of source files
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @returns Array containing an object with number and level of the source file.
*/
getOwnedSourceFiles(): SourceFileLvl[];
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* Returns an array containing the names (as strings) of all Augmentations
* that are available from the specified faction.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param faction - Name of faction.
* @returns Array containing the names of all Augmentations.
*/
getAugmentationsFromFaction(faction: FactionName): AugmentName[];
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns an array with the names of the prerequisite Augmentation(s) for the specified Augmentation.
* If there are no prerequisites, a blank array is returned.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param augName - Name of Augmentation.
* @returns Array with the names of the prerequisite Augmentation(s) for the specified Augmentation.
*/
getAugmentationPrereq(augName: AugmentName): AugmentName[];
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns an array with two elements that gives the cost for
* the specified Augmentation. The first element in the returned array is the
* reputation requirement of the Augmentation, and the second element is the
* money cost.
*
* If an invalid Augmentation name is passed in for the augName argument, this
* function will return the array [-1, -1].
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param augName - Name of Augmentation.
* @returns Array with first element as a reputation requirement and second element as the money cost.
*/
getAugmentationCost(augName: AugmentName): [number, number];
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will try to purchase the specified Augmentation through the given Faction.
*
* This function will return true if the Augmentation is successfully purchased, and false otherwise.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param faction - Name of faction to purchase Augmentation from.
* @param augmnet - Name of Augmentation to purchase.
* @returns True if the Augmentation is successfully purchased, and false otherwise.
*/
purchaseAugmentation(faction: FactionName, augmnet: AugmentName): boolean;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function returns augmentation stats.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param name - Name of Augmentation. CASE-SENSITIVE.
* @returns Augmentation stats.
*/
getAugmentationStats(name: AugmentName): AugmentationStats;
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will automatically install your Augmentations, resetting the game as usual.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
* @param cbScript - Optional callback script. This is a script that will automatically be run after Augmentations are installed (after the reset). This script will be run with no arguments and 1 thread. It must be located on your home computer.
*/
2021-10-30 21:46:34 +02:00
installAugmentations(cbScript?: string): void;
2021-10-30 18:34:14 +02:00
/**
* If you are not in BitNode-4, then you must have Level 3 of Source-File 4 in order to use this function and the RAM cost is doubled.
*
* This function will perform a reset even if you dont have any augmentation installed.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 5 GB
2021-10-30 18:34:14 +02:00
* @remarks Singularity - Level 3
*/
softReset(): void;
}
/**
2021-10-30 21:46:34 +02:00
* Sleeve API
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface Sleeve {
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return the number of duplicate sleeves the player has.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @returns number of duplicate sleeves the player has.
*/
getNumSleeves(): number;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a structure containing the stats of the sleeve.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to get stats of.
* @returns Object containing the stats of the sleeve.
*/
2021-10-30 21:46:34 +02:00
getSleeveStats(sleeveNumber: number): SleeveSkills;
2021-10-30 18:34:14 +02:00
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a struct containing tons of information about this sleeve
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to retrieve information.
* @returns Object containing tons of information about this sleeve.
*/
getInformation(sleeveNumber: number): SleeveInformation;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return the current task that the sleeve is performing. type is set to Idle if the sleeve isnt doing anything.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to retrieve task from.
* @returns Object containing information the current task that the sleeve is performing.
*/
getTask(sleeveNumber: number): SleeveTask;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not this action was set successfully.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to start recovery.
* @returns True if this action was set successfully, false otherwise.
*/
setToShockRecovery(sleeveNumber: number): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not this action was set successfully.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to start synchronizing.
* @returns True if this action was set successfully, false otherwise.
*/
setToSynchronize(sleeveNumber: number): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not this action was set successfully.
*
* Returns false if an invalid action is specified.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to start commiting crime.
* @param name - Name of the crime. Must be an exact match.
* @returns True if this action was set successfully, false otherwise.
*/
setToCommitCrime(sleeveNumber: number, name: Crime): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not the sleeve started working or this faction.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to work for the faction.
* @param factionName - Name of the faction to work for.
* @param factionWorkType - Name of the action to perform for this faction.
* @returns True if the sleeve started working on this faction, false otherwise.
*/
setToFactionWork(sleeveNumber: number, factionName: FactionName, factionWorkType: FactionWork): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not the sleeve started working or this company.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to work for the company.
* @param companyName - Name of the company to work for.
* @returns True if the sleeve started working on this company, false otherwise.
*/
setToCompanyWork(sleeveNumber: number, companyName: CompanyName): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not this action was set successfully.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to start taking class.
* @param university - Name of the university to attend.
* @param className - Name of the class to follow.
* @returns True if this action was set successfully, false otherwise.
*/
setToUniversityCourse(sleeveNumber: number, university: University, className: UniversityCourse): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not the sleeve started working out.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to workout at the gym.
* @param gymName - Name of the gym.
* @param stat - Name of the stat to train.
* @returns True if the sleeve started working out, false otherwise.
*/
setToGymWorkout(sleeveNumber: number, gymName: Gym, stat: GymStat): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a boolean indicating whether or not the sleeve reached destination.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to travel.
* @param cityName - Name of the destination city.
* @returns True if the sleeve reached destination, false otherwise.
*/
travel(sleeveNumber: number, cityName: City): boolean;
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a list of augmentation names that this sleeve has installed.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to retrieve augmentations from.
* @returns List of augmentation names that this sleeve has installed.
*/
getSleeveAugmentations(sleeveNumber: number): AugmentName[];
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return a list of augmentations that the player can buy for this sleeve.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to retrieve purchasable augmentations from.
* @returns List of augmentations that the player can buy for this sleeve.
*/
getSleevePurchasableAugs(sleeveNumber: number): AugmentPair[];
/**
* If you are not in BitNode-10, then you must have Source-File 10 in order to use this function.
*
* Return true if the aug was purchased and installed on the sleeve.
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 4 GB
2021-10-30 18:34:14 +02:00
* @param sleeveNumber - Index of the sleeve to buy an aug for.
* @param augName - Name of the aug to buy. Must be an exact match.
* @returns True if the aug was purchased and installed on the sleeve, false otherwise.
*/
purchaseSleeveAug(sleeveNumber: number, augName: AugmentName): boolean;
}
/**
2021-10-30 21:46:34 +02:00
* Object representing sleeve information.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface SleeveInformation {
/** location of the sleeve */
city: City;
/** current hp of the sleeve */
hp: number;
/** max hp of the sleeve */
maxHp: number;
/** jobs available to the sleeve */
jobs: string[];
/** job titles available to the sleeve */
jobTitle: CompanyField[];
/** does this sleeve have access to the tor router */
tor: boolean;
/** sleeve multipliers */
mult: CharacterMult;
/** time spent on the current task in milliseconds */
timeWorked: number;
/** earnings synchronized to other sleeves */
earningsForSleeves: SleeveWorkGains;
/** earnings synchronized to the player */
earningsForPlayer: SleeveWorkGains;
/** earnings for this sleeve */
earningsForTask: SleeveWorkGains;
/** faction or company reputation gained for the current task */
workRepGain: number;
}
/**
2021-10-30 21:46:34 +02:00
* Object representing a sleeve stats.
2021-10-30 18:34:14 +02:00
* @public
*/
2021-10-30 21:46:34 +02:00
export declare interface SleeveSkills {
2021-10-30 18:34:14 +02:00
/** current shock of the sleeve [0-100] */
2021-10-30 21:46:34 +02:00
shock: number;
2021-10-30 18:34:14 +02:00
/** current sync of the sleeve [0-100] */
2021-10-30 21:46:34 +02:00
sync: number;
2021-10-30 18:34:14 +02:00
/** current hacking skill of the sleeve */
hacking_skill: number;
/** current strength of the sleeve */
strength: number;
/** current defense of the sleeve */
defense: number;
/** current dexterity of the sleeve */
dexterity: number;
/** current agility of the sleeve */
agility: number;
/** current charisma of the sleeve */
charisma: number;
}
/**
2021-10-30 21:46:34 +02:00
* Object representing a sleeve current task.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface SleeveTask {
/** task type */
task: string;
/** crime currently attempting, if any */
crime: Crime | "";
/** location of the task, if any */
location: City | "";
/** stat being trained at the gym, if any */
gymStatType: GymStat | "";
/** faction work type being performed, if any */
factionWorkType: FactionWork | "";
}
/**
* @public
*/
export declare interface SleeveWorkGains {
/** hacking exp gained from work */
workHackExpGain: number;
/** strength exp gained from work */
workStrExpGain: number;
/** defense exp gained from work, */
workDefExpGain: number;
/** dexterity exp gained from work */
workDexExpGain: number;
/** agility exp gained from work */
workAgiExpGain: number;
/** charisma exp gained from work */
workChaExpGain: number;
/** money gained from work */
workMoneyGain: number;
}
/**
* @public
*/
export declare interface SourceFileLvl {
/** The number of the source file */
n: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12;
/** The level of the source file */
lvl: number;
}
/**
2021-10-30 21:46:34 +02:00
* Return value of {@link TIX.getOrders | getOrders}
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type StockOrder = {
/** Stock Symbol */
[key in StockSymbol]?: StockOrderObject[];
};
/**
2021-10-30 21:46:34 +02:00
* Value in map of {@link StockOrder}
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface StockOrderObject {
/** Number of shares */
shares: number;
/** Price per share */
price: number;
/** Order type */
type: "Limit Buy Order" | "Limit Sell Order" | "Stop Buy Order" | "Stop Buy Order";
/** Order position */
position: "S" | "L";
}
/**
2021-10-30 21:46:34 +02:00
* All possible stock market symbols.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type StockSymbol =
| "ECP"
| "MGCP"
| "BLD"
| "CLRK"
| "OMTK"
| "FSIG"
| "KGI"
| "FLCM"
| "STM"
| "DCOMM"
| "HLS"
| "VITA"
| "ICRS"
| "UNV"
| "AERO"
| "OMN"
| "SLRS"
| "GPH"
| "NVMD"
| "WDS"
| "LXO"
| "RHOC"
| "APHE"
| "SYSC"
| "CTK"
| "NTLK"
| "OMGA"
| "FNS"
| "SGC"
| "JGN"
| "CTYS"
| "MDYN"
| "TITN";
/**
2021-10-30 21:46:34 +02:00
* Stock market API
2021-10-30 18:34:14 +02:00
* @public
*/
export declare interface TIX {
/**
* Returns an array of the symbols of the tradable stocks
*
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* @returns Array of the symbols of the tradable stocks.
*/
getSymbols(): StockSymbol[];
/**
2021-10-30 22:03:34 +02:00
* Returns the price of a stock
2021-10-30 18:34:14 +02:00
*
2021-10-30 22:03:34 +02:00
* @remarks
* RAM cost: 2 GB
* The stocks price is the average of its bid and ask price.
2021-10-30 18:34:14 +02:00
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* getPrice("FISG");
* ```
* @param sym - Stock symbol.
* @returns The price of a stock.
*/
getPrice(sym: StockSymbol): number;
/**
2021-10-30 22:03:34 +02:00
* Returns the ask price of that stock.
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 22:03:34 +02:00
*
2021-10-30 18:34:14 +02:00
* @param sym - Stock symbol.
* @returns The ask price of a stock.
*/
getAskPrice(sym: StockSymbol): number;
/**
2021-10-30 22:03:34 +02:00
* Returns the bid price of that stock.
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2 GB
2021-10-30 22:03:34 +02:00
*
2021-10-30 18:34:14 +02:00
* @param sym - Stock symbol.
* @returns The bid price of a stock.
*/
getBidPrice(sym: StockSymbol): number;
/**
2021-10-30 22:03:34 +02:00
* Returns the players position in a stock.
* @remarks
* RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* Returns an array of four elements that represents the players position in a stock.
*
* The first element is the returned array is the number of shares the player owns of
* the stock in the Long position. The second element in the array is the average price
* of the players shares in the Long position.
*
* The third element in the array is the number of shares the player owns of the stock
* in the Short position. The fourth element in the array is the average price of the
* players Short position.
*
* All elements in the returned array are numeric.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* pos = getPosition("ECP");
* shares = pos[0];
* avgPx = pos[1];
* sharesShort = pos[2];
* avgPxShort = pos[3];
* ```
* @param sym - Stock symbol.
* @returns Array of four elements that represents the players position in a stock.
*/
getPosition(sym: StockSymbol): [number, number, number, number];
/**
2021-10-30 22:03:34 +02:00
* Returns the maximum number of shares of a stock.
* @remarks
* RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* This is the maximum amount of the stock that can be purchased
* in both the Long and Short positions combined.
*
* @param sym - Stock symbol.
* @returns Maximum number of shares that the stock has.
*/
getMaxShares(sym: StockSymbol): number;
/**
2021-10-30 22:03:34 +02:00
* Calculates cost of buying stocks.
* @remarks
* RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* Calculates and returns how much it would cost to buy a given number of shares of a stock.
* This takes into account spread, large transactions influencing the price of the stock and commission fees.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to purchase.
* @param posType - Specifies whether the order is a Long or Short position.
* @returns Cost to buy a given number of shares of a stock.
*/
2021-10-30 21:46:34 +02:00
getPurchaseCost(sym: StockSymbol, shares: number, posType: OrderPosition): number;
2021-10-30 18:34:14 +02:00
/**
2021-10-30 22:03:34 +02:00
* Calculate profit of setting stocks.
* @remarks
* RAM cost: 2 GB
2021-10-30 18:34:14 +02:00
* Calculates and returns how much you would gain from selling a given number of shares of a stock.
* This takes into account spread, large transactions influencing the price of the stock and commission fees.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to sell.
* @param posType - Specifies whether the order is a Long or Short position.
* @returns Gain from selling a given number of shares of a stock.
*/
2021-10-30 21:46:34 +02:00
getSaleGain(sym: StockSymbol, shares: number, posType: OrderPosition): number;
2021-10-30 18:34:14 +02:00
/**
2021-10-30 22:03:34 +02:00
* Buy stocks.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Attempts to purchase shares of a stock using a Market Order.
*
* If the player does not have enough money to purchase the specified number of shares,
* then no shares will be purchased. Remember that every transaction on the stock exchange
* costs a certain commission fee.
*
* If this function successfully purchases the shares, it will return the stock price at which
* each share was purchased. Otherwise, it will return 0.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to purchased. Must be positive. Will be rounded to nearest integer.
* @returns The stock price at which each share was purchased, otherwise 0 if the shares weren't purchased.
*/
buy(sym: StockSymbol, shares: number): number;
/**
2021-10-30 22:03:34 +02:00
* Sell stocks.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Attempts to sell shares of a stock using a Market Order.
*
* If the specified number of shares in the function exceeds the amount that the player
* actually owns, then this function will sell all owned shares. Remember that every
* transaction on the stock exchange costs a certain commission fee.
*
* The net profit made from selling stocks with this function is reflected in the scripts
* statistics. This net profit is calculated as:
*
* shares * (sell_price - average_price_of_purchased_shares)
*
* If the sale is successful, this function will return the stock price at
* which each share was sold. Otherwise, it will return 0.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to sell. Must be positive. Will be rounded to nearest integer.
* @returns The stock price at which each share was sold, otherwise 0 if the shares weren't sold.
*/
sell(sym: StockSymbol, shares: number): number;
/**
2021-10-30 22:03:34 +02:00
* Short stocks.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Attempts to purchase a short position of a stock using a Market Order.
*
* The ability to short a stock is **not** immediately available to the player and
* must be unlocked later on in the game.
*
* If the player does not have enough money to purchase the specified number of shares,
* then no shares will be purchased. Remember that every transaction on the stock exchange
* costs a certain commission fee.
*
* If the purchase is successful, this function will return the stock price at which each
* share was purchased. Otherwise, it will return 0.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to short. Must be positive. Will be rounded to nearest integer.
* @returns The stock price at which each share was purchased, otherwise 0 if the shares weren't purchased.
*/
short(sym: StockSymbol, shares: number): number;
/**
2021-10-30 22:03:34 +02:00
* Sell short stock.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Attempts to sell a short position of a stock using a Market Order.
*
* The ability to short a stock is **not** immediately available to the player and
* must be unlocked later on in the game.
*
* If the specified number of shares exceeds the amount that the player actually owns,
* then this function will sell all owned shares. Remember that every transaction on
* the stock exchange costs a certain commission fee.
*
* If the sale is successful, this function will return the stock price at which each
* share was sold. Otherwise it will return 0.
*
* @param sym - Stock symbol.
* @param shares - Number of shares to sell. Must be positive. Will be rounded to nearest integer.
* @returns The stock price at which each share was sold, otherwise 0 if the shares weren't sold.
*/
sellShort(sym: StockSymbol, shares: number): number;
/**
2021-10-30 22:03:34 +02:00
* Place order for stocks.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Places an order on the stock market. This function only works for Limit and Stop Orders.
*
* The ability to place limit and stop orders is **not** immediately available to the player and
* must be unlocked later on in the game.
*
* Returns true if the order is successfully placed, and false otherwise.
*
* @param sym - Stock symbol.
* @param shares - Number of shares for order. Must be positive. Will be rounded to nearest integer.
* @param price - Execution price for the order.
* @param type - Type of order.
* @param pos - Specifies whether the order is a Long or Short position.
* @returns True if the order is successfully placed, and false otherwise.
*/
2021-10-30 21:46:34 +02:00
placeOrder(sym: StockSymbol, shares: number, price: number, type: OrderType, pos: OrderPosition): boolean;
2021-10-30 18:34:14 +02:00
/**
2021-10-30 22:03:34 +02:00
* Cancel order for stocks.
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Cancels an oustanding Limit or Stop order on the stock market.
*
* The ability to use limit and stop orders is **not** immediately available to the player and
* must be unlocked later on in the game.
*
* @param sym - Stock symbol.
* @param shares - Number of shares for order. Must be positive. Will be rounded to nearest integer.
* @param price - Execution price for the order.
* @param type - Type of order.
* @param pos - Specifies whether the order is a Long or Short position.
*/
2021-10-30 21:46:34 +02:00
cancelOrder(sym: StockSymbol, shares: number, price: number, type: OrderType, pos: OrderPosition): void;
2021-10-30 18:34:14 +02:00
/**
* Returns your order book for the stock market.
2021-10-30 22:03:34 +02:00
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* This is an object containing information for all the Limit and Stop Orders you have in the stock market.
* The object has the following structure:
*
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* {
* StockSymbol1: [ // Array of orders for this stock
* {
* shares: Order quantity
* price: Order price
* type: Order type
* position: Either "L" or "S" for Long or Short position
* },
* {
* ...
* },
* ...
* ],
* StockSymbol2: [ // Array of orders for this stock
* ...
* ],
* ...
* }
* ```
2021-10-30 22:03:34 +02:00
* The Order type property can have one of the following four values: "Limit Buy Order", "Limit Sell Order", "Stop Buy Order", "Stop Sell Order".
2021-10-30 18:34:14 +02:00
* Note that the order book will only contain information for stocks that you actually have orders in.
*
* @example
2021-10-30 21:46:34 +02:00
* ```ts
2021-10-30 18:34:14 +02:00
* "If you do not have orders in Nova Medical (NVMD), then the returned object will not have a “NVMD” property."
* {
* ECP: [
* {
* shares: 5,
* price: 100,000
* type: "Stop Buy Order",
* position: "S",
* },
* {
* shares: 25,
* price: 125,000
* type: "Limit Sell Order",
* position: "L",
* },
* ],
* SYSC: [
* {
* shares: 100,
* price: 10,000
* type: "Limit Buy Order",
* position: "L",
* },
* ],
* }
* ```
* @returns Object containing information for all the Limit and Stop Orders you have in the stock market.
*/
getOrders(): StockOrder;
/**
* Returns the volatility of the specified stock.
2021-10-30 22:03:34 +02:00
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* Volatility represents the maximum percentage by which a stocks price can change every tick.
* The volatility is returned as a decimal value, NOT a percentage
* (e.g. if a stock has a volatility of 3%, then this function will return 0.03, NOT 3).
*
* In order to use this function, you must first purchase access to the Four Sigma (4S) Market Data TIX API.
*
* @param sym - Stock symbol.
* @returns Volatility of the specified stock.
*/
getVolatility(sym: StockSymbol): number;
/**
* Returns the probability that the specified stocks price will increase (as opposed to decrease) during the next tick.
2021-10-30 22:03:34 +02:00
* @remarks
* RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* The probability is returned as a decimal value, NOT a percentage
* (e.g. if a stock has a 60% chance of increasing, then this function will return 0.6, NOT 60).
*
* In other words, if this function returned 0.30 for a stock, then this means that the stocks price has a
* 30% chance of increasing and a 70% chance of decreasing during the next tick.
*
* In order to use this function, you must first purchase access to the Four Sigma (4S) Market Data TIX API.
*
* @param sym - Stock symbol.
* @returns Probability that the specified stocks price will increase (as opposed to decrease) during the next tick.
*/
getForecast(sym: StockSymbol): number;
/**
* Purchase 4S Market Data Access.
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* @returns True if you successfully purchased it or if you already have access, false otherwise.
*/
purchase4SMarketData(): boolean;
/**
* Purchase 4S Market Data TIX API Access.
2021-10-30 21:46:34 +02:00
* @remarks RAM cost: 2.5 GB
2021-10-30 18:34:14 +02:00
* @returns True if you successfully purchased it or if you already have access, false otherwise.
*/
purchase4SMarketDataTixApi(): boolean;
}
/**
2021-10-30 21:46:34 +02:00
* All universities.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type University = "Summit University" | "Rothman University" | "ZB Institute Of Technology";
/**
2021-10-30 21:46:34 +02:00
* All university courses.
2021-10-30 18:34:14 +02:00
* @public
*/
export declare type UniversityCourse =
| "Study Computer Science"
| "Data Strucures"
| "Networks"
| "Algorithms"
| "Management"
| "Leadership";
export { }