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-key: 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', input_=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:

# 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

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

# Retrieve all user integrations information
user_info = bosa.get_user_info(user_token)
integrations = user_info.integrations

# Select an integration
select_result = bosa.select_integration("github", user_token, integrations[0].user_identifier)

# Remove an integration
remove_result = bosa.remove_integration("github", user_token, integrations[0].user_identifier)

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.2.5b5-cp313-cp313-win_amd64.whl (384.1 kB view details)

Uploaded CPython 3.13Windows x86-64

bosa_connectors_binary-0.2.5b5-cp313-cp313-manylinux_2_34_x86_64.whl (565.2 kB view details)

Uploaded CPython 3.13manylinux: glibc 2.34+ x86-64

bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_x86_64.whl (401.7 kB view details)

Uploaded CPython 3.13macOS 13.0+ x86-64

bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl (348.4 kB view details)

Uploaded CPython 3.13macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_connectors_binary-0.2.5b5-cp312-cp312-win_amd64.whl (385.6 kB view details)

Uploaded CPython 3.12Windows x86-64

bosa_connectors_binary-0.2.5b5-cp312-cp312-manylinux_2_34_x86_64.whl (566.5 kB view details)

Uploaded CPython 3.12manylinux: glibc 2.34+ x86-64

bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_x86_64.whl (400.4 kB view details)

Uploaded CPython 3.12macOS 13.0+ x86-64

bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl (346.3 kB view details)

Uploaded CPython 3.12macOS 13.0+ ARM64macOS 15.0+ ARM64

bosa_connectors_binary-0.2.5b5-cp311-cp311-win_amd64.whl (390.5 kB view details)

Uploaded CPython 3.11Windows x86-64

bosa_connectors_binary-0.2.5b5-cp311-cp311-manylinux_2_34_x86_64.whl (506.5 kB view details)

Uploaded CPython 3.11manylinux: glibc 2.34+ x86-64

bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_x86_64.whl (392.7 kB view details)

Uploaded CPython 3.11macOS 13.0+ x86-64

bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl (340.9 kB view details)

Uploaded CPython 3.11macOS 13.0+ ARM64macOS 15.0+ ARM64

File details

Details for the file bosa_connectors_binary-0.2.5b5-cp313-cp313-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp313-cp313-win_amd64.whl
Algorithm Hash digest
SHA256 7930a1417a82c15f792b1e269bb0ce7dcb4317854db80806540d37e830107036
MD5 cdd63b028b3bffe6ee1f8abfe6abc0b5
BLAKE2b-256 9e9a16c7020ca40e0f7fc9c516b030fdb6ee447f81091091c9aedae0f6ac27dd

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-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.2.5b5-cp313-cp313-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp313-cp313-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 80c4a800cdf4892e3d1282304e11b8bb16cbd8a8fd6811ee9392fd5e98321c8d
MD5 ba9ec9e4f3d1a61f4a0da1eb481dd437
BLAKE2b-256 461ba5987d75fdc80c46aded64d9e8606e77f4499c01c1ced1cd09247b529fd7

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 bd8e7f374bcf4b6076d55fc38f193c0fa351c1c21c44c5df0746756557c64a2d
MD5 e7e6efa70da07a24f0d8d40532ff57b0
BLAKE2b-256 ec24e282a7f4e3f967b2f8fe6a416a4650308e3cf8e3968240db182e84b0a0f0

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_x86_64.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.2.5b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 2a55d6027fb174eba71a490c763885545b10e2a1854dad47e8f7a0f9bbecd16a
MD5 8877ac574b69531e8c9657cc12f1a84f
BLAKE2b-256 8cc557c718200f2bb54a219bfc9579bb6059c1ef60c2d1ce49d3b9fe416a7137

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp313-cp313-macosx_13_0_arm64.macosx_15_0_arm64.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.2.5b5-cp312-cp312-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp312-cp312-win_amd64.whl
Algorithm Hash digest
SHA256 e45237d8985d345247408b2d7978c69689a8b9eda50dc5dd5ff96ed6323699fa
MD5 0cb5f97ac7ee787b732f1fe47765ec35
BLAKE2b-256 be4ccf27e29711e0e23cee878582cfbd68528c5b6769a50d71bae5a39fd5dfd0

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-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.2.5b5-cp312-cp312-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp312-cp312-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 6685dbe2f95a212383fd949329f122038d6caab832b257067af02e6ba18708ac
MD5 816730790ad0f22e17ddf7c7c04cb098
BLAKE2b-256 d5589810d3f8bff89f14af1fa36424d127c0c3ec0adb8bc99ed703e4bd4291f6

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 d867888d8523fc0ebb235f508280606b40dcb90f2e1e4b54f9748972611601d8
MD5 fbe5108af539d6051f5e3e08b043eaa9
BLAKE2b-256 2d366afb49c02b0e494026ccfa7f82af8098c0efb7aa81f518662008083c5016

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_x86_64.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.2.5b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 09cf63ab6c3109b9cc4a8a7fc9b0dc0cb2d50a2790ce4de8c81a419f9d0a1861
MD5 8434a45f09678420ed97db1b25a6c88f
BLAKE2b-256 272c2a271ea28e1046f3652df4bccac091c829b5bdb2a31f96b636d878761ebb

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp312-cp312-macosx_13_0_arm64.macosx_15_0_arm64.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.2.5b5-cp311-cp311-win_amd64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp311-cp311-win_amd64.whl
Algorithm Hash digest
SHA256 228e598da4a44473e96c1c3bb3373b51126962fa0cb3b2c5517ad529739e5840
MD5 a5ba6d71f286eef1c704ae145adf196a
BLAKE2b-256 0fd7eba54057ca4d7c6ee35ebd7c8d76c776c5af012eef48d3fcdb3da32a5947

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-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.2.5b5-cp311-cp311-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp311-cp311-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 671721eb266bb51e0ca5052ff61ce77135832430d2bba7a56a6377a7bd18829b
MD5 72f4c8e96ed298d17ea37bd87427f49b
BLAKE2b-256 7a857db27681ce7898f1b23890a9cbded7fcd4ebdb7360ec631fb1772e261212

See more details on using hashes here.

File details

Details for the file bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_x86_64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_x86_64.whl
Algorithm Hash digest
SHA256 e49371e7d70b2ba7aa5816715beac8cff0190e4ef269f71172188088633ee410
MD5 2e4caa3f4d353417783ce4d768b07866
BLAKE2b-256 b2d6ca988e550b3ac98735d1777157578589674d3bd532e67f3405389fc237fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_x86_64.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.2.5b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl.

File metadata

File hashes

Hashes for bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.whl
Algorithm Hash digest
SHA256 c1e2173054641039269b4e6778893e7f100a5c3143c7b22a907a965511d4567b
MD5 d813c24caddb9e4b00022d7d0ef3a7ff
BLAKE2b-256 666557cf57211fc2dc3ff80249775e3e3f0ab0cf7456aeea35353a9b4ab4a3d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for bosa_connectors_binary-0.2.5b5-cp311-cp311-macosx_13_0_arm64.macosx_15_0_arm64.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