h1z1-server

    Hierarchy

    • EventEmitter
      • ZoneServer2016
    Index

    Constructors

    Properties

    _accountItemDefinitions _airdrop? _allowedCommands _characterIds _characters _clientEffectsData _clients _constructionDoors _constructionFoundations _constructionSimple _containerDefinitions _crates _db _decoys _destroyableDTOlist _destroyables _doors _explosives _firegroupDefinitions _firemodeDefinitions _gatewayServer _grid _hudIndicators _itemDefinitions _itemUseOptions _loginConnectionManager _loginServerInfo _lootableConstruction _lootableProps _lootbags _modelsData _mongoAddress _npcs _packetHandlers _plants _protocol _ready _rewardCrateDefinitions _screenEffects _serverGuid _serverName _serverStartTime _soloMode _spawnedItems _spawnGrid _taskProps _temporaryObjects _throwableProjectiles _transientIds _traps _vehicles _weaponDefinitions _worldId _worldLootableConstruction _worldSimpleConstruction abilitiesManager abortShutdown accountInventoriesManager adminMessage aiManager baseConstructionDamage challengeManager challengePositionCheckInterval? charactersRenderDistance chatManager commandHandler configManager constructionManager crowbarHitDamage crowbarHitRewardChance decayManager dynamicappearance dynamicAppearanceCache? enableLoginServerKickRequests enablePacketInputLogging enableWorldSaves fairPlayManager gameVersion groupManager hookManager inGameTimeManager initialDataStaticDtoCache? interactionDistance isFirstPersonOnly isHeadshotOnly isLocked isNoBuildInPois isPvE isRebooting isSaving itemClassDefinitionsCache? itemDefinitionsCache? lastItemGuid navManager nextSaveTime playTimeManager pluginManager profileDefinitionsCache? projectileDefinitionsCache? proximityItemsDistance pSetImmediate pSetTimeout pUtilizeHudTimer randomEventsManager rconManager rebootTime rebootTimeTimer? rebootWarnTime rewardManager routinesLoopTimer? saveTimeInterval serverGameRules shutdownStarted shutdownStartedTime smeltingManager speedtreeManager staticBuildings staticDTOs tickRate voiceChatManager weaponDefinitionsCache? weatherManager welcomeMessage worldDataManager worldObjectManager worldRoutineRate worldRoutineTimer worldSaveFailed worldSaveVersion captureRejections captureRejectionSymbol defaultMaxListeners errorMonitor

    Methods

    [captureRejectionSymbol]? addContainerItem addItem addLightweightNpc addListener addScreenEffect addSimpleNpc airdropManager applyArmorDamageReduction applyCharacterEffect applyHelmetDamageReduction applyMovementModifier assignChunkRenderDistance assignManagedObject banClient changeSeat checkInMapBounds checkNightVision checkRespirator checkZonePing clearEquipmentSlot clearInventory clearMovementModifiers combatLog containerError createClient createFairPlayInternalPacket createProjectileNpc createThrowableProjectile customizeDTO customizeStaticDTOs damageItem debugSendData deleteClient deleteEntity deleteItem despawnEntity detectEnasMovement dismissVehicle dismountVehicle divideLargeCells divideMovementModifier dropAllManagedObjects dropItem dropManagedObject dropVehicleManager emit enforceBan eventNames executeFuncForAllReadyClients executeFuncForAllReadyClientsInRange executeRconCommand executeRoutine explosionDamage fertilizePlants fetchCharacterData fillPass firstRoutine generateAccountItem generateDamageRecord generateGuid generateItem generateItemGuid generateRandomEquipmentForSlot generateRandomEquipmentsFromAnEntity getAllCurrentUsedTransientId getClientByCharId getClientByContainerAccessor getClientByGuid getClientByLoginSessionId getClientByName getClientByNameOrLoginSession getClientsInRange getConstructionDictionary getConstructionEntity getContainerDefinition getCraftingProximityItems getCrateRewards getDurabilityDamage getEntity getEntityDictionary getFiregroupDefinition getFiremodeDefinition getIsAdmin getItemBaseDurability getItemDefinition getLoadoutSlot getLootableEntity getMaxListeners getOfflineClientByCharId getOfflineClientByName getProjectileDamage getProximityItems getRandomCrateReward getResourceMaxValue getShaderGroupId getShaderParameterGroup getTransientId getWeaponAmmoId getWeaponClipSize getWeaponDefinition getWeaponHitEffect getWeaponMaxAmmo getWeaponReloadTime handleRconMessage handleWeaponFire handleWeaponFireStateUpdate handleWeaponReload igniteOption igniteoptionPass initClientEffectsDataSource initHudIndicatorDataSource initializeContainerList initModelsDataSource initScreenEffectDataSource initUseOptionsDataSource isAccountItem isAdminItem isArmor isBanExpired isBoot isClientBanned isConstruction isContainer isConvey isFootwear isGator isGeneric isHelmet isStackable isWeapon isZed kickPlayer kickPlayerWithReason killCharacter listenerCount listeners loadCharacterData logPlayerDeath lootAccountItem lootCrateWithChance mountVehicle multiplyMovementModifier off on once onCharacterCreateRequest onClientAllowedRequest onClientIsAdminRequest onZoneDataEvent onZoneLoginEvent pickupItem playerNotFound prependListener prependOnceListener pushToGridCell rawListeners refuelVehicle refuelVehiclePass registerHit registerLoginConnectionListeners reloadCommandCache reloadInterrupt reloadPackets reloadZonePacketHandlers removeAccountItem removeAllListeners removeContainerItem removeInventoryItem removeInventoryItems removeListener removeLoadoutItem removeScreenEffect repairOption repairOptionPass requestModules respawnPlayer salvageAmmo salvageItemPass saveWorld sendAlert sendAlertToAll sendAnimationToAllWithSpawnedEntity sendCharacterAllowedReply sendCharacterData sendChatText sendChatTextToAdmins sendChatTextToAllOthers sendCompositeEffectToAllInRange sendCompositeEffectToAllWithSpawnedEntity sendConsoleText sendConsoleTextToAdmins sendData sendDataToAll sendDataToAllInRange sendDataToAllOthersWithSpawnedEntity sendDataToAllWithSpawnedEntity sendDeathMetrics sendDeliveryStatus sendDialogEffectToAllInRange sendGameTimeSync sendGlobalChatText sendHitmarker sendHudIndicators sendInitData sendKillFeed sendManagedObjectResponseControlPacket sendOrderedData sendRawDataReliable sendRawToAllOthersWithSpawnedCharacter sendRawToAllOthersWithSpawnedEntity sendRemoteWeaponData sendRemoteWeaponDataToAllOthers sendRemoteWeaponUpdateData sendRemoteWeaponUpdateDataToAllOthers sendUnbufferedData sendUnbufferedRawDataReliable sendWeaponData sendWeaponReload sendZonePopulationUpdate setGodMode setMaxListeners setTempGodMode setTickRate shredItem shredItemPass shutdown sleep sliceItem slicePass sniffPass spawnAirdrop spawnCharacters spawnCharacterToOtherClients spawnContainerAccessNpc spawnSimpleNpcForAllInRange spawnStaticBuildings start startH1emuAi startInteractionTimer startRoutinesLoop startTimer stop stopHudTimer switchLoadoutSlot syncAirdrop takeoverManagedObject taskOption taskOptionPass tempGodMode timeoutClient unbanClient unbanClientId updateAirdropIndicator updateCharacterState updateContainer updateContainerItem updateFootwear updateItem updateLoadoutItem updateResource updateResourceToAllWithSpawnedEntity useAirdrop useAmmoBox useComsumablePass useConsumable useDeerScent useItem usePills utilizeHudTimer validateEquipmentSlot validateHit validateLoadoutSlot vehicleManager addAbortListener getEventListeners getMaxListeners listenerCount on once setMaxListeners

    Constructors

    • Parameters

      • serverPort: number
      • gatewayKey: Uint8Array = ...
      • mongoAddress: string = ""
      • OptionalworldId: number
      • OptionalinternalServerPort: number

      Returns ZoneServer2016

    Properties

    _accountItemDefinitions: { [ACCOUNT_ITEM_ID: number]: AccountDefinition } = accountItemConversions
    _airdrop?: {
        cargo?: Plane;
        cargoSpawned: boolean;
        cargoTarget: string;
        cargoTargetPos: Float32Array;
        containerSpawned: boolean;
        destination: string;
        destinationPos: Float32Array;
        forcedAirdropType?: string;
        manager?: ZoneClient2016;
        plane: Plane;
        planeTarget: string;
        planeTargetPos: Float32Array;
    }

    Airdrop information - includes: plane (Plane), cargo (Plane), planeTarget (string), planeTargetPos (Float32Array), cargoTarget (string), cargoTargetPos(Float32Array), destination (string), destinationPos (Float32Array), cargoSpawned (boolean), hospitalCrate (boolean), manager (Client)

    _allowedCommands: string[] = ...
    _characterIds: { [characterId: string]: number } = {}
    _characters: EntityDictionary<Character2016> = {}

    Global dictionaries for all entities

    _clientEffectsData: { [effectId: number]: clientEffect } = {}
    _clients: { [characterId: string]: ZoneClient2016 } = {}

    Total amount of clients on the server

    _constructionDoors: EntityDictionary<ConstructionDoor> = {}
    _constructionFoundations: EntityDictionary<ConstructionParentEntity> = {}
    _constructionSimple: EntityDictionary<ConstructionChildEntity> = {}
    _containerDefinitions: { [containerDefinitionId: number]: any } = containerDefinitions
    _crates: EntityDictionary<Crate> = {}
    _db: Db
    _decoys: {
        [transientId: number]: {
            action: string;
            characterId: string;
            position: Float32Array;
            transientId: number;
        };
    } = {}
    _destroyableDTOlist: number[] = []
    _destroyables: EntityDictionary<Destroyable> = {}
    _firegroupDefinitions: { [firegroupId: number]: any } = weaponDefinitions.FIRE_GROUP_DEFINITIONS
    _firemodeDefinitions: { [firemodeId: number]: any } = weaponDefinitions.FIRE_MODE_DEFINITIONS
    _gatewayServer: GatewayServer

    Networking layer - allows sending game data to the game client, lays on top of the H1Z1 protocol (on top of the actual H1Z1 packets)

    _grid: GridCell[] = []
    _hudIndicators: { [indicatorId: string]: HudIndicator } = {}
    _itemDefinitions: { [itemDefinitionId: number]: ItemDefinition } = itemDefinitions

    Information from ServerItemDefinitions.json

    _itemUseOptions: { [optionId: number]: UseOption } = {}

    Interactible options for items - See (ZonePacketHandlers.ts or datasources/ItemUseOptions)

    _loginConnectionManager: LoginConnectionManager
    _loginServerInfo: { address?: string; port: number } = ...

    Determines which login server is used, Localhost by default.

    _lootableConstruction: EntityDictionary<LootableConstructionEntity> = {}
    _lootableProps: EntityDictionary<LootableProp> = {}
    _lootbags: EntityDictionary<Lootbag> = {}
    _modelsData: { [modelId: number]: modelData } = {}
    _mongoAddress: string
    _npcs: EntityDictionary<Npc> = {}
    _packetHandlers: ZonePacketHandlers

    Handles all packets for H1Z1

    _plants: EntityDictionary<Plant> = {}
    _protocol: H1Z1Protocol
    _ready: boolean = false
    _rewardCrateDefinitions: RewardCrateDefinition[] = rewardCrates
    _screenEffects: { [screenEffectName: string]: ScreenEffect } = {}
    _serverGuid: string = ...
    _serverName: string = ...
    _serverStartTime: TimeWrapper = ...
    _soloMode: boolean
    _spawnedItems: EntityDictionary<ItemObject> = {}
    _spawnGrid: SpawnCell[] = []
    _taskProps: EntityDictionary<TaskProp> = {}
    _throwableProjectiles: EntityDictionary<ProjectileEntity> = {}
    _transientIds: { [transientId: number]: string } = {}
    _vehicles: EntityDictionary<Vehicle2016> = {}
    _weaponDefinitions: { [weaponDefinitionId: number]: any } = weaponDefinitions.WEAPON_DEFINITIONS
    _worldId: number = 0
    _worldLootableConstruction: EntityDictionary<LootableConstructionEntity> = {}
    _worldSimpleConstruction: EntityDictionary<ConstructionChildEntity> = {}
    abilitiesManager: AbilitiesManager
    abortShutdown: boolean = false
    accountInventoriesManager: AccountInventoryManager

    Managers used for handling core functionalities

    adminMessage: string
    aiManager: AiManager
    baseConstructionDamage: number
    challengeManager: ChallengeManager
    challengePositionCheckInterval?: Timeout
    charactersRenderDistance: number
    chatManager: ChatManager
    commandHandler: CommandHandler
    configManager: ConfigManager
    constructionManager: ConstructionManager
    crowbarHitDamage: number
    crowbarHitRewardChance: number
    decayManager: DecayManager
    dynamicappearance: DynamicAppearance
    dynamicAppearanceCache?: Buffer<ArrayBufferLike>
    enableLoginServerKickRequests: boolean
    enablePacketInputLogging: boolean = false
    enableWorldSaves: boolean
    fairPlayManager: FairPlayManager
    gameVersion: GAME_VERSIONS = GAME_VERSIONS.H1Z1_6dec_2016
    groupManager: GroupManager
    hookManager: HookManager
    inGameTimeManager: IngameTimeManager = ...
    initialDataStaticDtoCache?: Buffer<ArrayBufferLike>
    interactionDistance: number
    isFirstPersonOnly: boolean
    isHeadshotOnly: boolean
    isLocked: boolean = false
    isNoBuildInPois: boolean
    isPvE: boolean
    isRebooting: boolean = false
    isSaving: boolean = false
    itemClassDefinitionsCache?: Buffer<ArrayBufferLike>
    itemDefinitionsCache?: Buffer<ArrayBufferLike>
    lastItemGuid: bigint = 0x3000000000000000n
    navManager: NavManager
    nextSaveTime: number = ...
    playTimeManager: PlayTimeManager
    pluginManager: PluginManager
    profileDefinitionsCache?: Buffer<ArrayBufferLike>
    projectileDefinitionsCache?: Buffer<ArrayBufferLike>
    proximityItemsDistance: number

    MANAGED BY CONFIGMANAGER - See defaultConfig.yaml for more information

    pSetImmediate: <T = void>(value?: T, options?: TimerOptions) => Promise<T> = ...

    Type declaration

      • <T = void>(value?: T, options?: TimerOptions): Promise<T>
      • import {
        setImmediate,
        } from 'node:timers/promises';

        const res = await setImmediate('result');

        console.log(res); // Prints 'result'

        Type Parameters

        • T = void

        Parameters

        • Optionalvalue: T

          A value with which the promise is fulfilled.

        • Optionaloptions: TimerOptions

        Returns Promise<T>

        v15.0.0

    pSetTimeout: <T = void>(
        delay?: number,
        value?: T,
        options?: TimerOptions,
    ) => Promise<T> = ...

    Type declaration

      • <T = void>(delay?: number, value?: T, options?: TimerOptions): Promise<T>
      • import {
        setTimeout,
        } from 'node:timers/promises';

        const res = await setTimeout(100, 'result');

        console.log(res); // Prints 'result'

        Type Parameters

        • T = void

        Parameters

        • Optionaldelay: number

          The number of milliseconds to wait before fulfilling the promise.

        • Optionalvalue: T

          A value with which the promise is fulfilled.

        • Optionaloptions: TimerOptions

        Returns Promise<T>

        v15.0.0

    pUtilizeHudTimer: (
        arg1: ZoneClient2016,
        arg2: number,
        arg3: number,
        arg4: number,
    ) => Promise<unknown> = ...
    randomEventsManager: RandomEventsManager
    rconManager: RConManager
    rebootTime: number
    rebootTimeTimer?: Timeout
    rebootWarnTime: number
    rewardManager: RewardManager
    routinesLoopTimer?: Timeout
    saveTimeInterval: number = 600000
    serverGameRules: string
    shutdownStarted: boolean = false
    shutdownStartedTime: number = 0
    smeltingManager: SmeltingManager
    speedtreeManager: SpeedTreeManager
    staticBuildings: AddSimpleNpc[] = ...
    staticDTOs: PropInstance[] = []
    tickRate: number
    voiceChatManager: VoiceChatManager
    weaponDefinitionsCache?: Buffer<ArrayBufferLike>
    weatherManager: WeatherManager
    welcomeMessage: string
    worldDataManager: WorldDataManagerThreaded
    worldObjectManager: WorldObjectManager
    worldRoutineRate: number
    worldRoutineTimer: Timeout
    worldSaveFailed: boolean = false
    worldSaveVersion: number = 2
    captureRejections: boolean

    Value: boolean

    Change the default captureRejections option on all new EventEmitter objects.

    v13.4.0, v12.16.0

    captureRejectionSymbol: typeof captureRejectionSymbol

    Value: Symbol.for('nodejs.rejection')

    See how to write a custom rejection handler.

    v13.4.0, v12.16.0

    defaultMaxListeners: number

    By default, a maximum of 10 listeners can be registered for any single event. This limit can be changed for individual EventEmitter instances using the emitter.setMaxListeners(n) method. To change the default for allEventEmitter instances, the events.defaultMaxListeners property can be used. If this value is not a positive number, a RangeError is thrown.

    Take caution when setting the events.defaultMaxListeners because the change affects all EventEmitter instances, including those created before the change is made. However, calling emitter.setMaxListeners(n) still has precedence over events.defaultMaxListeners.

    This is not a hard limit. The EventEmitter instance will allow more listeners to be added but will output a trace warning to stderr indicating that a "possible EventEmitter memory leak" has been detected. For any single EventEmitter, the emitter.getMaxListeners() and emitter.setMaxListeners() methods can be used to temporarily avoid this warning:

    import { EventEmitter } from 'node:events';
    const emitter = new EventEmitter();
    emitter.setMaxListeners(emitter.getMaxListeners() + 1);
    emitter.once('event', () => {
    // do stuff
    emitter.setMaxListeners(Math.max(emitter.getMaxListeners() - 1, 0));
    });

    The --trace-warnings command-line flag can be used to display the stack trace for such warnings.

    The emitted warning can be inspected with process.on('warning') and will have the additional emitter, type, and count properties, referring to the event emitter instance, the event's name and the number of attached listeners, respectively. Its name property is set to 'MaxListenersExceededWarning'.

    v0.11.2

    errorMonitor: typeof errorMonitor

    This symbol shall be used to install a listener for only monitoring 'error' events. Listeners installed using this symbol are called before the regular 'error' listeners are called.

    Installing a listener using this symbol does not change the behavior once an 'error' event is emitted. Therefore, the process will still crash if no regular 'error' listener is installed.

    v13.6.0, v12.17.0

    Methods

    • Type Parameters

      • K

      Parameters

      • error: Error
      • event: string | symbol
      • ...args: AnyRest

      Returns void

    • Alias for emitter.on(eventName, listener).

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v0.1.26

    • Parameters

      • loginSessionId: string
      • characterName: string
      • reason: string
      • adminId: string
      • timestamp: number
      • isSilent: boolean

      Returns Promise<void>

    • Clears a character's equipment slot.

      Parameters

      • character: BaseFullCharacter

        The character to have their equipment slot cleared.

      • equipmentSlotId: number

        The equipment slot to clear.

      • OptionalsendPacket: boolean = true

        Optional: Specifies whether to send a packet to other clients, default is true.

      Returns boolean

      Returns true if the slot was cleared, false if the slot is invalid.

    • Parameters

      • sessionId: number
      • soeClientId: string
      • loginSessionId: string
      • characterId: string
      • generatedTransient: number

      Returns ZoneClient2016

    • Synchronously calls each of the listeners registered for the event named eventName, in the order they were registered, passing the supplied arguments to each.

      Returns true if the event had listeners, false otherwise.

      import { EventEmitter } from 'node:events';
      const myEmitter = new EventEmitter();

      // First listener
      myEmitter.on('event', function firstListener() {
      console.log('Helloooo! first listener');
      });
      // Second listener
      myEmitter.on('event', function secondListener(arg1, arg2) {
      console.log(`event with parameters ${arg1}, ${arg2} in second listener`);
      });
      // Third listener
      myEmitter.on('event', function thirdListener(...args) {
      const parameters = args.join(', ');
      console.log(`event with parameters ${parameters} in third listener`);
      });

      console.log(myEmitter.listeners('event'));

      myEmitter.emit('event', 1, 2, 3, 4, 5);

      // Prints:
      // [
      // [Function: firstListener],
      // [Function: secondListener],
      // [Function: thirdListener]
      // ]
      // Helloooo! first listener
      // event with parameters 1, 2 in second listener
      // event with parameters 1, 2, 3, 4, 5 in third listener

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol
      • ...args: AnyRest

      Returns boolean

      v0.1.26

    • Returns an array listing the events for which the emitter has registered listeners. The values in the array are strings or Symbols.

      import { EventEmitter } from 'node:events';

      const myEE = new EventEmitter();
      myEE.on('foo', () => {});
      myEE.on('bar', () => {});

      const sym = Symbol('symbol');
      myEE.on(sym, () => {});

      console.log(myEE.eventNames());
      // Prints: [ 'foo', 'bar', Symbol(symbol) ]

      Returns (string | symbol)[]

      v6.0.0

    • Generates a new item with the specified itemDefinitionId and count.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the item to generate.

      • Optionalcount: number = 1

        The count of the item.

      • OptionalforceMaxDurability: boolean = false

        force the item to have his max durability.

      Returns undefined | BaseItem

      The generated item, or undefined if the item definition is invalid.

    • Generates random equipment for a specific slot (Zombies only).

      Parameters

      • slotId: number

        The ID of the slot.

      • gender: number

        The gender of the entity.

      • excludedModels: string[] = []

        [excludedModels=[]] - The excluded equipment models.

      Returns { guid: string; modelName: string; slotId: number; textureAlias: any }

      The generated equipment.

    • Generates random equipment for the specified entity and slots (Zombies only). To be deprecated soon

      Parameters

      • entity: BaseFullCharacter

        The entity to generate equipment for.

      • slots: number[]

        The slots to generate equipment for.

      • excludedModels: string[] = []

        [excludedModels=[]] - The excluded equipment models.

      Returns void

    • Gets the container definition for a given containerDefinitionId.

      Parameters

      • containerDefinitionId: number

        The id of the container definition to retrieve.

      Returns any

      The container definition.

    • Gets the firegroup definition for a given firegroupId.

      Parameters

      • firegroupId: number

        The ID of the firegroup definition to retrieve.

      Returns any

      The firegroup definition or undefined.

    • Gets the firemode definition for a given firemodeId.

      Parameters

      • firemodeId: number

        The ID of the firemode definition to retrieve.

      Returns any

      The firemode definition or undefined.

    • Gets the max durability for a given itemDefinitionId.

      Parameters

      • OptionalitemDefinitionId: number

        The ID of the item definition to retrieve.

      Returns number

      The item definition or undefined.

    • Gets the first loadout slot that a specified item is able to go into.

      Parameters

      • itemDefId: number

        The definition ID of an item to check.

      • OptionalloadoutId: number = LoadoutIds.CHARACTER

        Optional: The loadoutId of the entity to get the slot for, default LoadoutIds.CHARACTER.

      Returns any

      Returns the ID of the first loadout slot that an item can go into (occupied or not).

    • Returns the current max listener value for the EventEmitter which is either set by emitter.setMaxListeners(n) or defaults to EventEmitter.defaultMaxListeners.

      Returns number

      v1.0.0

    • Generates a new transientId and maps it to a provided characterId.

      Parameters

      • characterId: string

        The characterId to map the transientId to.

      Returns number

    • Gets the ammoId for a given weapon.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the weapon.

      Returns number

      The ammoId (0 if undefined).

    • Gets the clip size for a given weapon.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the weapon.

      Returns number

      The clip size (0 if undefined).

    • Gets the weapon definition for a given weaponDefinitionId.

      Parameters

      • weaponDefinitionId: number

        The ID of the weapon definition to retrieve.

      Returns any

      The weapon definition or undefined.

    • Gets the maximum amount of ammo a clip can hold for a given weapon.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the weapon.

      Returns number

      The maximum ammo (0 if undefined).

    • Gets the reload time in milliseconds for a given weapon.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the weapon.

      Returns number

      The reload time in milliseconds (0 if undefined).

    • Checks if an item with the specified itemDefinitionId is an armor.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is an armor, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a boot.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a convey, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a construction type.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a generic type, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a container.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a container, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a convey.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a convey, false otherwise.

    • Checks if an item with the specified itemDefinitionId is footwear.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a boot, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a gator shoe.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a convey, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a generic item type.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a generic type, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a helmet.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a helmet, false otherwise.

    • Checks if an item with the specified itemDefinitionId is stackable.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is stackable, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a weapon.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a weapon, false otherwise.

    • Checks if an item with the specified itemDefinitionId is a zed shoe.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId to check.

      Returns boolean

      True if the item is a convey, false otherwise.

    • Returns the number of listeners listening for the event named eventName. If listener is provided, it will return how many times the listener is found in the list of the listeners of the event.

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

        The name of the event being listened for

      • Optionallistener: Function

        The event handler function

      Returns number

      v3.2.0

    • Returns a copy of the array of listeners for the event named eventName.

      server.on('connection', (stream) => {
      console.log('someone connected!');
      });
      console.log(util.inspect(server.listeners('connection')));
      // Prints: [ [Function] ]

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

      Returns Function[]

      v0.1.26

    • Alias for emitter.removeListener().

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v10.0.0

    • Adds the listener function to the end of the listeners array for the event named eventName. No checks are made to see if the listener has already been added. Multiple calls passing the same combination of eventName and listener will result in the listener being added, and called, multiple times.

      server.on('connection', (stream) => {
      console.log('someone connected!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      By default, event listeners are invoked in the order they are added. The emitter.prependListener() method can be used as an alternative to add the event listener to the beginning of the listeners array.

      import { EventEmitter } from 'node:events';
      const myEE = new EventEmitter();
      myEE.on('foo', () => console.log('a'));
      myEE.prependListener('foo', () => console.log('b'));
      myEE.emit('foo');
      // Prints:
      // b
      // a

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v0.1.101

    • Adds a one-time listener function for the event named eventName. The next time eventName is triggered, this listener is removed and then invoked.

      server.once('connection', (stream) => {
      console.log('Ah, we have our first user!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      By default, event listeners are invoked in the order they are added. The emitter.prependOnceListener() method can be used as an alternative to add the event listener to the beginning of the listeners array.

      import { EventEmitter } from 'node:events';
      const myEE = new EventEmitter();
      myEE.once('foo', () => console.log('a'));
      myEE.prependOnceListener('foo', () => console.log('b'));
      myEE.emit('foo');
      // Prints:
      // b
      // a

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v0.3.0

    • Adds the listener function to the beginning of the listeners array for the event named eventName. No checks are made to see if the listener has already been added. Multiple calls passing the same combination of eventName and listener will result in the listener being added, and called, multiple times.

      server.prependListener('connection', (stream) => {
      console.log('someone connected!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v6.0.0

    • Adds a one-timelistener function for the event named eventName to the beginning of the listeners array. The next time eventName is triggered, this listener is removed, and then invoked.

      server.prependOnceListener('connection', (stream) => {
      console.log('Ah, we have our first user!');
      });

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

        The name of the event.

      • listener: (...args: any[]) => void

        The callback function

      Returns this

      v6.0.0

    • Returns a copy of the array of listeners for the event named eventName, including any wrappers (such as those created by .once()).

      import { EventEmitter } from 'node:events';
      const emitter = new EventEmitter();
      emitter.once('log', () => console.log('log once'));

      // Returns a new Array with a function `onceWrapper` which has a property
      // `listener` which contains the original listener bound above
      const listeners = emitter.rawListeners('log');
      const logFnWrapper = listeners[0];

      // Logs "log once" to the console and does not unbind the `once` event
      logFnWrapper.listener();

      // Logs "log once" to the console and removes the listener
      logFnWrapper();

      emitter.on('log', () => console.log('log persistently'));
      // Will return a new Array with a single function bound by `.on()` above
      const newListeners = emitter.rawListeners('log');

      // Logs "log persistently" twice
      newListeners[0]();
      emitter.emit('log');

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol

      Returns Function[]

      v9.4.0

    • Removes an item from the account inventory.

      Parameters

      • character: BaseFullCharacter

        The character to have their items removed.

      • item: BaseItem

        The item to remove.

      • Optionalcount: number = 1

        Optional: Specifies the amount of items that need to be removed, default is 1.

      Returns boolean

      Returns true if the item was successfully removed, false if there was an error.

    • Removes all listeners, or those of the specified eventName.

      It is bad practice to remove listeners added elsewhere in the code, particularly when the EventEmitter instance was created by some other component or module (e.g. sockets or file streams).

      Returns a reference to the EventEmitter, so that calls can be chained.

      Parameters

      • OptionaleventName: string | symbol

      Returns this

      v0.1.26

    • Removes items from a specific item stack in a container.

      Parameters

      • character: BaseFullCharacter

        The character to have their items removed.

      • Optionalitem: BaseItem

        The item object.

      • Optionalcontainer: LoadoutContainer

        The container that has the item stack in it.

      • Optionalcount: number

        Optional: The number of items to remove from the stack, default 1.

      Returns boolean

      Returns true if the items were successfully removed, false if there was an error.

    • Removes items from a specific item stack in the inventory, including containers and loadout.

      Parameters

      • character: BaseFullCharacter

        The character to have their items removed.

      • item: BaseItem

        The item object.

      • Optionalcount: number = 1

        Optional: The number of items to remove from the stack, default 1.

      • OptionalupdateEquipment: boolean = true

        Optional: Specifies whether to update the equipment, default is true.

      Returns boolean

      Returns true if the items were successfully removed, false if there was an error.

    • Removes a specified amount of an item across all inventory containers / loadout (LOADOUT DISABLED FOR NOW).

      Parameters

      • character: BaseFullCharacter
      • itemDefinitionId: number

        The itemDefinitionId of the item(s) to be removed.

      • requiredCount: number = 1

        Optional: The number of items to remove, default 1.

      Returns boolean

      Returns true if all items were successfully removed, false if there was an error.

    • Removes the specified listener from the listener array for the event named eventName.

      const callback = (stream) => {
      console.log('someone connected!');
      };
      server.on('connection', callback);
      // ...
      server.removeListener('connection', callback);

      removeListener() will remove, at most, one instance of a listener from the listener array. If any single listener has been added multiple times to the listener array for the specified eventName, then removeListener() must be called multiple times to remove each instance.

      Once an event is emitted, all listeners attached to it at the time of emitting are called in order. This implies that any removeListener() or removeAllListeners() calls after emitting and before the last listener finishes execution will not remove them fromemit() in progress. Subsequent events behave as expected.

      import { EventEmitter } from 'node:events';
      class MyEmitter extends EventEmitter {}
      const myEmitter = new MyEmitter();

      const callbackA = () => {
      console.log('A');
      myEmitter.removeListener('event', callbackB);
      };

      const callbackB = () => {
      console.log('B');
      };

      myEmitter.on('event', callbackA);

      myEmitter.on('event', callbackB);

      // callbackA removes listener callbackB but it will still be called.
      // Internal listener array at time of emit [callbackA, callbackB]
      myEmitter.emit('event');
      // Prints:
      // A
      // B

      // callbackB is now removed.
      // Internal listener array [callbackA]
      myEmitter.emit('event');
      // Prints:
      // A

      Because listeners are managed using an internal array, calling this will change the position indices of any listener registered after the listener being removed. This will not impact the order in which listeners are called, but it means that any copies of the listener array as returned by the emitter.listeners() method will need to be recreated.

      When a single function has been added as a handler multiple times for a single event (as in the example below), removeListener() will remove the most recently added instance. In the example the once('ping') listener is removed:

      import { EventEmitter } from 'node:events';
      const ee = new EventEmitter();

      function pong() {
      console.log('pong');
      }

      ee.on('ping', pong);
      ee.once('ping', pong);
      ee.removeListener('ping', pong);

      ee.emit('ping');
      ee.emit('ping');

      Returns a reference to the EventEmitter, so that calls can be chained.

      Type Parameters

      • K

      Parameters

      • eventName: string | symbol
      • listener: (...args: any[]) => void

      Returns this

      v0.1.26

    • Removes an item from the loadout.

      Parameters

      • character: BaseFullCharacter

        The character to have their items removed.

      • loadoutSlotId: number

        The loadout slot containing the item to remove.

      • OptionalupdateEquipment: boolean = true

        Optional: Specifies whether to update the equipment, default is true.

      Returns boolean

      Returns true if the item was successfully removed, false if there was an error.

    • Parameters

      • range: number
      • characterId: string
      • position: Float32Array
      • effectId: Effects

      Returns void

    • Parameters

      • message: string
      • showConsole: boolean = false
      • clearOutput: boolean = false

      Returns void

    • Parameters

      • client: ZoneClient2016
      • hitLocation: string = ""
      • hasHelmet: boolean
      • hasArmor: boolean
      • hasHelmetBefore: boolean
      • hasArmorBefore: boolean

      Returns void

    • By default EventEmitters will print a warning if more than 10 listeners are added for a particular event. This is a useful default that helps finding memory leaks. The emitter.setMaxListeners() method allows the limit to be modified for this specific EventEmitter instance. The value can be set to Infinity (or 0) to indicate an unlimited number of listeners.

      Returns a reference to the EventEmitter, so that calls can be chained.

      Parameters

      • n: number

      Returns this

      v0.3.5

    • Parameters

      • client: ZoneClient2016
      • timeout: number
      • nameId: number
      • removedItem: { count: number; itemDefinitionId: number }
      • rewardItems: { count: number; itemDefinitionId: number }[]

      Returns void

    • Parameters

      • client: ZoneClient2016
      • removedItem: { count: number; itemDefinitionId: number }
      • rewardItems: { count: number; itemDefinitionId: number }[]

      Returns void

    • Validates if an item can be equipped in the specified equipment slot.

      Parameters

      • itemDefinitionId: number

        The itemDefinitionId of the item to validate.

      • equipmentSlotId: number

        The equipment slot ID.

      Returns boolean

      True if the item can be equipped in the slot, false otherwise.

    • Validates that a given itemDefinitionId can be equipped in a given loadout slot.

      Parameters

      • itemDefinitionId: number

        The definition ID of an item to validate.

      • loadoutSlotId: number

        The loadoutSlotId to have the item validated for.

      • loadoutId: number

        The loadoutId of the entity to get the slot for.

      Returns boolean

      Returns true/false if the item can go in a specified loadout slot.

    • Experimental

      Listens once to the abort event on the provided signal.

      Listening to the abort event on abort signals is unsafe and may lead to resource leaks since another third party with the signal can call e.stopImmediatePropagation(). Unfortunately Node.js cannot change this since it would violate the web standard. Additionally, the original API makes it easy to forget to remove listeners.

      This API allows safely using AbortSignals in Node.js APIs by solving these two issues by listening to the event such that stopImmediatePropagation does not prevent the listener from running.

      Returns a disposable so that it may be unsubscribed from more easily.

      import { addAbortListener } from 'node:events';

      function example(signal) {
      let disposable;
      try {
      signal.addEventListener('abort', (e) => e.stopImmediatePropagation());
      disposable = addAbortListener(signal, (e) => {
      // Do something when signal is aborted.
      });
      } finally {
      disposable?.[Symbol.dispose]();
      }
      }

      Parameters

      • signal: AbortSignal
      • resource: (event: Event) => void

      Returns Disposable

      Disposable that removes the abort listener.

      v20.5.0

    • Returns a copy of the array of listeners for the event named eventName.

      For EventEmitters this behaves exactly the same as calling .listeners on the emitter.

      For EventTargets this is the only way to get the event listeners for the event target. This is useful for debugging and diagnostic purposes.

      import { getEventListeners, EventEmitter } from 'node:events';

      {
      const ee = new EventEmitter();
      const listener = () => console.log('Events are fun');
      ee.on('foo', listener);
      console.log(getEventListeners(ee, 'foo')); // [ [Function: listener] ]
      }
      {
      const et = new EventTarget();
      const listener = () => console.log('Events are fun');
      et.addEventListener('foo', listener);
      console.log(getEventListeners(et, 'foo')); // [ [Function: listener] ]
      }

      Parameters

      • emitter: EventEmitter<DefaultEventMap> | EventTarget
      • name: string | symbol

      Returns Function[]

      v15.2.0, v14.17.0

    • Returns the currently set max amount of listeners.

      For EventEmitters this behaves exactly the same as calling .getMaxListeners on the emitter.

      For EventTargets this is the only way to get the max event listeners for the event target. If the number of event handlers on a single EventTarget exceeds the max set, the EventTarget will print a warning.

      import { getMaxListeners, setMaxListeners, EventEmitter } from 'node:events';

      {
      const ee = new EventEmitter();
      console.log(getMaxListeners(ee)); // 10
      setMaxListeners(11, ee);
      console.log(getMaxListeners(ee)); // 11
      }
      {
      const et = new EventTarget();
      console.log(getMaxListeners(et)); // 10
      setMaxListeners(11, et);
      console.log(getMaxListeners(et)); // 11
      }

      Parameters

      • emitter: EventEmitter<DefaultEventMap> | EventTarget

      Returns number

      v19.9.0

    • A class method that returns the number of listeners for the given eventName registered on the given emitter.

      import { EventEmitter, listenerCount } from 'node:events';

      const myEmitter = new EventEmitter();
      myEmitter.on('event', () => {});
      myEmitter.on('event', () => {});
      console.log(listenerCount(myEmitter, 'event'));
      // Prints: 2

      Parameters

      • emitter: EventEmitter

        The emitter to query

      • eventName: string | symbol

        The event name

      Returns number

      v0.9.12

      Since v3.2.0 - Use listenerCount instead.

    • import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      });

      for await (const event of on(ee, 'foo')) {
      // The execution of this inner block is synchronous and it
      // processes one event at a time (even with await). Do not use
      // if concurrent execution is required.
      console.log(event); // prints ['bar'] [42]
      }
      // Unreachable here

      Returns an AsyncIterator that iterates eventName events. It will throw if the EventEmitter emits 'error'. It removes all listeners when exiting the loop. The value returned by each iteration is an array composed of the emitted event arguments.

      An AbortSignal can be used to cancel waiting on events:

      import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ac = new AbortController();

      (async () => {
      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      });

      for await (const event of on(ee, 'foo', { signal: ac.signal })) {
      // The execution of this inner block is synchronous and it
      // processes one event at a time (even with await). Do not use
      // if concurrent execution is required.
      console.log(event); // prints ['bar'] [42]
      }
      // Unreachable here
      })();

      process.nextTick(() => ac.abort());

      Use the close option to specify an array of event names that will end the iteration:

      import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      ee.emit('close');
      });

      for await (const event of on(ee, 'foo', { close: ['close'] })) {
      console.log(event); // prints ['bar'] [42]
      }
      // the loop will exit after 'close' is emitted
      console.log('done'); // prints 'done'

      Parameters

      • emitter: EventEmitter
      • eventName: string | symbol
      • Optionaloptions: StaticEventEmitterIteratorOptions

      Returns AsyncIterator<any[]>

      An AsyncIterator that iterates eventName events emitted by the emitter

      v13.6.0, v12.16.0

    • import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      });

      for await (const event of on(ee, 'foo')) {
      // The execution of this inner block is synchronous and it
      // processes one event at a time (even with await). Do not use
      // if concurrent execution is required.
      console.log(event); // prints ['bar'] [42]
      }
      // Unreachable here

      Returns an AsyncIterator that iterates eventName events. It will throw if the EventEmitter emits 'error'. It removes all listeners when exiting the loop. The value returned by each iteration is an array composed of the emitted event arguments.

      An AbortSignal can be used to cancel waiting on events:

      import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ac = new AbortController();

      (async () => {
      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      });

      for await (const event of on(ee, 'foo', { signal: ac.signal })) {
      // The execution of this inner block is synchronous and it
      // processes one event at a time (even with await). Do not use
      // if concurrent execution is required.
      console.log(event); // prints ['bar'] [42]
      }
      // Unreachable here
      })();

      process.nextTick(() => ac.abort());

      Use the close option to specify an array of event names that will end the iteration:

      import { on, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      // Emit later on
      process.nextTick(() => {
      ee.emit('foo', 'bar');
      ee.emit('foo', 42);
      ee.emit('close');
      });

      for await (const event of on(ee, 'foo', { close: ['close'] })) {
      console.log(event); // prints ['bar'] [42]
      }
      // the loop will exit after 'close' is emitted
      console.log('done'); // prints 'done'

      Parameters

      • emitter: EventTarget
      • eventName: string
      • Optionaloptions: StaticEventEmitterIteratorOptions

      Returns AsyncIterator<any[]>

      An AsyncIterator that iterates eventName events emitted by the emitter

      v13.6.0, v12.16.0

    • Creates a Promise that is fulfilled when the EventEmitter emits the given event or that is rejected if the EventEmitter emits 'error' while waiting. The Promise will resolve with an array of all the arguments emitted to the given event.

      This method is intentionally generic and works with the web platform EventTarget interface, which has no special'error' event semantics and does not listen to the 'error' event.

      import { once, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      process.nextTick(() => {
      ee.emit('myevent', 42);
      });

      const [value] = await once(ee, 'myevent');
      console.log(value);

      const err = new Error('kaboom');
      process.nextTick(() => {
      ee.emit('error', err);
      });

      try {
      await once(ee, 'myevent');
      } catch (err) {
      console.error('error happened', err);
      }

      The special handling of the 'error' event is only used when events.once() is used to wait for another event. If events.once() is used to wait for the 'error' event itself, then it is treated as any other kind of event without special handling:

      import { EventEmitter, once } from 'node:events';

      const ee = new EventEmitter();

      once(ee, 'error')
      .then(([err]) => console.log('ok', err.message))
      .catch((err) => console.error('error', err.message));

      ee.emit('error', new Error('boom'));

      // Prints: ok boom

      An AbortSignal can be used to cancel waiting for the event:

      import { EventEmitter, once } from 'node:events';

      const ee = new EventEmitter();
      const ac = new AbortController();

      async function foo(emitter, event, signal) {
      try {
      await once(emitter, event, { signal });
      console.log('event emitted!');
      } catch (error) {
      if (error.name === 'AbortError') {
      console.error('Waiting for the event was canceled!');
      } else {
      console.error('There was an error', error.message);
      }
      }
      }

      foo(ee, 'foo', ac.signal);
      ac.abort(); // Abort waiting for the event
      ee.emit('foo'); // Prints: Waiting for the event was canceled!

      Parameters

      • emitter: EventEmitter
      • eventName: string | symbol
      • Optionaloptions: StaticEventEmitterOptions

      Returns Promise<any[]>

      v11.13.0, v10.16.0

    • Creates a Promise that is fulfilled when the EventEmitter emits the given event or that is rejected if the EventEmitter emits 'error' while waiting. The Promise will resolve with an array of all the arguments emitted to the given event.

      This method is intentionally generic and works with the web platform EventTarget interface, which has no special'error' event semantics and does not listen to the 'error' event.

      import { once, EventEmitter } from 'node:events';
      import process from 'node:process';

      const ee = new EventEmitter();

      process.nextTick(() => {
      ee.emit('myevent', 42);
      });

      const [value] = await once(ee, 'myevent');
      console.log(value);

      const err = new Error('kaboom');
      process.nextTick(() => {
      ee.emit('error', err);
      });

      try {
      await once(ee, 'myevent');
      } catch (err) {
      console.error('error happened', err);
      }

      The special handling of the 'error' event is only used when events.once() is used to wait for another event. If events.once() is used to wait for the 'error' event itself, then it is treated as any other kind of event without special handling:

      import { EventEmitter, once } from 'node:events';

      const ee = new EventEmitter();

      once(ee, 'error')
      .then(([err]) => console.log('ok', err.message))
      .catch((err) => console.error('error', err.message));

      ee.emit('error', new Error('boom'));

      // Prints: ok boom

      An AbortSignal can be used to cancel waiting for the event:

      import { EventEmitter, once } from 'node:events';

      const ee = new EventEmitter();
      const ac = new AbortController();

      async function foo(emitter, event, signal) {
      try {
      await once(emitter, event, { signal });
      console.log('event emitted!');
      } catch (error) {
      if (error.name === 'AbortError') {
      console.error('Waiting for the event was canceled!');
      } else {
      console.error('There was an error', error.message);
      }
      }
      }

      foo(ee, 'foo', ac.signal);
      ac.abort(); // Abort waiting for the event
      ee.emit('foo'); // Prints: Waiting for the event was canceled!

      Parameters

      • emitter: EventTarget
      • eventName: string
      • Optionaloptions: StaticEventEmitterOptions

      Returns Promise<any[]>

      v11.13.0, v10.16.0

    • import { setMaxListeners, EventEmitter } from 'node:events';

      const target = new EventTarget();
      const emitter = new EventEmitter();

      setMaxListeners(5, target, emitter);

      Parameters

      • Optionaln: number

        A non-negative number. The maximum number of listeners per EventTarget event.

      • ...eventTargets: (EventEmitter<DefaultEventMap> | EventTarget)[]

        Zero or more {EventTarget} or {EventEmitter} instances. If none are specified, n is set as the default max for all newly created {EventTarget} and {EventEmitter} objects.

      Returns void

      v15.4.0

    MMNEPVFCICPMFPCPTTAAATR