Skip to main content

No project description provided

Project description

Smooth Python SDK

The Smooth Python SDK provides a convenient way to interact with the Smooth API for programmatic browser automation and task execution.

Features

  • Synchronous and Asynchronous Clients: Choose between SmoothClient for traditional sequential programming and SmoothAsyncClient for high-performance asynchronous applications.
  • Task Management: Easily run tasks and retrieve results upon completion.
  • Interactive Browser Sessions: Get access to, interact with, and delete stateful browser sessions to manage your login credentials.
  • Advanced Task Configuration: Customize task execution with options for device type, session recording, stealth mode, and proxy settings.
  • 🆕 MCP Server: Use the included Model Context Protocol server to integrate browser automation with AI assistants like Claude Desktop.

Installation

You can install the Smooth Python SDK using pip:

pip install smooth-py

For MCP server functionality, also install FastMCP:

pip install fastmcp

Quick Start Options

Option 1: Direct SDK Usage

Use the SDK directly in your Python applications:

Option 2: MCP Server (AI Assistant Integration)

Use the included MCP server to integrate browser automation with AI assistants:

Installation

# Install with MCP support
pip install smooth-py[mcp]

Basic Usage

from smooth.mcp import SmoothMCP

# Create and run the MCP server  
mcp = SmoothMCP(api_key="your-api-key")
mcp.run()  # STDIO transport for Claude Desktop

# Or with HTTP transport for web deployment
mcp.run(transport="http", host="0.0.0.0", port=8000)

Standalone Script (Backward Compatible)

# Set your API key
export CIRCLEMIND_API_KEY="your-api-key-here"

# Run the MCP server
python mcp_server.py

Then configure your AI assistant (like Claude Desktop) to use the MCP server. See MCP_README.md for detailed setup instructions.

Authentication

The SDK requires an API key for authentication. You can provide the API key in two ways:

  1. Directly in the client constructor:

    from smooth import SmoothClient
    
    client = SmoothClient(api_key="YOUR_API_KEY")
    
  2. As an environment variable:

    Set the CIRCLEMIND_API_KEY environment variable, and the client will automatically use it.

    export CIRCLEMIND_API_KEY="YOUR_API_KEY"
    
    from smooth import SmoothClient
    
    # The client will pick up the API key from the environment variable
    client = SmoothClient()
    

Usage

Synchronous Client

The SmoothClient is ideal for scripts and applications that don't require asynchronous operations.

Running a Task and Waiting for the Result

The run method returns a TaskHandle. You can use the result() method on this handle to wait for the task to complete and get its final state.

from smooth import SmoothClient
from smooth.models import ApiError, TimeoutError

with SmoothClient() as client:
    try:
        # The run method returns a handle to the task immediately
        task_handle = client.run(
            task="Go to https://www.google.com and search for 'Smooth SDK'",
            device="desktop",
            enable_recording=True
        )
        print(f"Task submitted with ID: {task_handle.id}")
        print(f"Live view available at: {task_handle.live_url}")

        # The result() method waits for the task to complete
        completed_task = task_handle.result()
        
        if completed_task.status == "done":
            print("Task Result:", completed_task.output)
            print(f"View recording at: {completed_task.recording_url}")
        else:
            print("Task Failed:", completed_task.output)
            
    except TimeoutError:
        print("The task timed out.")
    except ApiError as e:
        print(f"An API error occurred: {e}")

Managing Browser Sessions

You can create, list, and delete browser sessions to maintain state (like logins) between tasks.

from smooth import SmoothClient

with SmoothClient() as client:
    # Create a new browser session
    browser_session = client.open_session()
    print("Live URL:", browser_session.live_url)
    print("Session ID:", browser_session.session_id)

    # List all browser sessions
    sessions = client.list_sessions()
    print("All Session IDs:", sessions.session_ids)

    # Delete the browser session
    client.delete_session(session_id=session_id)
    print(f"Session '{session_id}' deleted.")

Asynchronous Client

The SmoothAsyncClient is designed for use in asynchronous applications, such as those built with asyncio, to handle multiple operations concurrently without blocking.

Running a Task and Waiting for the Result

The run method returns an AsyncTaskHandle. Await the result() method on the handle to get the final task status.

import asyncio
from smooth import SmoothAsyncClient
from smooth.models import ApiError, TimeoutError

async def main():
    async with SmoothAsyncClient() as client:
        try:
            # The run method returns a handle to the task immediately
            task_handle = await client.run(
                task="Go to Github and search for \"smooth-sdk\""
            )
            print(f"Task submitted with ID: {task_handle.id}")
            print(f"Live view available at: {task_handle.live_url}")

            # The result() method waits for the task to complete
            completed_task = await task_handle.result()
            
            if completed_task.status == "done":
                print("Task Result:", completed_task.output)
            else:
                print("Task Failed:", completed_task.output)
                
        except TimeoutError:
            print("The task timed out.")
        except ApiError as e:
            print(f"An API error occurred: {e}")

if __name__ == "__main__":
    asyncio.run(main())

MCP Server (AI Assistant Integration)

The Smooth SDK includes a Model Context Protocol (MCP) server that allows AI assistants like Claude Desktop or Cursor to perform browser automation tasks through natural language commands.

Installation

pip install smooth-py[mcp]

Basic Usage

from smooth.mcp import SmoothMCP

# Create and run the MCP server
mcp = SmoothMCP(api_key="your-api-key")
mcp.run()

Example MCP Usage

Once configured, you can ask your MCP client to perform browser automation:

  • "Please go to news.ycombinator.com and get the top 5 story titles"
  • "Create a browser session, log into Gmail, and check for unread emails"
  • "Go to Amazon and search for wireless headphones under $100"
  • "Fill out the contact form at example.com with test data"

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

smooth_py-0.3.0.dev20251014.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

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

smooth_py-0.3.0.dev20251014-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file smooth_py-0.3.0.dev20251014.tar.gz.

File metadata

  • Download URL: smooth_py-0.3.0.dev20251014.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for smooth_py-0.3.0.dev20251014.tar.gz
Algorithm Hash digest
SHA256 ddc8a5d0965d39f90ac987869a85766aa9eb04c087acbabeb70a1b09df1832a3
MD5 77f2eab1ac9b9c11ac6a7dbe86a19d2d
BLAKE2b-256 eb1ac854af56081b41bb1e6f6e5d8e120905858cf758a00a545a79622f37aaed

See more details on using hashes here.

Provenance

The following attestation bundles were made for smooth_py-0.3.0.dev20251014.tar.gz:

Publisher: publish-dev.yaml on circlemind-ai/smooth-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 smooth_py-0.3.0.dev20251014-py3-none-any.whl.

File metadata

File hashes

Hashes for smooth_py-0.3.0.dev20251014-py3-none-any.whl
Algorithm Hash digest
SHA256 77f59d9c753647307dbc9c9970ae5669d42127cc5a719fa124f2d5ac44a4bfa5
MD5 a43d4d1297c0a20f423e45162a6564f2
BLAKE2b-256 274bdff74dfb24528e0abad8cc0cb10047715578073cd2d4eb9580d468f5a10f

See more details on using hashes here.

Provenance

The following attestation bundles were made for smooth_py-0.3.0.dev20251014-py3-none-any.whl:

Publisher: publish-dev.yaml on circlemind-ai/smooth-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