Skip to main content

Asynchronous implementation of the Hell Let Loose RCON protocol

Project description

hllrcon - Hell Let Loose RCON

Release PyPI Branch Coverage License GitHub contributors GitHub issues GitHub pull requests GitHub stars


hllrcon is an asynchronous Python implementation of the Hell Let Loose RCON protocol.
It allows you to interact with your HLL servers programmatically, supporting modern Python async features and robust error handling.

Features

  • Full async/await support
  • Command execution and response parsing
  • Collection of vanilla maps, factions, weapons, and more
  • Alternative interfaces for synchronous applications
  • Well-typed and tested

Installation

pip install hllrcon

Usage

import asyncio
from hllrcon import Rcon, Layer


async def main():
    # Initialize client
    rcon = Rcon(
        host="127.0.0.1",
        port=12345,
        password="your_rcon_password",
    )

    # Send commands. The client will (re)connect for you.
    await rcon.broadcast("Hello, HLL!")
    await rcon.change_map(Layer.STALINGRAD_WARFARE_DAY)
    players = await rcon.get_players()

    # Close the connection
    rcon.disconnect()


    # Alternatively, use the context manager interface to avoid
    # having to manually disconnect.
    async with rcon.connect():
        assert rcon.is_connected() is True
        await rcon.broadcast("Hello, HLL!")


if __name__ == "__main__":
    # Run the program
    asyncio.run(main())

For integration of synchronous applications, a SyncRcon class is provided.

from hllrcon.sync import SyncRcon

rcon = SyncRcon(
    host="127.0.0.1",
    port=12345,
    password="your_rcon_password",
)

# Connect and send a broadcast message
with rcon.connect():
    rcon.broadcast("Hello, HLL!")

The library contains a swathe of details about in-game maps, factions, weapons, vehicles, and more. Below is just an example of what it might be used for.

from hllron import Weapon

# Find a weapon by its ID
weapon_id = "COAXIAL M1919 [Stuart M5A1]"
weapon = Weapon.by_id(weapon_id)

# Print out whichever vehicle seat the attacker must have been in, if any
if weapon.vehicle:
    for seat in weapon.vehicle.seats:
        if weapon in seat.weapons:
            print("This weapon belongs to the", seat.type.name, "seat")
            break
from hllrcon import Rcon, Map, Team

# Get the AA Network capture zone (SMDM, 3rd sector, 2nd capture zone)
sector = Layer.STMARIEDUMONT_WARFARE_DAY.sectors[2]
capture_zone = sector.capture_zones[1]
assert capture_zone.strongpoint.name == "AA Network"

# Get the current online players
rcon = Rcon(...)
players = await rcon.get_players()

# Calculate each team's capture strength towards the sector
strength = {Team.ALLIES: 0, Team.AXIS: 0}
for player in players.players:
    if player.faction is None:
        continue

    if player.world_position == (0.0, 0.0, 0.0):
        # Player is dead. Note: Does not exclude players bleeding out
        continue

    # Grant 3 strength if inside the strongpoint
    if capture_zone.strongpoint.is_inside(player.world_position):
        strength[player.faction.team] += 3

    # Only grant 1 strength if inside the capture zone
    elif capture_zone.is_inside(player.world_position):
        strength[player.faction.team] += 1

# Print out the results
print("Allied cap weight:", strength[Team.ALLIES])
print("Axis cap weight:", strength[Team.AXIS])

Versioning

Hell Let Loose (referred to as "the game") is a constantly evolving game, and game updates might alter its RCON interfaces in ways that are not backward-compatible. This affects any tools and libraries that depend on it, including this library and any software utilizing it.

Releases of hllrcon only guarantee compatibility with the latest version of the game at the time of release. See the release notes of a given version for more information on what version this is.

This project uses its own versioning system similar to Pragmatic Versioning principles (i.e. GRADE.MAJOR.MINOR.PATCH). However, there are differences in the way each of the four components are defined and what they guarantee:

  • GRADE - Reserved for structural changes. Likely to increase only with the release of Hell Let Loose: Vietnam.
  • MAJOR - Incremented when backward-incompatible changes are released.
  • MINOR - Incremented when support for the previously supported game version is dropped.
  • PATCH - Incremented when backward-compatible changes are released.

When specifying hllrcon as a dependency, it is recommended to pin the MINOR version but not the PATCH version. MINOR versions are still backwards-incompatible in that they require the game server to be updated. MINOR versions may depend on upcoming, unreleased game version.

License

This project is licensed under the MIT License. See LICENSE for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

hllrcon-1.2.0.0b1100372.post0.tar.gz (154.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

hllrcon-1.2.0.0b1100372.post0-py3-none-any.whl (83.3 kB view details)

Uploaded Python 3

File details

Details for the file hllrcon-1.2.0.0b1100372.post0.tar.gz.

File metadata

  • Download URL: hllrcon-1.2.0.0b1100372.post0.tar.gz
  • Upload date:
  • Size: 154.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for hllrcon-1.2.0.0b1100372.post0.tar.gz
Algorithm Hash digest
SHA256 bacddd0bdfcb5efa72b46b8900781f407489e6e777c549aaa4001edae925a104
MD5 c6e6ad4a40474dab26dcca82f9c92379
BLAKE2b-256 463b64c25a33e52d4b8da2c03c1b9d0de07fdaad736e84ce009cd62fa67061c1

See more details on using hashes here.

Provenance

The following attestation bundles were made for hllrcon-1.2.0.0b1100372.post0.tar.gz:

Publisher: python-publish.yaml on timraay/hllrcon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file hllrcon-1.2.0.0b1100372.post0-py3-none-any.whl.

File metadata

File hashes

Hashes for hllrcon-1.2.0.0b1100372.post0-py3-none-any.whl
Algorithm Hash digest
SHA256 5e21022adf44a1fab8d4ff86695ffcc2139bf13fc33ef41468e3e2baa7ff24ba
MD5 b80f099b390b3cee07b059114d40c2e5
BLAKE2b-256 1625bcde596171eb75f3cbf3a59fb697f7d4cefd1f84c4ceaf9e2b9c240701ce

See more details on using hashes here.

Provenance

The following attestation bundles were made for hllrcon-1.2.0.0b1100372.post0-py3-none-any.whl:

Publisher: python-publish.yaml on timraay/hllrcon

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page