Autodesk Platform: ACC (Autodesk Construction Cloud) SDK for Python
Project description
autodesk-acc - Autodesk Construction Cloud SDK for Python
A Python SDK providing a Fluent API for the Autodesk Construction Cloud (ACC) APIs, generated from the official OpenAPI specifications using Microsoft Kiota.
Installation
pip install adsk-platform-acc
Quick Start
from autodesk_acc import ACCClient
# Provide an async function that returns the access token
async def get_access_token() -> str:
return "YOUR_ACCESS_TOKEN"
# Initialize the ACC client
acc_client = ACCClient(get_access_token)
Using with 2-Legged Authentication
For server-to-server communication using client credentials (2-legged OAuth):
import httpx
from autodesk_acc import ACCClient
# Your APS app credentials (load from environment variables)
import os
client_id = os.environ["APS_CLIENT_ID"]
client_secret = os.environ["APS_CLIENT_SECRET"]
# Simple token cache
_token_cache: dict[str, str] = {}
async def get_access_token() -> str:
if "token" not in _token_cache:
async with httpx.AsyncClient() as client:
response = await client.post(
"https://developer.api.autodesk.com/authentication/v2/token",
data={
"grant_type": "client_credentials",
"client_id": client_id,
"client_secret": client_secret,
"scope": "data:read data:write account:read",
},
)
response.raise_for_status()
_token_cache["token"] = response.json()["access_token"]
return _token_cache["token"]
# Initialize the ACC client with token provider
acc_client = ACCClient(get_access_token)
Usage Examples
Get Issues
# Get issues for a project
issues = await acc_client.issues.projects[project_id].issues.get()
for issue in issues.results or []:
print(f"Issue: {issue.title} - Status: {issue.status}")
Get Clash Results
# Get clash test results
clash_tests = await acc_client.clash.containers[container_id].clash.tests.get()
Get Project Files
# Get files in a folder
files = await acc_client.files.projects[project_id].folders[folder_id].contents.get()
Get RFIs
# Get RFIs for a project
rfis = await acc_client.rfis.projects[project_id].rfis.get()
Using the .api Property
All endpoints are available through the acc_client.api property, which mirrors the full URL path. You can always use .api instead of (or in addition to) the shortcut properties:
# These two calls are exactly equivalent:
issues = await acc_client.issues.projects[project_id].issues.get() # shortcut
issues = await acc_client.api.construction.issues.v1.projects[project_id].issues.get() # full path via .api
Custom HTTP Client
You can provide your own httpx.AsyncClient instance for advanced scenarios:
import httpx
http_client = httpx.AsyncClient(timeout=60.0)
# Configure your client...
acc_client = ACCClient(get_access_token, http_client=http_client)
Rate Limiting
The SDK handles API rate limits automatically thanks to the built-in retry handler provided by the Kiota HTTP client. When the API returns a 429 Too Many Requests response, the SDK will:
- Automatically retry the request with exponential backoff
- Respect the
Retry-Afterheader returned by the API - Retry up to a configurable number of times before failing
This means you don't need to implement custom retry logic in your application — the SDK handles transient failures and rate limiting transparently.
Error Handling
The SDK uses Kiota's built-in error handling. API errors are raised as exceptions that you can catch:
from kiota_abstractions.api_error import APIError
try:
issues = await acc_client.issues.projects[project_id].issues.get()
except APIError as e:
print(f"Request failed: {e.message}")
print(f"Status code: {e.response_status_code}")
API Structure
This SDK provides access to multiple ACC API endpoints through a unified client. Every endpoint is accessible via the acc_client.api property, which exposes the full generated API tree. For convenience, shortcut properties are also available on the client to skip the common path prefix — but they are entirely optional.
| API | Endpoint Path | Shortcut | Full .api equivalent |
|---|---|---|---|
| Accounts | /hq/v1/accounts/* |
acc_client.accounts |
acc_client.api.hq.v1.accounts |
| Admin | /construction/admin/v1/* |
acc_client.admin |
acc_client.api.construction.admin.v1 |
| Assets | /construction/assets/* |
acc_client.assets |
acc_client.api.construction.assets |
| AutoSpecs | /construction/autospecs/v1/* |
acc_client.auto_specs |
acc_client.api.construction.autospecs.v1 |
| Clash | /bim360/clash/v3/* |
acc_client.clash |
acc_client.api.bim360.clash.v3 |
| Cost | /cost/v1/* |
acc_client.cost |
acc_client.api.cost.v1 |
| Data Connector | /dataconnector/v1/* |
acc_client.data_connector |
acc_client.api.data_connector.v1 |
| Docs | /bim360/docs/v1/* |
acc_client.docs |
acc_client.api.bim360.docs.v1 |
| Files | /construction/files/v1/* |
acc_client.files |
acc_client.api.construction.files.v1 |
| Forms | /construction/forms/v1/* |
acc_client.forms |
acc_client.api.construction.forms.v1 |
| Index | /construction/index/v2/* |
acc_client.index |
acc_client.api.construction.index.v2 |
| Issues | /construction/issues/v1/* |
acc_client.issues |
acc_client.api.construction.issues.v1 |
| Locations | /construction/locations/v2/* |
acc_client.locations |
acc_client.api.construction.locations.v2 |
| ModelSet | /bim360/modelset/v3/* |
acc_client.model_set |
acc_client.api.bim360.modelset.v3 |
| Packages | /construction/packages/v1/* |
acc_client.packages |
acc_client.api.construction.packages.v1 |
| Photos | /construction/photos/v1/* |
acc_client.photos |
acc_client.api.construction.photos.v1 |
| RCM | /construction/rcm/v1/* |
acc_client.rcm |
acc_client.api.construction.rcm.v1 |
| Relationships | /bim360/relationship/v2/* |
acc_client.relationships |
acc_client.api.bim360.relationship.v2 |
| Reviews | /construction/reviews/v1/* |
acc_client.reviews |
acc_client.api.construction.reviews.v1 |
| RFIs | /construction/rfis/v3/* |
acc_client.rfis |
acc_client.api.construction.rfis.v3 |
| Sheets | /construction/sheets/v1/* |
acc_client.sheets |
acc_client.api.construction.sheets.v1 |
| Submittals | /construction/submittals/v2/* |
acc_client.submittals |
acc_client.api.construction.submittals.v2 |
| Takeoff | /construction/takeoff/v1/* |
acc_client.takeoff |
acc_client.api.construction.takeoff.v1 |
| Transmittals | /construction/transmittals/v1/* |
acc_client.transmittals |
acc_client.api.construction.transmittals.v1 |
Note: You never need to use the shortcut properties. They simply save a few keystrokes by resolving the common path prefix for you. The
acc_client.apiproperty gives you access to the complete API surface — including any endpoints that may not have a dedicated shortcut.
Requirements
- Python 3.10 or later
- Valid Autodesk Platform Services (APS) access token with appropriate scopes
Dependencies
microsoft-kiota-abstractionsmicrosoft-kiota-httpmicrosoft-kiota-serialization-jsonmicrosoft-kiota-serialization-textmicrosoft-kiota-serialization-formmicrosoft-kiota-serialization-multiparthttpx
Documentation
License
This project is licensed under the MIT License.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file adsk_platform_acc-0.2.9.tar.gz.
File metadata
- Download URL: adsk_platform_acc-0.2.9.tar.gz
- Upload date:
- Size: 1.1 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8b97fb36b9f229d2dc85f965dab316ccdab4549a0e33934214f8c5620813136a
|
|
| MD5 |
723e9c370c74f195c4e0f276289d65a6
|
|
| BLAKE2b-256 |
8d0a9bbdd190f75d22cb687e53c870c4e1a0ffc00a11ecee6695735bdb235494
|
Provenance
The following attestation bundles were made for adsk_platform_acc-0.2.9.tar.gz:
Publisher:
publishPyPi.yml on adsk-duszykf/Adsk.Platform.Toolkit.Python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
adsk_platform_acc-0.2.9.tar.gz -
Subject digest:
8b97fb36b9f229d2dc85f965dab316ccdab4549a0e33934214f8c5620813136a - Sigstore transparency entry: 976844390
- Sigstore integration time:
-
Permalink:
adsk-duszykf/Adsk.Platform.Toolkit.Python@44500c93f4f8a3d07abce55026a061f749f2635d -
Branch / Tag:
refs/tags/v0.2.9 - Owner: https://github.com/adsk-duszykf
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publishPyPi.yml@44500c93f4f8a3d07abce55026a061f749f2635d -
Trigger Event:
push
-
Statement type:
File details
Details for the file adsk_platform_acc-0.2.9-py3-none-any.whl.
File metadata
- Download URL: adsk_platform_acc-0.2.9-py3-none-any.whl
- Upload date:
- Size: 3.5 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
68c215049188c38ed6479d5bfc80d40e6203b00990e681a08c7661981dd56767
|
|
| MD5 |
a224e85d3d608336e5b9c2bb149067bd
|
|
| BLAKE2b-256 |
10630834e095ed5c533f0fb57072ceac42e4e32cbf5815a20513e052870c048f
|
Provenance
The following attestation bundles were made for adsk_platform_acc-0.2.9-py3-none-any.whl:
Publisher:
publishPyPi.yml on adsk-duszykf/Adsk.Platform.Toolkit.Python
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
adsk_platform_acc-0.2.9-py3-none-any.whl -
Subject digest:
68c215049188c38ed6479d5bfc80d40e6203b00990e681a08c7661981dd56767 - Sigstore transparency entry: 976844393
- Sigstore integration time:
-
Permalink:
adsk-duszykf/Adsk.Platform.Toolkit.Python@44500c93f4f8a3d07abce55026a061f749f2635d -
Branch / Tag:
refs/tags/v0.2.9 - Owner: https://github.com/adsk-duszykf
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publishPyPi.yml@44500c93f4f8a3d07abce55026a061f749f2635d -
Trigger Event:
push
-
Statement type: