Skip to main content

Tesla-API SDK

Project description

Getting Started with Tesla Fleet Management API

Introduction

Unofficial OpenAPI specification for Tesla Fleet Management Charging endpoints.

Install the Package

The package is compatible with Python versions 3.7+. Install the package from PyPi using the following pip command:

pip install tesla-api-sdk==1.0.2

You can also view the package at: https://pypi.python.org/pypi/tesla-api-sdk/1.0.2

Initialize the API Client

Note: Documentation for the client can be found here.

The following parameters are configurable for the API Client:

Parameter Type Description
environment Environment The API environment.
Default: Environment.PRODUCTION
http_client_instance Union[Session, HttpClientProvider] The Http Client passed from the sdk user for making requests
override_http_client_configuration bool The value which determines to override properties of the passed Http Client from the sdk user
http_call_back HttpCallBack The callback value that is invoked before and after an HTTP call is made to an endpoint
timeout float The value to use for connection timeout.
Default: 60
max_retries int The number of times to retry an endpoint call if it fails.
Default: 0
backoff_factor float A backoff factor to apply between attempts after the second try.
Default: 2
retry_statuses Array of int The http statuses on which retry is to be done.
Default: [408, 413, 429, 500, 502, 503, 504, 521, 522, 524]
retry_methods Array of string The http methods on which retry is to be done.
Default: ["GET", "PUT"]
proxy_settings ProxySettings Optional proxy configuration to route HTTP requests through a proxy server.
logging_configuration LoggingConfiguration The SDK logging configuration for API calls
bearer_auth_credentials BearerAuthCredentials The credential object for OAuth 2 Bearer token
thirdpartytoken_credentials ThirdpartytokenCredentials The credential object for OAuth 2 Authorization Code Grant

The API client can be initialized as follows:

Code-Based Client Initialization

import logging

from teslafleetmanagementapi.configuration import Environment
from teslafleetmanagementapi.http.auth.bearer_auth import BearerAuthCredentials
from teslafleetmanagementapi.http.auth.thirdpartytoken import ThirdpartytokenCredentials
from teslafleetmanagementapi.logging.configuration.api_logging_configuration import LoggingConfiguration
from teslafleetmanagementapi.logging.configuration.api_logging_configuration import RequestLoggingConfiguration
from teslafleetmanagementapi.logging.configuration.api_logging_configuration import ResponseLoggingConfiguration
from teslafleetmanagementapi.models.o_auth_scope_thirdpartytoken import OAuthScopeThirdpartytoken
from teslafleetmanagementapi.teslafleetmanagementapi_client import TeslafleetmanagementapiClient

client = TeslafleetmanagementapiClient(
    bearer_auth_credentials=BearerAuthCredentials(
        access_token='AccessToken'
    ),
    thirdpartytoken_credentials=ThirdpartytokenCredentials(
        o_auth_client_id='OAuthClientId',
        o_auth_client_secret='OAuthClientSecret',
        o_auth_redirect_uri='OAuthRedirectUri',
        o_auth_scopes=[
            OAuthScopeThirdpartytoken.OPENID,
            OAuthScopeThirdpartytoken.OFFLINE_ACCESS
        ]
    ),
    environment=Environment.PRODUCTION,
    logging_configuration=LoggingConfiguration(
        log_level=logging.INFO,
        request_logging_config=RequestLoggingConfiguration(
            log_body=True
        ),
        response_logging_config=ResponseLoggingConfiguration(
            log_headers=True
        )
    )
)

Environment-Based Client Initialization

from teslafleetmanagementapi.teslafleetmanagementapi_client import TeslafleetmanagementapiClient

# Specify the path to your .env file if it’s located outside the project’s root directory.
client = TeslafleetmanagementapiClient.from_environment(dotenv_path='/path/to/.env')

See the Environment-Based Client Initialization section for details.

Authorization

This API uses the following authentication schemes.

List of APIs

SDK Infrastructure

Configuration

HTTP

Utilities

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

tesla_api_sdk-1.0.2.tar.gz (55.7 kB view details)

Uploaded Source

Built Distribution

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

tesla_api_sdk-1.0.2-py3-none-any.whl (164.5 kB view details)

Uploaded Python 3

File details

Details for the file tesla_api_sdk-1.0.2.tar.gz.

File metadata

  • Download URL: tesla_api_sdk-1.0.2.tar.gz
  • Upload date:
  • Size: 55.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.13

File hashes

Hashes for tesla_api_sdk-1.0.2.tar.gz
Algorithm Hash digest
SHA256 a6c49f9a31c23bcdb129ca35927ac19d750b1ac7e2a69ca986045dba4186fd17
MD5 31fc729317b66e8574f2fddc1a49e3f5
BLAKE2b-256 1f966a7ba74c5362500d66a3a0df6250cb3e8937cc406440649a87d1e266ade1

See more details on using hashes here.

File details

Details for the file tesla_api_sdk-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: tesla_api_sdk-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 164.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.9.13

File hashes

Hashes for tesla_api_sdk-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 35435d93aba42234e3aeff0bc08ec42c31e9b5b32450649c3d34e7393e4d10bc
MD5 658a99c8ff31c43d912cacccb24c34ca
BLAKE2b-256 6050bd64e7fcecde185ef0f80e1efc02d43cfad7a22d9e37f0b10850423eba05

See more details on using hashes here.

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