A Python client for accessing the complete Eve Online ESI API.
Project description
esi-client
A Python client for accessing the complete Eve Online ESI API.
Contents
Overview
This package is a library that provides a Python client for accessing the public 3rd party API of EVE Online, which is more commonly known as "ESI" (EVE Swagger Interface).
The client is automatically generated from ESI's specification with the Open API generator.
This approach offers many benefits in comparison to other ESI libraries:
- Complete and correct coverage of all endpoints
- Automatic serialization and mapping to Python data types
- Python classes for all data models
- Type annotations, i.e. enabling auto complete for API methods
- No delay at startup for building the client
- Robust and proven API client
- Fast turnaround on API updates
Installation
You can install the current this library directly from PyPI:
pip install esi-client
Usage
In this chapter we are showing how to get information from ESI with the open API client.
Accessing public endpoints
The esi client from openAPI is easy to use. Here is a minimal example for fetching a character from the public endpoint:
from esi_client.api.character_api import CharacterApi
api = CharacterApi()
character = api.get_characters_character_id(character_id=93330670)
print(character.name)
Error handling
Common errors can be handled by catching ApiException
:
import esi_client
from esi_client.api.character_api import CharacterApi
api = CharacterApi()
try:
character = api.get_characters_character_id(character_id=93330670)
print(character.name)
except esi_client.ApiException as ex:
print(f"Exception occurred when trying to fetch a character: {ex}")
Making multiple calls to endpoints
When making multiple calls to endpoints it is more efficient to use the same API client instance. Here we are first calling the character endpoint to get information about a character and then we are calling the corporation endpoint to get the name of the corporation the character belongs to.
import esi_client
from esi_client.api.character_api import CharacterApi
from esi_client.api.corporation_api import CorporationApi
with esi_client.ApiClient() as api_client:
character_api = CharacterApi(api_client)
character = character_api.get_characters_character_id(character_id=93330670)
corporation_api = CorporationApi(api_client)
corporation = corporation_api.get_corporations_corporation_id(
corporation_id=character.corporation_id
)
print(f"{character.name} if a member of {corporation.name}")
Accessing private endpoints
For accessing private endpoint you need a valid access token.
Note that to topic of obtaining an access token is not in scope of this library. Please see the SSO documentation for more information on how to obtain an access token for your web site or app. For testing purposes it is possible to generate an access token on the ESI web site.
You can provide your access token in two ways:
- As configuration for the api client
- As parameter when calling an endpoint
Token as configuration
One way for providing your access token is as configuration for the api client:
import esi_client
from esi_client.api.character_api import CharacterApi
configuration = esi_client.Configuration(access_token="ACCESS-TOKEN")
with esi_client.ApiClient(configuration) as api_client:
api_instance = CharacterApi(api_client)
api_response = api_instance.get_characters_character_id_medals(
character_id=93330670
)
...
Token as parameter
Another way of providing your access token is as parameter when making the call to the endpoint:
from esi_client.api.character_api import CharacterApi
api_instance = CharacterApi(api_client)
api_response = api_instance.get_characters_character_id_medals(
character_id=93330670, token="ACCESS-TOKEN"
)
Getting HTTP information for a response
In some cases you also need to get the HTTP information for a response. e.g. if a endpoint supports paging the information about how many pages there are is in the HTTP header.
To get the HTTP information you need to pass the argument _return_http_data_only=False
when calling the API method. The API method will then return a tuple consisting of:
- data
- HTTP status code
- HTTP response headers
Here is an example:
from esi_client.api.universe_api import UniverseApi
api = UniverseApi()
data, status_code, header = api.get_universe_types(_return_http_data_only=False)
The source code for these examples can also be found in project's examples
folder.
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
File details
Details for the file esi_client-0.1.0a2.tar.gz
.
File metadata
- Download URL: esi_client-0.1.0a2.tar.gz
- Upload date:
- Size: 349.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6b912efbca390ad4d5ddbfdb1ca8c54cc7f738e62fdbcc9b0546c64a7cb75712 |
|
MD5 | 9ff2eaac9b312b2ec27c84703817e6ed |
|
BLAKE2b-256 | f7e890a3351b51bda622f1af5f2ae893a2d0f6c6f9caf1adf052c6fe58f2c619 |
File details
Details for the file esi_client-0.1.0a2-py3-none-any.whl
.
File metadata
- Download URL: esi_client-0.1.0a2-py3-none-any.whl
- Upload date:
- Size: 1.6 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.10.11
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 368eff95ad20c1bf7e31546cca830bb10e04b001d2c74366225030fbe6f79e4d |
|
MD5 | 99b70fa67a2752478ed6f5f486a0ff2a |
|
BLAKE2b-256 | d63ef1586a1e5b8cc84da6d3cabc024261c65bc06a25a4be2908edc9a9753df3 |