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.1

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

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
oauth_2_credentials Oauth2Credentials 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.oauth_2 import Oauth2Credentials
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_oauth_2 import OAuthScopeOauth2
from teslafleetmanagementapi.teslafleetmanagementapi_client import TeslafleetmanagementapiClient

client = TeslafleetmanagementapiClient(
    bearer_auth_credentials=BearerAuthCredentials(
        access_token='AccessToken'
    ),
    oauth_2_credentials=Oauth2Credentials(
        o_auth_client_id='OAuthClientId',
        o_auth_client_secret='OAuthClientSecret',
        o_auth_redirect_uri='OAuthRedirectUri',
        o_auth_scopes=[
            OAuthScopeOauth2.OPENID,
            OAuthScopeOauth2.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.1.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.1-py3-none-any.whl (164.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tesla_api_sdk-1.0.1.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.1.tar.gz
Algorithm Hash digest
SHA256 562292f880de18ffce8ccae49951961cdd1a92eaa3e8868ff70a2d6f5c3028d0
MD5 e83bf6241c687eff8c1f5a165a6ade20
BLAKE2b-256 c9480afc6882d18e4dbee1e12c118bef082474eaa1416905630e871a3bcc7ac4

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tesla_api_sdk-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 164.3 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8bc8ab93826fb7554d12bba92d9d4228edf5f146da20d17b147ccdaa2e6690fc
MD5 c030b409ccfba63038b49a0e4c6d5db5
BLAKE2b-256 cfda39edcba626281860af19f09b39f653e118e8ed3931e9d4c65a62459d4466

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