Skip to main content

Client API for using the Boa infrastructure

Project description

About Boa Python Client API

The Boa Python Client API provides programmatic access to the Boa language and infrastructure from Python.

About Boa

For more information about Boa, please see the main website: https://boa.cs.iastate.edu/

Creating a client

The main entry point for the API is a BoaClient object. You use this to log in, submit queries, find datasets, log out, etc. To instantiate this object, you must provide the API endpoint's URL. The API has several constants for common endpoints:

  • BOA_API_ENDPOINT - for the Boa MSR endpoint
  • BOAC_API_ENDPOINT - for the Boa CORD-19 endpoint

For example if you want a client for the CORD-19 endpoint, you do the following:

client = BoaClient(endpoint=BOAC_API_ENDPOINT)

If you don't specify an endpoint, it will default to the MSR endpoint.

Example Use (using MSR endpoint)

import getpass
import time

from boaapi.boa_client import BoaClient, BOA_API_ENDPOINT
from boaapi.status import CompilerStatus, ExecutionStatus

client = BoaClient(endpoint=BOA_API_ENDPOINT)
user = input("Username [%s]: " % getpass.getuser())
if not user:
    user = getpass.getuser()
client.login(user, getpass.getpass())
print('successfully logged in to Boa API')

query = """# Counting the 10 most used programming languages
p: Project = input;
counts: output top(10) of string weight int;

foreach (i: int; def(p.programming_languages[i]))
    counts << p.programming_languages[i] weight 1;"""

# query using a specific dataset
job = client.query(query, client.get_dataset('2019 October/GitHub'))
print('query submitted')

while job.is_running():
    job.refresh()
    print('job ' + str(job.id) + ' still running, waiting 10s...')
    time.sleep(10)

if job.compiler_status is CompilerStatus.ERROR:
    print('job ' + str(job.id) + ' had compile error')
elif job.exec_status is ExecutionStatus.ERROR:
    print('job ' + str(job.id) + ' had exec error')
else:
    try:
        print('output:')
        print(job.output())
    except:
        pass

client.close()
print('client closed')

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

boa-api-0.1.14.tar.gz (11.4 kB view details)

Uploaded Source

Built Distribution

boa_api-0.1.14-py3-none-any.whl (16.1 kB view details)

Uploaded Python 3

File details

Details for the file boa-api-0.1.14.tar.gz.

File metadata

  • Download URL: boa-api-0.1.14.tar.gz
  • Upload date:
  • Size: 11.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.7

File hashes

Hashes for boa-api-0.1.14.tar.gz
Algorithm Hash digest
SHA256 1b7e69b30b43d1966cc321271a4925657c654220eecb85f6e2eadd6e9c1f751c
MD5 50e091618ef98ee6aa384278fa4c105b
BLAKE2b-256 356a9357f85fa91c32e9c7074ceb7bfcc414ea1108488e20d131e80066e39cac

See more details on using hashes here.

File details

Details for the file boa_api-0.1.14-py3-none-any.whl.

File metadata

  • Download URL: boa_api-0.1.14-py3-none-any.whl
  • Upload date:
  • Size: 16.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.7

File hashes

Hashes for boa_api-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 b131dbfbc6ed04045aaff56f0520bde7f199b4940b99c136427cad3c22864d67
MD5 a6be2effb7eacda686498b5dab9ca59f
BLAKE2b-256 93595c12cf4ec766a59a0a823c80f13543bd4b65813cc4c7c6718be514ce6ec6

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