Skip to main content

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.

release python openapi ESI pipeline status license chat

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:

  1. As configuration for the api client
  2. 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


Download files

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

Source Distribution

esi_client-0.1.0a2.tar.gz (349.6 kB view hashes)

Uploaded Source

Built Distribution

esi_client-0.1.0a2-py3-none-any.whl (1.6 MB view hashes)

Uploaded Python 3

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