Skip to main content

wrapper over kavahq.com API

Project description

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.1.0.tar.gz (5.0 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.1.0.linux-x86_64.tar.gz (8.1 kB view details)

Uploaded Source

File details

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

File metadata

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

File hashes

Hashes for kavahq-api-0.1.0.tar.gz
Algorithm Hash digest
SHA256 5787b92f9c84664b8b15cbe6aadcb82a4f5856dac675211a6bf1cf591742d99d
MD5 9d2da05c95ae5a2d6b12eb535b8e58c9
BLAKE2b-256 550b59fd2d6c4a5a4948cd1029467120c29b244e06f274702de986ddbff66d70

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for kavahq-api-0.1.0.linux-x86_64.tar.gz
Algorithm Hash digest
SHA256 0c841dfabca0973494b32d6b86d43b6d9179be5469772e7dc71d296af09bf09b
MD5 b381521750aff099dbb594bf0dd5671b
BLAKE2b-256 3f90c98178fa2153431447d3802d21ab7c49fd1b15c752eed1041df8d29a1dc8

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