Skip to main content

BOSA Connectors

Project description

BOSA API SDK (Bosa Connector)

A Python SDK for seamlessly connecting to APIs that implement BOSA's Plugin Architecture under HTTP Interface. This connector acts as a proxy, simplifying the integration with BOSA-compatible APIs.

Features

  • Simple and intuitive API for connecting to BOSA-compatible services
  • Automatic endpoint discovery and schema validation
  • Built-in authentication support (BOSA API Key and User Token)
  • User management and OAuth2 integration flow support
  • Type-safe parameter validation
  • Flexible parameter passing (dictionary or keyword arguments)
  • Retry support for requests that fail (429 or 5xx)
  • Response fields filtering based on action and output

Prerequisites

After the bosa-api ready, you can perform the following tasks:

  • Ensure Bosa API is running. If you want to test locally, or you can use Staging or Production environments.
  • Create Client
    • You can send a create-client request to the bosa-api using Postman with the following header and body:
      • Header
        • x-api-user: KEY1
      • Body
        • name: "{client name}"
    • Response :
      {
           "data": {
               "id": "{client_id}",
               "name": "admin",
               "api_key": "{client_api_key}",
               "is_active": true
           },
           "meta": null
      }
      
  • Register the user, see the details here.

Installation

Prerequisites

1. Installation from Pypi

Choose one of the following methods to install the package:

Using pip

pip install bosa-connectors-binary

Using Poetry

poetry add bosa-connectors-binary

2. Development Installation (Git)

For development purposes, you can install directly from the Git repository:

poetry add "git+ssh://git@github.com/GDP-ADMIN/bosa-sdk.git#subdirectory=python/bosa-connectors"

Quick Start

Here's a simple example of how to use the BOSA Connector with API key authentication and user token.

Initialization

Before using the connector, you need to initialize it with your BOSA API base URL and API key.

from bosa_connectors.connector import BosaConnector

# Initialize the connector
bosa = BosaConnector(api_base_url="YOUR_BOSA_API_BASE_URL", api_key="YOUR_API_KEY")

Authentication

After initializing the connector, you can authenticate with your BOSA API key.

# User token from authentication
user_token = "Enter your key (bearer token) here from authentication, or refer to User Authentication section below"

# Check if a user has an integration for a connector
has_integration = bosa.user_has_integration("github", user_token)

if not has_integration:
    # Initiate the OAuth2 flow for a connector
    auth_url = bosa.initiate_connector_auth("github", user_token, "https://your-callback-uri.com")
    # Redirect the user to auth_url to complete authentication, we exit here.
    print("Integration with GitHub not found.")
    print(f"Please visit {auth_url} to complete authentication.")
    exit()

Alternatively, you can authenticate the user first and then use their token:

user = bosa.authenticate_bosa_user("username", "password")

# Get user token
user_token = user.token

Basic Example (Direct Execution)

It is the basic way to execute actions, where you need to provide the connector name, action name, and user token. The response will contain the data and status:

# Prepare input parameters
params = {
    "repo": "my-local-repo", # try to use your local repo for testing
    "owner": "rexywjy",
}

# Execute the action with user token
data, status = bosa.execute("github", "list_collaborators", token=user_token, max_attempts=1, input_=params)
print(data)
print(status)

More details about parameters and actions in bosa-api docs {domain}/docs

Alternative Approach (Fluent Interface)

For more complex scenarios or more control over the execution, you can use the fluent interface. We're recommending this approach if you:

  • Need to execute multiple actions with different parameters
  • Expecting list response
  • Need to execute actions in a loop
# Prepare input parameters
params = {
    "owner": "gdp-admin",
    "author": "samuellusandi",
    "per_page": 1,
    "sort": "author_date",
    "created_date_start": "2025-02-01",
    "created_date_end": "2025-02-02"
}

# Create a connector instance to a service
github = bosa.connect('github')

# Execute actions with fluent interface
response = github.action('list_pull_requests')\
    .params(params)\
    .max_attempts(3)\
    .token('user-token')\
    .run()  # Execute and return ActionResponse for advanced data handling

# Get initial data
initial_data = response.get_data()

# Iterate the following next pages
while response.has_next():
    response = response.next_page()
    data = response.get_data()
    # Process data here
    ...

# You can also navigate backwards
while response.has_prev():
    response = response.prev_page()
    data = response.get_data()
    # Process data here
    ...

# Execute multiple independent actions using the same connector instance
commits_response = github.action('list_commits')\
    .params({
        'owner': 'GDP-ADMIN',
        'repo': 'bosa',
        'page': 1,
        'per_page': 10
    })\
    .token('user-token')\
    .run()

run method also available for direct execution from connector instance, without using fluent interface.

# Prepare input parameters
params = {
    "owner": "gdp-admin",
    "author": "samuellusandi",
    "per_page": 1,
    "sort": "author_date",
    "created_date_start": "2025-02-01",
    "created_date_end": "2025-02-02"
}

# Execute actions with run method
response = bosa.run('github', 'list_pull_requests', params)
print(response.get_data())

Working with Files using ConnectorFile

When working with APIs that require file uploads or return file downloads, use the ConnectorFile model:

from bosa_connectors.models.file import ConnectorFile

# For uploads: Create a ConnectorFile object
with open("document.pdf", "rb") as f:
    upload_file = ConnectorFile(
        file=f.read(),
        filename="document.pdf",
        content_type="application/pdf"
    )

params = {
  "file": upload_file,
  "name": "My Document"
}

# Include in your parameters
result, status = bosa.execute("google_drive", "upload_file", input_=params)

# For downloads: Check response type
file_result, status = bosa.execute("google_drive", "download_file", input_={"file_id": "123"})
if isinstance(file_result, ConnectorFile):
    # Save to disk
    with open(file_result.filename or "downloaded_file", "wb") as f:
        f.write(file_result.file)

Available Methods

Connector Instance Methods

The connector instance provides several methods for configuring and executing actions:

  • connect(name): Create a connector instance to a service

  • action(name): Specify the action to execute

  • params(dict): Set request parameters (including pagination parameters like page and per_page). Note that params for each plugin and action could be different

  • token(str): Set the BOSA user token

  • headers(dict): Set custom request headers

  • max_attempts(number): Set the maximum number of retry attempts (default: 1) Execution Methods:

  • run(): Execute and return ActionResponse for advanced data handling

  • execute(): Execute and return data and status for basic data handling. The data part of the return value can be a ConnectorFile object when the API returns a non-JSON response (such as a file download).

Response Handling (ActionResponse)

The ActionResponse class provides methods for handling the response and pagination:

  • get_data(): Get the current page data (returns the data field from the response). This can return a ConnectorFile object when the API returns a non-JSON response (such as a file download).
  • get_meta(): Get the metadata information from the response (e.g., pagination details, total count)
  • get_status(): Get the HTTP status code
  • is_list(): Check if response is a list
  • has_next(): Check if there is a next page
  • has_prev(): Check if there is a previous page
  • next_page(): Move to and execute next page
  • prev_page(): Move to and execute previous page
  • get_all_items(): Get all items from all pages (returns a list of objects containing data and meta for each page)

Data Models

The SDK uses the following data models:

  • ActionResponseData: Contains the response data structure with data (list, object, or ConnectorFile instance) and meta (metadata) fields
  • InitialExecutorRequest: Stores the initial request parameters used for pagination and subsequent requests
  • ConnectorFile: Represents a file in requests and responses with these properties:
    • file: Raw bytes content of the file
    • filename: Optional name of the file
    • content_type: Optional MIME type of the file
    • headers: Optional HTTP headers for the file

Configuration Parameters

  • api_base_url: The base URL of your BOSA API endpoint (default: "https://api.bosa.id"). This parameter is extremely important as it determines the URL of the BOSA API you are connecting to, and it will be used to populate the available actions/endpoints and their parameters upon initialization.
  • api_key: Your BOSA API key for authentication. This is different from plugin-specific API keys, which are managed separately by the BOSA system.

Execution Parameters

  • connector: The name of the connector to use. This parameter is used to determine the connector's available actions and their parameters.
  • action: The name of the action to execute. This parameter is automatically populated by the connector based on the available actions and their parameters. The list of available actions per connector can be found in https://api.bosa.id/docs and are populated through https://api.bosa.id/connectors.
  • max_attempts: The maximum number of attempts to make the API request. If the request fails, the connector will retry the request up to this number of times. The default value is 1 if not provided.
    • The retries are handled automatically by the connector, with exponential backoff.
    • The retries are only done for errors that are considered retryable (429 or 5xx).
  • input_: The input parameters for the action. This parameter is a dictionary that contains the parameters for the action. The connector will validate the input parameters against the action's schema.
    • To filter response fields, simply add the response_fields parameter to the input dictionary. This parameter is a list of field names that will be returned in the response. For nested fields, you can use dot notation, e.g. user.login will return the following:
    {
      "user": {
        "login": "userlogin"
      }
    }
    
  • token: Optional BOSA User Token for authenticating requests. When provided, the connector will include this token in the request headers. This is required for user-specific actions or when working with third-party integrations.

How It Works

  1. Initialization: When you create a BosaConnector instance, and trigger an execute(), the connector will first populate and cache the available actions and their parameters. This is done automatically.

  2. Action Discovery: The connector expects the BOSA API to expose an endpoint that lists all available actions and their parameters. This is handled automatically by BOSA's HTTP Interface.

  3. Execution: When you call execute(), the connector:

    • Validates your input parameters against the action's schema
    • Handles authentication
    • Makes the API request
    • Returns the formatted response

Compatibility

While primarily tested with BOSA's HTTP Interface, this connector should theoretically work with any API that implements BOSA's Plugin Architecture, as long as it:

  1. Exposes an endpoint listing available actions and their parameters
  2. Follows BOSA's standard HTTP Interface specifications (through the Plugin Architecture)
    • All actions must be exposed as POST endpoints.
  3. Implements the required authentication mechanisms

Error Handling

The connector includes built-in error handling for:

  • Invalid parameters
  • Authentication failures
  • Connection issues
  • API response errors

User Authentication

The BOSA Connector supports user-based authentication which allows for user-specific actions and third-party integrations:

# Step 1: Create a new BOSA user
user_data = bosa.create_bosa_user("username")
# Save the secret for later use
user_secret = user_data.secret

# Step 2: Authenticate the user and obtain their token
token = bosa.authenticate_bosa_user("username", user_secret)

# Step 3: Retrieve user information using the obtained token
user_info = bosa.get_user_info(token.token)

❗ Important Notes

🛡️ Best Practice: Since bearer tokens can have a long lifespan, it is highly recommended to reuse existing tokens whenever possible. While creating new tokens is functionally acceptable, be aware that older tokens may become dangling and can pose a security risk if they are exposed or misused.

⚠️ Security Reminder: When you register a new BOSA user, you will receive a token that starts with "sk-user-...". It is essential to keep this token safe, as it cannot be recovered if lost, and currently, there is no option to reset it.

Integration Management

The BOSA Connector provides methods to manage third-party integrations for authenticated users:

# Check if a user has an integration for a connector
has_integration = bosa.user_has_integration("github", user_token)

# Initiate the OAuth2 flow for a connector
auth_url = bosa.initiate_connector_auth("github", user_token, "https://your-callback-uri.com")
# Redirect the user to auth_url to complete authentication

# Remove an integration
remove_result = bosa.remove_integration("github", user_token)

References

Product Requirements Documents(PRD):

Architecture Documents:

Design Documents:

Implementation Documents:

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

bosa_connectors_binary-0.1.6-cp313-cp313-win_amd64.whl (360.7 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_connectors_binary-0.1.6-cp313-cp313-manylinux_2_31_x86_64.whl (537.6 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.31+ x86-64

bosa_connectors_binary-0.1.6-cp313-cp313-macosx_11_0_universal2.whl (332.6 kB view details)

Uploaded CPython 3.13macOS 11.0+ universal2 (ARM64, x86-64)

bosa_connectors_binary-0.1.6-cp313-cp313-macosx_10_13_universal2.whl (371.2 kB view details)

Uploaded CPython 3.13macOS 10.13+ universal2 (ARM64, x86-64)

bosa_connectors_binary-0.1.6-cp312-cp312-win_amd64.whl (362.0 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_connectors_binary-0.1.6-cp312-cp312-manylinux_2_31_x86_64.whl (541.1 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.31+ x86-64

bosa_connectors_binary-0.1.6-cp312-cp312-macosx_11_0_universal2.whl (330.8 kB view details)

Uploaded CPython 3.12macOS 11.0+ universal2 (ARM64, x86-64)

bosa_connectors_binary-0.1.6-cp312-cp312-macosx_10_13_universal2.whl (369.3 kB view details)

Uploaded CPython 3.12macOS 10.13+ universal2 (ARM64, x86-64)

bosa_connectors_binary-0.1.6-cp311-cp311-win_amd64.whl (369.3 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_connectors_binary-0.1.6-cp311-cp311-manylinux_2_31_x86_64.whl (491.1 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.31+ x86-64

bosa_connectors_binary-0.1.6-cp311-cp311-macosx_11_0_universal2.whl (327.5 kB view details)

Uploaded CPython 3.11macOS 11.0+ universal2 (ARM64, x86-64)

bosa_connectors_binary-0.1.6-cp311-cp311-macosx_10_9_universal2.whl (363.7 kB view details)

Uploaded CPython 3.11macOS 10.9+ universal2 (ARM64, x86-64)

File details

Details for the file bosa_connectors_binary-0.1.6-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 50647e8b40f48edc833b0d6c46a81939b4f3c59e3f02c926571881d256c99f65
MD5 6f5516c779a03b9e162c04b740076ff4
BLAKE2b-256 1864523819afd5bb31505e0172ee546316d89b65022e7d8859aea2773eb01745

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp313-cp313-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp313-cp313-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp313-cp313-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 08bbbd5713b0983e5e7d9907a1172dad65a7a1d3c588d736839814d246a5f57d
MD5 28d885e97cc99f4cf85e0a717b14939a
BLAKE2b-256 724ecc2bb763e082b1273bb5c641c18eb02570f1c848d8ead99827d998994d1e

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.1.6-cp313-cp313-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 467f02bb05b23db49c9a4c30fb46b60eca65f14b11499addb0b2838b7019f770
MD5 98a6178116d4c7d0e79847d359a88051
BLAKE2b-256 8a7ca1c127597d5429ec674cea33b557ae9a9d1223e9835dd3f32d0ab9821e52

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp313-cp313-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp313-cp313-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp313-cp313-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 63aaa26ed85abf801216da715d3edd224b4d28140b7b125ba49c7eb227a96fed
MD5 229ad6e0d987f54f04ae05e9bfa04bd1
BLAKE2b-256 d2164b2db49d29fa580688ec4f09ad78770042dd6ad5aacc1175af23285d09b0

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp313-cp313-macosx_10_13_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 6d24d25c2d7108320f47956fad7332e32d2c79ac24a4f1592c142cd6f07fa339
MD5 3530e8ca7e738fff3839e2054ad0e3a1
BLAKE2b-256 ebd0e251a177d96138774313679750017699cd1100a5e325b819ae3e3b7a1018

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp312-cp312-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp312-cp312-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp312-cp312-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 276c2d19f01e367d761cadb776dc0020ec27fc66b77d22db2b8a9b7593f93518
MD5 f392ab13469ecca7ab5e5a21e05d3d1a
BLAKE2b-256 d20200c2bca67445c647da1f509de1c8df6ebee416c85e5a973616cbfe50da69

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.1.6-cp312-cp312-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp312-cp312-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 4f0eadc441da9c36039518dbd1323f4122d67bcb53cd893b4ceeaea32c34430e
MD5 7cf86e1c3b65d06b09c72b89e41c8859
BLAKE2b-256 68bc2c02acb5171555debce541895d921035f2e4ae4d76c027851e851a99143d

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp312-cp312-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp312-cp312-macosx_10_13_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp312-cp312-macosx_10_13_universal2.whl
Algorithm Hash digest
SHA256 2c22deef5eaec6bae82fd783d5a139aa41282012bb3ba6850c6dc181acdc8ea9
MD5 bfda5040a733b84d8d2c391fc798587f
BLAKE2b-256 c0acbb9c5f27d416339115f8d7864c955d7654946a0fc2a4a2d13cc426dd8646

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp312-cp312-macosx_10_13_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 8e9b10aecfabd25e4dd5764e01625a818ee5a45d96729e4f0ea473bd824dda1e
MD5 4e6cf46712d85beea83531a5a45df77c
BLAKE2b-256 867e1eb516fe37d792fdc79f21d398a631e70ba42dd45744337e32477bec2cc3

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp311-cp311-win_amd64.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp311-cp311-manylinux_2_31_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp311-cp311-manylinux_2_31_x86_64.whl
Algorithm Hash digest
SHA256 93f3ab84c3777f2ec4c1cb0903569812c8042fe65f2b1699943cdeb9f6e33aaa
MD5 f435bc738d35120770955370767be13d
BLAKE2b-256 2f35fdef92eb7c8d6e97b308424882180ea4c5674836bc01cd245e99f1f5facd

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.1.6-cp311-cp311-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp311-cp311-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 c9b95c1976b0f34db587c7578254e4f97a145118d95d08ad3b02e15a58f925f0
MD5 021b4b8c87b83fcbb4bce5c506974c05
BLAKE2b-256 32515497c37c0a49a7d2257cdc058568e4b5bd955671172552397d0716cdccf4

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp311-cp311-macosx_11_0_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file bosa_connectors_binary-0.1.6-cp311-cp311-macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.1.6-cp311-cp311-macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 a228edd625b9d27b2989fd2b984775016cea1e645521fd334824d3c4149bb5b7
MD5 a9ab48139aaf68c838f2ede2384f07ed
BLAKE2b-256 e833ca008cc8a9e36088ee204959fb0434f62d0c6d672757fd1990f0f13ca622

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.1.6-cp311-cp311-macosx_10_9_universal2.whl:

Publisher: build-binary.yml on GDP-ADMIN/bosa-sdk

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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