Skip to main content

Python SDK for the AMPA API

Project description

AMPA SDK

The AMPA SDK is a Python library that provides a convenient, high-level interface for interacting with the AMPA API. It is designed to simplify prompt management, versioning, and execution from any Python application, script, or notebook.

Overview

  • Easy integration: Manage prompts and their versions with simple Python calls
  • Handles authentication: Securely connect to the AMPA API with username/password or environment variables
  • Request/response abstraction: No need to manually format HTTP requests
  • Extensible: Add custom methods or extend for new API endpoints

Features

  • Create, update, delete, and run prompts from Python
  • List and manage prompt versions
  • Automatic handling of API authentication and errors
  • Works with both local and remote AMPA API deployments
  • CRUD and search for the prompt_tests endpoints

Installation

To install the AMPA SDK, use pip:

pip install the37lab_ampa_sdk

Configuration

You can configure the SDK via parameters or environment variables:

Environment variables:

  • AMPA_API_URL
  • AMPA_API_USERNAME
  • AMPA_API_PASSWORD

Usage Example

from the37lab_ampa_sdk import PromptAPI

# Initialize the client (parameters or env vars)
client = PromptAPI(
    ampa_url="http://localhost:8000",
    username="your_username",
    password="your_password",
)

# Create an prompt
data = {
    "prompt_name": "My Prompt",
    "description": "A helpful assistant",
    "purpose": "You are a helpful assistant",
    "instruction": "Tell a story about Sweden"
}
prompt = client.create_prompt(data)

# Run the prompt
response = client.call_prompt(
    "My Prompt",
    variables={"name": "John"},
    prompt="Tell me a story"
)

# List prompt versions
versions = client.list_prompt_versions(prompt["id"])

Use Cases

  • Integrate prompt management into Python apps, scripts, or notebooks
  • Automate prompt creation and execution in pipelines
  • Rapid prototyping and experimentation with LLM prompts

Extensibility

  • Add new methods for custom API endpoints
  • Subclass PromptAPI to add custom logic or error handling

Troubleshooting

  • Ensure the AMPA API is running and accessible
  • Check credentials and API URL
  • Review exception messages for error details

License

This project is proprietary software. All rights reserved.

prompt_tests Table Usage

The SDK supports CRUD and search for the prompt_tests endpoints:

from the37lab_ampa_sdk import PromptAPI
client = PromptAPI(...)

# Create
data = {
    'name': 'Test',
    'description': 'desc',
    'data': {'foo': 'bar'},
    'prompt': 'Say hi',
    'prompt_ids': [1, 2]
}
r = client.create_prompt_test(**data)

# Get by id
r = client.get_prompt_test(r['id'])

# Update
r = client.update_prompt_test(r['id'], description='new desc')

# Delete
client.delete_prompt_test(r['id'])

# List all
rows = client.list_prompt_tests()

# List by prompt id
rows = client.list_prompt_tests_by_prompt_id(1)

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

the37lab_ampa_sdk-0.1.1756971985.tar.gz (3.7 kB view details)

Uploaded Source

Built Distribution

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

the37lab_ampa_sdk-0.1.1756971985-py3-none-any.whl (4.1 kB view details)

Uploaded Python 3

File details

Details for the file the37lab_ampa_sdk-0.1.1756971985.tar.gz.

File metadata

File hashes

Hashes for the37lab_ampa_sdk-0.1.1756971985.tar.gz
Algorithm Hash digest
SHA256 81a8a40e2815e3e69771a357368aabd2368524df9e117611ad9d3facf2f4b60d
MD5 89c3e6fd28a4d08ffa4fcdabd5d5478c
BLAKE2b-256 e9e8a1b0b4fd9da03a2c566fce3606276ab29c2ef4731ec1a9aefb86ef78fc70

See more details on using hashes here.

File details

Details for the file the37lab_ampa_sdk-0.1.1756971985-py3-none-any.whl.

File metadata

File hashes

Hashes for the37lab_ampa_sdk-0.1.1756971985-py3-none-any.whl
Algorithm Hash digest
SHA256 5831f7d9758459c7302160de43d002e5b3da7511a30ede7e2b555eff42d6200c
MD5 52a3b79508f12893e9b2320b3ad88697
BLAKE2b-256 3cfe2942d6f8ee216ac33eb57b6256e2f950528df2d08cfa78dda47657acd422

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