Skip to main content

Python wrapper around the Trello API (Provisional version)

Project description

A wrapper around the Trello API written in Python. Each Trello object is represented by a corresponding Python object. The attributes of these objects are cached, but the child objects are not. This can possibly be improved when the API allows for notification subscriptions; this would allow caching (assuming a connection was available to invalidate the cache as appropriate).

I’ve created a Trello Board for feature requests, discussion and some development tracking.

Install

pip install py-trello

Usage

from trello import TrelloClient

client = TrelloClient(
    api_key='your-key',
    api_secret='your-secret',
    token='your-oauth-token-key',
    token_secret='your-oauth-token-secret'
)

Where token and token_secret come from the 3-legged OAuth process and api_key and api_secret are your Trello API credentials that are (generated here).

To use without 3-legged OAuth, use only api_key and api_secret on client.

Working with boards

all_boards = client.list_boards()
last_board = all_boards[-1]
print(last_board.name)

working with board lists and cards

all_boards = client.list_boards()
last_board = all_boards[-1]
last_board.list_lists()
my_list = last_board.get_list(list_id)

for card in my_list.list_cards():
    print(card.name)

Getting your Trello OAuth Token

Make sure the following environment variables are set:

  • TRELLO_API_KEY

  • TRELLO_API_SECRET

These are obtained from the link mentioned above.

TRELLO_EXPIRATION is optional. Set it to a string such as ‘never’ or ‘1day’. Trello’s default OAuth Token expiration is 30 days.

Default permissions are read/write.

More info on setting the expiration here: https://trello.com/docs/gettingstarted/#getting-a-token-from-a-user

Run

python -m trello oauth

Required Python modules

Found in requirements.txt

Tests

To run the tests, run python -m unittest discover. Four environment variables must be set:

  • TRELLO_API_KEY: your Trello API key

  • TRELLO_TOKEN: your Trello OAuth token

  • TRELLO_TEST_BOARD_COUNT: the number of boards in your Trello account

  • TRELLO_TEST_BOARD_NAME: name of the board to test card manipulation on. Must be unique, or the first match will be used

  • TRELLO_TEST_STAR_COUNT: the number of stars on your test Trello board

WARNING: The tests will delete all cards on the board called TRELLO_TEST_BOARD_NAME!

To run tests across various Python versions, tox is supported. Install it and simply run tox from the py-trello directory.

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

py-trello-api-0.20.0.tar.gz (60.5 kB view details)

Uploaded Source

Built Distribution

py_trello_api-0.20.0-py3-none-any.whl (41.5 kB view details)

Uploaded Python 3

File details

Details for the file py-trello-api-0.20.0.tar.gz.

File metadata

  • Download URL: py-trello-api-0.20.0.tar.gz
  • Upload date:
  • Size: 60.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.8.10

File hashes

Hashes for py-trello-api-0.20.0.tar.gz
Algorithm Hash digest
SHA256 3ea6ab3afdf52dbed41068d795e9a2d10c03f5255c62e1b6be0dd36b2a9d31ef
MD5 6c2b570d1bddabb0895bf4698a9a5602
BLAKE2b-256 f135b1039310c945e5c9baa98c79f286c2b61ae2a37633d6f2aa0b52611e8df0

See more details on using hashes here.

File details

Details for the file py_trello_api-0.20.0-py3-none-any.whl.

File metadata

File hashes

Hashes for py_trello_api-0.20.0-py3-none-any.whl
Algorithm Hash digest
SHA256 abc92b4f3c3cf425e0b9d74e109bf421e5c9330ab5d07ba2a2a20376e3243c87
MD5 2fbb4b63ea87ebee8b93164bf5645677
BLAKE2b-256 21d8a769fde73decc28e9a02a66ec051961a61912f5a295a50b9d0fad5d798c6

See more details on using hashes here.

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