The Informly Python library provides convenient access to the Informly APIs from Python.
API reference documentation is available here.
pip install informlyInstantiate and use the client with the following:
from informly import Informly
client = Informly(
token="<token>",
)
client.contacts.create_contact()This SDK allows you to configure different environments for API requests.
from informly import Informly
from informly.environment import InformlyEnvironment
client = Informly(
environment=InformlyEnvironment.DEFAULT,
)The SDK also exports an async client so that you can make non-blocking calls to our API. Note that if you are constructing an Async httpx client class to pass into this client, use httpx.AsyncClient() instead of httpx.Client() (e.g. for the httpx_client parameter of this client).
import asyncio
from informly import AsyncInformly
client = AsyncInformly(
token="<token>",
)
async def main() -> None:
await client.contacts.create_contact()
asyncio.run(main())When the API returns a non-success status code (4xx or 5xx response), a subclass of the following error will be thrown.
from informly.core.api_error import ApiError
try:
client.contacts.create_contact(...)
except ApiError as e:
print(e.status_code)
print(e.body)The SDK provides access to raw response data, including headers, through the .with_raw_response property.
The .with_raw_response property returns a "raw" client that can be used to access the .headers and .data attributes.
from informly import Informly
client = Informly(...)
response = client.contacts.with_raw_response.create_contact(...)
print(response.headers) # access the response headers
print(response.status_code) # access the response status code
print(response.data) # access the underlying objectThe SDK is instrumented with automatic retries with exponential backoff. A request will be retried as long as the request is deemed retryable and the number of retry attempts has not grown larger than the configured retry limit (default: 2).
A request is deemed retryable when any of the following HTTP status codes is returned:
Use the max_retries request option to configure this behavior.
client.contacts.create_contact(..., request_options={
"max_retries": 1
})The SDK defaults to a 60 second timeout. You can configure this with a timeout option at the client or request level.
from informly import Informly
client = Informly(..., timeout=20.0)
# Override timeout for a specific method
client.contacts.create_contact(..., request_options={
"timeout_in_seconds": 1
})You can override the httpx client to customize it for your use-case. Some common use-cases include support for proxies
and transports.
import httpx
from informly import Informly
client = Informly(
...,
httpx_client=httpx.Client(
proxy="http://my.test.proxy.example.com",
transport=httpx.HTTPTransport(local_address="0.0.0.0"),
),
)