A wrapper for the foxhole API
Project description
FoxAPI Documentation
Join our discord : https://discord.gg/XJJkuDYZXw
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
- FoxAPI Documentation
Dependencies
pip install pillow requests aiohttp
Wrapper
class FoxAPI(shard: str = "", 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, use_cache: bool = False) -> APIResponse
Fetches data from the specified endpoint, you can choose to use cache instead of sending a request and you can pass ETag.
-
Parameters:
endpoint(str): The API endpoint to call.etag(str, optional): The ETag header for cache validation (not required since managed natively).use_cache(bool, optional): Whether to use cached data (default: False).
-
Returns: The response data from the API as a APIResponse object.
Map and War Data
get_maps(use_cache: bool = True, session: aiohttp.ClientSession | None = None) -> list
- Retrieves a list of available hexagons (maps) in the game world.
get_war(use_cache: bool = False, session: aiohttp.ClientSession | None = None) -> dict
- Retrieves the current war state (war data).
get_static(hexagon: str, use_cache: bool = False, session: aiohttp.ClientSession | None = None) -> dict
- Retrieves the static data for the specified hexagon.
get_dynamic(hexagon: str, use_cache: bool = False, session: aiohttp.ClientSession | None = None) -> dict
- Retrieves the dynamic data for the specified hexagon.
get_war_report(hexagon: str, use_cache: bool = False, session: aiohttp.ClientSession | None = None) -> dict
- Retrieves the war report for the specified hexagon.
get_hexagon_data(hexagon: str, use_cache: bool = False, session: aiohttp.ClientSession | None = None) -> HexagonObject
- Retrieves all the data awailable for the specified hexagon.
Hexagon Operations
calc_distance(x1: float, y1: float, x2: float, y2: float) -> float
- Calculates the Euclidean distance between two points on the map.
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, icons: str | list = "all", colored: bool = False, 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.
- colored -> display each region in the team's color
- icons -> display selected building in their team's color
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 = "all")
- Registers a callback function to be called when the data for specified hexagons is updated.
Queue Tasks
This library also give the possibility to queue up some sync and async methods to run them simultaneously
from foxapi import FoxAPI
api = FoxAPI()
for i in range(10):
api.add_task(function=api.get_war) # or any other method
data = api.run_task_sync()
for elem in data:
print(elem.result)
from foxapi import FoxAPI
import asyncio
api = FoxAPI()
async def main():
for i in range(10):
api.add_task(function=api.get_war) # or any other method
data = await api.run_task()
for elem in data:
print(elem.result)
asyncio.run(main())
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 Task:
def __init__(self, function: callable, args: any = "no_args", result: any = None):
self.function: callable = function
self.args: any = args
self.result: any = result
class APIResponse:
def __init__(self, headers: dict, json: dict, status_code: int, hexagon: str, is_use_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):
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
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(shard="1")
def function(hexagon: str = "DeadLandsHex"):
# 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 function(hexagon: str = "DeadLandsHex"):
# 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
@fox.on_hexagon_update("all")
def on_update(hexa: HexagonObject):
print(f"Hexagon {hexa.hexagon} has been updated")
# The following async code works as well
@fox.on_hexagon_update("all")
async def on_update(hexa: HexagonObject):
print(f"Hexagon {hexa.hexagon} has been updated")
I am not responsible for what you are doing with it
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file foxapi-1.8.0.tar.gz.
File metadata
- Download URL: foxapi-1.8.0.tar.gz
- Upload date:
- Size: 14.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d44e07fae4432748f72704ad0ee59eeb5ae61f6489270633273fa164bb601460
|
|
| MD5 |
a5f91af156f883dc9c76d465c0e1eab6
|
|
| BLAKE2b-256 |
cb15465ddc26b4db655f52fd4b5dcb61b85478442ec95b2558f90cd645394ecd
|
File details
Details for the file foxapi-1.8.0-py3-none-any.whl.
File metadata
- Download URL: foxapi-1.8.0-py3-none-any.whl
- Upload date:
- Size: 14.8 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb3a94ce3c5e09ddc6170683ffe0ce6642d1aa8c99a14f159bf390c7d39b8b74
|
|
| MD5 |
eadaddd190f0e9e7ddebfb65ce8ec5b1
|
|
| BLAKE2b-256 |
01d3a738fc815467d4cf5471a38ae6aa30e5bd623cbbd4c8d41b7e0cfe2320df
|