Skip to main content

Python SDK for creating, managing, and deploying AI agents in Salesforce

Project description

Salesforce AgentForce SDK

PyPI version Python 3.11+ License

A Python SDK for creating, managing, and deploying AI agents and prompt templates in Salesforce.

Introduction

The Salesforce AgentForce SDK provides a programmatic interface to Salesforce's Agent infrastructure, allowing developers to define and interact with agents using Python code. It also includes tools for generating and managing prompt templates with Salesforce field mappings.

Installation

pip install agentforce-sdk

Dependencies

The SDK has several dependencies that will be installed automatically, including:

  • requests: For HTTP requests to Salesforce APIs
  • simple-salesforce: For Salesforce authentication and API access
  • aiohttp: For asynchronous HTTP operations, especially in deployment tools
  • jsonschema: For validating agent and template configurations
  • python-dotenv: For environment variable management
  • openai: For LLM API integration

If you encounter import errors when using deployment features, ensure that aiohttp is properly installed:

pip install aiohttp>=3.8.0

Features

  • Create and manage AI agents in Salesforce
  • Generate and manage prompt templates with Salesforce field mappings
  • Support for various Salesforce field types and relationships
  • Automatic Apex class generation for related data queries
  • Template tuning for different LLM models
  • Multiple formats for defining agents (JSON, nested directory, modular directory)
  • MCP server for HTTP-based integration

Documentation

Comprehensive documentation for the SDK is available in the docs directory:

  • API Documentation: Detailed documentation for all SDK components, classes, and methods.
  • JSON Schemas: JSON schemas for validating agent definitions in various formats.

Examples

Prompt Template Examples

The SDK provides several examples demonstrating prompt template functionality:

Basic Template Generation

The examples/generate_prompt_template_example.py script demonstrates how to generate a prompt template with Salesforce field mappings:

python examples/generate_prompt_template_example.py \
  --username your_username \
  --password your_password \
  --security-token your_security_token \
  --output_dir templates \
  --model gpt-4

This will:

  1. Connect to your Salesforce org
  2. Generate a prompt template with appropriate field mappings
  3. Save the template and any generated Apex classes to the specified output directory

Template with Apex Actions

The examples/generate_template_with_apex_example.py script shows how to create a template that includes Apex invocable actions:

python examples/generate_template_with_apex_example.py \
  --username your_username \
  --password your_password \
  --security-token your_security_token \
  --output_dir templates \
  --model gpt-4

This example demonstrates:

  1. Creating a template for account opportunity analysis
  2. Including Apex invocable actions for data manipulation
  3. Generating necessary Apex classes for the actions
  4. Saving the complete template with action mappings

Template Tuning

The examples/tune_prompt_template_example.py script demonstrates how to tune an existing template for different LLM models:

python examples/tune_prompt_template_example.py \
  --username your_username \
  --password your_password \
  --security-token your_security_token \
  --template-path templates/my_template.json \
  --output_dir tuned_templates \
  --model gpt-4

This example shows how to:

  1. Load an existing template
  2. Optimize it for specific LLM models
  3. Add explicit instructions and validation rules
  4. Save the enhanced template

Template Deployment

The examples/deploy_prompt_template_example.py script shows how to deploy a template to Salesforce:

python examples/deploy_prompt_template_example.py \
  --username your_username \
  --password your_password \
  --security-token your_security_token \
  --template-path templates/my_template.json \
  --validate-only

This example demonstrates:

  1. Loading a template from a JSON file
  2. Validating the template before deployment
  3. Deploying the template and associated components
  4. Monitoring deployment status and handling errors

Arguments

Common arguments across examples:

  • --username: Your Salesforce username (required)
  • --password: Your Salesforce password (required)
  • --security-token: Your Salesforce security token (optional)
  • --output_dir: Directory to save generated files (default varies by example)
  • --model: Model to use for generation/tuning (default: 'gpt-4')

Example-specific arguments:

  • --template-path: Path to an existing template JSON file (for tuning and deployment)
  • --validate-only: Only validate the deployment without actually deploying (deployment example)
  • --description: Additional context for template tuning (tuning example)

Output

The examples generate various outputs depending on their function:

  • Template JSON files with field mappings
  • Generated Apex classes for actions and queries
  • Deployment status and validation results
  • Detailed logs of operations performed

Agent Examples

The examples directory contains additional sample code for agent functionality:

Quick Start

from agent_sdk import Agentforce
from agent_sdk.core.auth import BasicAuth
from agent_sdk.utils.prompt_templates.prompt_template_utils import PromptTemplateUtils

# Initialize authentication
auth = BasicAuth(username="your_username", password="your_password")

# Initialize the client
client = Agentforce(auth=auth)

# Generate a prompt template
prompt_utils = PromptTemplateUtils(client.sf)
template = prompt_utils.generate_prompt_template(
    name="Account Health Analysis",
    description="Generate a health analysis for an account",
    output_dir="templates",
    model="gpt-4"
)

print(f"Template saved to: {template}")

Project Structure

agent-sdk/
├── agent_sdk/
│   ├── core/
│   │   ├── agentforce.py
│   │   ├── auth.py
│   │   ├── base.py
│   │   └── prompt_template_utils.py
│   └── models/
│       ├── agent.py
│       └── prompt_template.py
├── examples/
│   ├── generate_prompt_template_example.py
│   └── [other examples]
└── README.md

Development

You'll require poetry >= 2.0 for dependency management. To install it, follow the instructions on their website.

To contribute to the project:

  1. Clone the repository
  2. Create a virtual environment and install dependencies: poetry install
  3. Run tests: pytest

License

This project is licensed under the Apache 2.0 License - see the LICENSE file for details.

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

agentforce_sdk-0.2.0.tar.gz (78.9 kB view details)

Uploaded Source

Built Distribution

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

agentforce_sdk-0.2.0-py3-none-any.whl (104.8 kB view details)

Uploaded Python 3

File details

Details for the file agentforce_sdk-0.2.0.tar.gz.

File metadata

  • Download URL: agentforce_sdk-0.2.0.tar.gz
  • Upload date:
  • Size: 78.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.1

File hashes

Hashes for agentforce_sdk-0.2.0.tar.gz
Algorithm Hash digest
SHA256 a4b53cbfa72028361c58c4d4e2a7d90e41439047cc4d2d5b0b9cdfea9ab492a4
MD5 2310225e827b003092e47bf510a98271
BLAKE2b-256 354b4819caf559d691e5e060be0669043127d5a6929294f7fc789cf6ed2ba3a4

See more details on using hashes here.

File details

Details for the file agentforce_sdk-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: agentforce_sdk-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 104.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.1

File hashes

Hashes for agentforce_sdk-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3ed28bac57953cb2622b546f31c57281f8b2a49909fb335657868d5da7a72567
MD5 39284a8fb1d284011f46e05288f8e6fb
BLAKE2b-256 daa110367fd0d5b437fee33ea570d30813d730b2ea504dff733be1f8a538ce4a

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