Skip to main content

Klavis AI (https://www.klavis.ai)

Project description

Klavis AI Python SDK

PyPI version License: MIT

Klavis AI - Open Source MCP Integrations for AI Applications. This Python package provides a convenient way to interact with the Klavis AI API (https://www.klavis.ai).

Installation

You can install the Klavis AI Python SDK using pip:

pip install klavis

Getting Started

To use the SDK, you need to obtain an API key from Klavis AI.

Here's a basic example of how to configure the client and make an API call:

import os
from pprint import pprint

from klavis import ApiClient, Configuration
from klavis.api import McpServerApi
from klavis.models import CreateServerRequest, ServerName, CallToolRequest

# Replace 'YOUR_API_KEY' with your actual Klavis API key
# You can also set the KLAVIS_API_KEY environment variable
api_key = os.environ.get("KLAVIS_API_KEY", "YOUR_API_KEY") 
if api_key == "YOUR_API_KEY":
    print("Warning: API Key not configured. Please set the KLAVIS_API_KEY environment variable or replace 'YOUR_API_KEY'.")
    # exit(1) # Consider exiting if the key is required for all operations

config = Configuration(
    host="https://api.klavis.ai", # Default production server
    api_key=api_key,
)

# Create an API client instance
api_client = ApiClient(config)

# Example: Using the MCP Server API
mcp_api = McpServerApi(api_client)

try:
    # 1. Create a server instance for a specific MCP (e.g., GitHub)
    print("\n--- Creating a server instance ---")
    create_request = CreateServerRequest(
        server_name=ServerName.GITHUB, 
        user_id="example_user_id",        # Replace with a relevant user identifier
        platform_name="example_platform"  # Replace with your platform name
    )
    instance = mcp_api.create_server_instance(create_request)
    instance_id = instance.instance_id
    server_url = instance.server_url
    print("Instance created:")
    pprint(instance.to_dict())

    # (Optional) Check instance details
    print("\n--- Getting instance details ---")
    instance_details = mcp_api.get_server_instance(instance_id)
    print("Instance details:")
    pprint(instance_details.to_dict())
    
    # (Optional) If the server requires authentication (e.g., PAT for GitHub), 
    # you might need to set it after the OAuth flow or manually.
    # See OAuth endpoints and set_instance_auth_token. 
    # For GitHub, you'd typically complete the OAuth flow first.
    # The server_url obtained above includes the instance_id and handles routing.

    # 2. Call a tool on the created instance
    # Ensure the instance is properly authenticated if required by the tool.
    print("\n--- Calling a tool (GitHub Search Repositories) ---")
    call_request = CallToolRequest(
        server_url=server_url,                # Use the URL from the create step
        tool_name="github_search_repositories", # Tool name for the specific MCP
        tool_args={"query": "klavis ai"}      # Arguments required by the tool
    )
    tool_result = mcp_api.call_server_tool(call_request)
    print("Tool call result:")
    pprint(tool_result.to_dict())

    # 3. Clean up: Delete the instance when done
    print("\n--- Deleting instance ---")
    delete_result = mcp_api.delete_server_instance(instance_id)
    print("Deletion result:")
    pprint(delete_result.to_dict())

except Exception as e:
    print(f"An API error occurred: {e}")

Available APIs

This SDK provides access to the following Klavis AI API functionalities:

  • MCP Server API (klavis.api.McpServerApi): Manage MCP server instances, list and call tools on connected MCPs (like Slack, GitHub, Jira, etc.).
  • OAuth APIs (e.g., klavis.api.SlackOauthApi, klavis.api.GithubOauthApi, etc.): Handle OAuth flows for different services to authenticate MCP instances.
  • White Labeling API (klavis.api.WhiteLabelingApi): Manage OAuth white labeling configurations.

Please refer to the docs and directories or the official Klavis AI API documentation for details on all available methods and models.

Authentication

Authentication is handled via an API key passed as a Bearer token in the Authorization header. The Configuration object manages this automatically when you provide your api_key.

from klavis import Configuration

config = Configuration(
    api_key="YOUR_API_KEY", 
)

Documentation

For more detailed information on the API endpoints and models, please refer to the Klavis AI API Documentation.

Contributing

Contributions are welcome! Please refer to the main repository's contribution guidelines.

License

This SDK is distributed under the terms of the LICENSE file.

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

klavis-0.0.8.tar.gz (36.3 kB view details)

Uploaded Source

Built Distribution

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

klavis-0.0.8-py3-none-any.whl (84.7 kB view details)

Uploaded Python 3

File details

Details for the file klavis-0.0.8.tar.gz.

File metadata

  • Download URL: klavis-0.0.8.tar.gz
  • Upload date:
  • Size: 36.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for klavis-0.0.8.tar.gz
Algorithm Hash digest
SHA256 fd3a7790efda35918dfff29e93b7afaa83f4f9b7e79933e7e5b99190c96672b7
MD5 dcc582d9d0c5c760843394d11470770c
BLAKE2b-256 be7a8bdfe0ab97df34173731cc4835cb564e25fd56059c4aaf1a68986b886808

See more details on using hashes here.

Provenance

The following attestation bundles were made for klavis-0.0.8.tar.gz:

Publisher: python-app.yml on Klavis-AI/klavis

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

File details

Details for the file klavis-0.0.8-py3-none-any.whl.

File metadata

  • Download URL: klavis-0.0.8-py3-none-any.whl
  • Upload date:
  • Size: 84.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for klavis-0.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 830a3ed4418d6fd35c9b67329c61b3fa0dc6d736a7dd9a010fc20a27e042d582
MD5 30b360574c1c05069ca5422ffec35712
BLAKE2b-256 470990ee3f59ecc8e36073490251eaef1a3f0c3a3f677ca4936d9fdb4f68c152

See more details on using hashes here.

Provenance

The following attestation bundles were made for klavis-0.0.8-py3-none-any.whl:

Publisher: python-app.yml on Klavis-AI/klavis

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