Skip to main content

A wrapper for the foxhole API

Project description

FoxAPI Documentation

If you use the PyPi version, you might need to download manually the Images folder in the github and pass it as an argument like fox = FoxAPI(image_dir="Images")

Installation

pip install foxapi

FoxAPI is a wrapper for the Official Foxhole API. It provides methods to interact with various endpoints related to maps, war data, dynamic/static map states, and more. The client supports data caching and etags natively to avoid overloading the Foxhole servers.

If you are new to the developer world (or lazy like me), it's the perfect tool!

Also, if you work with discord.py or any asynchronous API, this tool might be useful as well since it support async methods natively as well as synchronous

Table of Contents

Dependencies

pip install pillow requests

Wrapper

class FoxAPI(image_dir: str = None, safe_mode: bool = True)

Methods

API Interaction (async)

Note : all of theses methods are async, to run the synchronous version, add _sync at the end (see API example)

  • get_data(endpoint: str, etag: str = None, cache: bool = False) -> requests.Response
    Fetches data from the specified endpoint with optional caching and ETag support.

    • Parameters:

      • endpoint (str): The API endpoint to call.
      • etag (str, optional): The ETag header for cache validation (not required since managed natively).
      • cache (bool, optional): Whether to use cached data (default: False).
    • Returns: The response data from the API as a requests.Response object.

Map and War Data

  • get_maps(cache: bool = True) -> list
    Retrieves a list of available hexagons (maps) in the game world.

  • get_war(cache: bool = False) -> dict
    Retrieves the current war state (war data).

  • get_static(hexagon: str, cache: bool = False) -> dict
    Retrieves the static data for the specified hexagon.

  • get_dynamic(hexagon: str, cache: bool = False) -> dict
    Retrieves the dynamic data for the specified hexagon.

  • get_war_report(hexagon: str, cache: bool = False) -> dict
    Retrieves the war report for the specified hexagon.

  • get_hexagon_data(hexagon: str, cache: bool = False) -> HexagonObject Retrieves all the data awailable for the specified hexagon.

Hexagon Operations

  • await calc_distance(x1: float, y1: float, x2: float, y2: float) -> float
    Calculates the Euclidean distance between two points on the map.

  • await get_captured_towns(hexagon: str = None, dynamic: dict = None, static: dict = None) -> dict Retrieves the captured towns for a given hexagon based on dynamic and static data.

  • load_hexagon_map(hexagon: str) -> pillow.Image
    Loads the PNG map for the specified hexagon.

  • make_map_png(hexagon: str, dynamic: dict = None, static: dict = None) -> pillow.Image Generates a PNG image of the hexagon map with all the icons associated to each faction in their respective colors (included fields and town base). Only public data will be present.

  • calculate_death_rate(hexagon: str = None, war_report: dict = None): -> dict
    calculate the death rate between the first launch and the current one

Listener Functions

  • on_api_update(callback: callable = None, endpoints: list = None)
    Registers a callback function to be called when the data for specified API endpoints is updated.

  • on_hexagon_update(callback: callable = None, hexagons: list = None)
    Registers a callback function to be called when the data for specified hexagons is updated.

Error Handling

  • EndpointError: Raised if an invalid API endpoint is used.
  • HexagonError: Raised if an invalid hexagon is provided.
  • FoxAPIError: A general error for issues within the FoxAPI class (e.g., missing data).

Objects

class APIResponse:
    def __init__(self, headers: dict, json: dict, status_code: int, hexagon: str, is_cache: bool):
        self.headers: dict = headers
        self.json: dict = json
        self.status_code: int = status_code
        self.hexagon: str = hexagon
        self.is_cache: bool = is_cache


class HexagonObject:
    def __init__(self, hexagon: str, war_report: dict, static: dict, dynamic: dict, captured_towns: dict, casualty_rate: dict, image: pillow.Image):
        self.hexagon: str = hexagon
        self.war_report: dict = war_report
        self.static: dict = static
        self.dynamic: dict = dynamic
        self.captured_towns: dict = captured_towns
        self.casualty_rate: dict = casualty_rate
        self.image: pillow.Image = image

Example Usage

from foxapi import FoxAPI

# Initialize the API client in safe mode

# if you are a developer and plane to use the exact hexagons name
# you can turn the safe_mode off, otherwise it will convert
# api calls and hexagons name into valid ones
# Ex: deadlands -> DeadLandsHex (Yes, I am *that* lazy)

fox = FoxAPI()

hexagon: str = "DeadLandsHex"

def retrieve():
    # Get the list of available hexagons (maps) and state of the current war
    maps: list = fox.get_maps_sync()
    war: dict = fox.get_war_sync()

    # Retrieve data for a specific hexagon
    dynamic_data: dict = fox.get_dynamic_sync(hexagon)
    static_data: dict = fox.get_static_sync(hexagon)
    war_report: dict = fox.get_war_report_sync(hexagon)

    # Create a map PNG for a hexagon with building informations on it
    map_image = fox.make_map_png_sync(hexagon)
    map_image.show()

    # to get all the data at once

    data: HexagonObject = fox.get_hexagon_data_sync(hexagon=hexagon, use_cache=True)

# Async equivalent

async def retrieve():
    # Get the list of available hexagons (maps) and state of the current war
    maps: list = await fox.get_maps()
    war: dict = await fox.get_war()

    # Retrieve data for a specific hexagon
    dynamic_data: dict = await fox.get_dynamic(hexagon)
    static_data: dict = await fox.get_static(hexagon)
    war_report: dict = await fox.get_war_report(hexagon)

    # Create a map PNG for a hexagon with building informations on it
    map_image = await fox.make_map_png(hexagon)
    map_image.show()

    # to get all the data at once

    data: HexagonObject = await fox.get_hexagon_data(hexagon=hexagon, use_cache=True)


# Register a callback to listen for updates on all the hexagons
# it will run forever don't worry

@on_hexagon_update("all")
def on_update(hexa: HexagonObject):
    print(f"Hexagon {hexa.hexagon} has been updated")
    hexa.image.save(f"{hexa.hexagon}.png")


# The following async code works as well

@on_hexagon_update("all")
async def on_update(hexa: HexagonObject):
    print(f"Hexagon {hexa.hexagon} has been updated")
    hexa.image.save(f"{hexa.hexagon}.png")

(Yes, most of this documentation has been generated with ChatGPT, I am alone and too lazy to do that)

I am not responsible for what you are doing with it

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

foxapi-1.0.6.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

foxapi-1.0.6-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file foxapi-1.0.6.tar.gz.

File metadata

  • Download URL: foxapi-1.0.6.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for foxapi-1.0.6.tar.gz
Algorithm Hash digest
SHA256 47d33101ed1150ddaad4a386b27a474d646ea353ef76f50ef2e0ffb8d4faea35
MD5 503b07c8073fcac489d80a87075cb54a
BLAKE2b-256 68b18390df6859ba76fd33f33522e085dc233a469a48c2b2635c28ed3c15a65a

See more details on using hashes here.

File details

Details for the file foxapi-1.0.6-py3-none-any.whl.

File metadata

  • Download URL: foxapi-1.0.6-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.11

File hashes

Hashes for foxapi-1.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 284562256a0914a137f2309a96a35620dd87f5bba17d27deb3aaec11bca7b120
MD5 3b6d2b9dbcac0a4854d3fc6909bc51b6
BLAKE2b-256 e096378f8e6fe1ee85ac6d70c16ec814ef482bf5efd66db08de1a123a04f48ea

See more details on using hashes here.

Supported by

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