Skip to main content

Client library for Kanboard

Project description

Client library for Kanboard API.

  • Author: Frédéric Guillot

  • License: MIT

Installation

python3 -m pip install kanboard

This library is compatible with Python >= 3.5.

Note: Support for Python 2.7 has been dropped since version 1.1.0.

On Fedora (36 and later), you can install the package using DNF:

dnf install python3-kanboard

Examples

Methods and arguments are the same as the JSON-RPC procedures described in the official documentation.

Python methods are dynamically mapped to the API procedures: You must use named arguments.

By default, calls are made synchronously, meaning that they will block the program until completed.

Creating a new team project

import kanboard

kb = kanboard.Client('http://localhost/jsonrpc.php', 'jsonrpc', 'your_api_token')
project_id = kb.create_project(name='My project')

Authenticate as user

import kanboard

kb = kanboard.Client('http://localhost/jsonrpc.php', 'admin', 'secret')
kb.get_my_projects()

Create a new task

import kanboard

kb = kanboard.Client('http://localhost/jsonrpc.php', 'jsonrpc', 'your_api_token')
project_id = kb.create_project(name='My project')
task_id = kb.create_task(project_id=project_id, title='My task title')

Use a personalized user agent

import kanboard

kb = kanboard.Client(url='http://localhost/jsonrpc.php',
                     username='admin',
                     password='secret',
                     user_agent='My Kanboard client')

SSL connection and self-signed certificates

Example with a valid certificate:

import kanboard

kb = kanboard.Client('https://example.org/jsonrpc.php', 'admin', 'secret')
kb.get_my_projects()

Example with a custom certificate:

import kanboard

kb = kanboard.Client(url='https://example.org/jsonrpc.php',
                     username='admin',
                     password='secret',
                     cafile='/path/to/my/cert.pem')
kb.get_my_projects()

Example with a custom certificate and hostname mismatch:

import kanboard

kb = kanboard.Client(url='https://example.org/jsonrpc.php',
                     username='admin',
                     password='secret',
                     cafile='/path/to/my/cert.pem',
                     ignore_hostname_verification=True)
kb.get_my_projects()

Ignore invalid/expired certificates and hostname mismatches, which will make your application vulnerable to man-in-the-middle (MitM) attacks:

import kanboard

kb = kanboard.Client(url='https://example.org/jsonrpc.php',
                     username='admin',
                     password='secret',
                     insecure=True)
kb.get_my_projects()

Asynchronous I/O

The client also exposes async/await style method calls. Similarly to the synchronous calls (see above), the method names are mapped to the API methods.

To invoke an asynchronous call, the method name must be appended with _async. For example, a synchronous call to create_project can be made asynchronous by calling create_project_async instead.

import asyncio
import kanboard

kb = kanboard.Client('http://localhost/jsonrpc.php', 'jsonrpc', 'your_api_token')

loop = asyncio.get_event_loop()
project_id = loop.run_until_complete(kb.create_project_async(name='My project'))
import asyncio
import kanboard

async def call_within_function():
    kb = kanboard.Client('http://localhost/jsonrpc.php', 'jsonrpc', 'your_api_token')
    return await kb.create_project_async(name='My project')

loop = asyncio.get_event_loop()
project_id = loop.run_until_complete(call_within_function())

See the official API documentation for the complete list of methods and arguments.

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

kanboard-1.1.5.tar.gz (5.4 kB view details)

Uploaded Source

Built Distribution

kanboard-1.1.5-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file kanboard-1.1.5.tar.gz.

File metadata

  • Download URL: kanboard-1.1.5.tar.gz
  • Upload date:
  • Size: 5.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for kanboard-1.1.5.tar.gz
Algorithm Hash digest
SHA256 5482c50cb1d83ea531f834e4dfe8c41774baacb2f465303b4920d72371361440
MD5 d6bb44ca92dfbf99ad3d07af75932111
BLAKE2b-256 4c01cc8d67d9867680bec3c72d9c9d575ed22aa797d6d187ab33cdefce7b01ad

See more details on using hashes here.

File details

Details for the file kanboard-1.1.5-py3-none-any.whl.

File metadata

  • Download URL: kanboard-1.1.5-py3-none-any.whl
  • Upload date:
  • Size: 5.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for kanboard-1.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2eafd47dc4638a1226d9516dd10cea3621da4c058d28bcd7b232040213a9f5d3
MD5 ead76f9d75df8207491899c41904d0fa
BLAKE2b-256 c63be540e4973f0d26289ea2d5d24354280547f92b389da354462a61efe576ec

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