Skip to main content

wrapper over kavahq.com API

Project description

Installation

pip install kavahq-api

Usage

import kavahq
import keyring
import getpass

SERVICE = 'kavahq-api'
username = 'imposeren'
password = keyring.get_password(SERVICE, username)
if password is None:
    password = getpass.getpass()
    keyring.set_password(SERVICE, username, password)

api = kavahq.KavaApi(username=username, password=password, company_name='42 Coffee Cups')

# almost all attributes of Api return instances of ApiObject which do not query results until they are required:
projects_api = api.projects  # no requests made
first_project_api = projects_api.children[0]  # project list api called but project details are not
first_project_estimate_api = first_project_api.estimate  # zero apis called
first_project_api.estimate['avg_time_per_cp']  # estimates api called and result is returned

# you can also get all results of api as a dict:
dict(first_project_api)

# you can also get specific project api by it's slug:
kava_project_api = api.projects.get('kavyarnya')
dict(kava_project_api)
# {u'days_num_bugs_showing': X, ...}

dict(kava_project_api.estimate)
# {u'avg_time_per_cp': u'2.1'...}
kava_project_api.properties['owner']
# u'akhavr'

# as you can see api calls can be "chained":
api.projects.estimate  # ApiObject for /api/project/estimate
api.projects.properties  # ApiObject for /api/project/properties

# but some attributes of ApiObject "break chaining":
api.projects.children[0].estimate.response  # returns dict with response from API
api.projects.get  # method to get projects by slug, (see examples above)
api.projects.keys()  # will return keys of response dict


# alternate way to call specific api:
dict(api.projects.estimate.get(project='kavyarnya', company='42 Coffee Cups'))
# this is equivivalent to:
api.company_name = '42 Coffee Cups')
dict(api.projects.get('kavyarnya').estimate)

Running tests

python setup.py nosetests

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

kavahq-api-0.2.9.tar.gz (5.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kavahq-api-0.2.9.linux-x86_64.tar.gz (9.1 kB view details)

Uploaded Source

File details

Details for the file kavahq-api-0.2.9.tar.gz.

File metadata

  • Download URL: kavahq-api-0.2.9.tar.gz
  • Upload date:
  • Size: 5.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for kavahq-api-0.2.9.tar.gz
Algorithm Hash digest
SHA256 521ba123cb261778d6394130aabcd39030e40e2bbce46e96b278ebd6c2dc9ac0
MD5 ae280561ba62f49115ec8d722fe76aa0
BLAKE2b-256 4fae2d225ed2923c6c5f4befdc233a73735f3fd46cd0a1ca12ec8e48e0c8cb51

See more details on using hashes here.

File details

Details for the file kavahq-api-0.2.9.linux-x86_64.tar.gz.

File metadata

File hashes

Hashes for kavahq-api-0.2.9.linux-x86_64.tar.gz
Algorithm Hash digest
SHA256 27e945a699c785004dd753bb0f57677b750a79648fa91b6764f7733d7839f88f
MD5 3f40215a9892e7618752bb68b2606734
BLAKE2b-256 26db973c16cc439da98e1ed3d6c59bcbcd48794b2f32aea86c9ef0f9a61b74b2

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