Toolkit for Persona, an agent AI system — provides modular, callable tools for dynamic function execution
Project description
Persona CLI
Persona CLI is a command-line tool for creating and managing projects that use the persona-toolkit — a modular
function-calling framework designed for agent-based systems.
This CLI helps you scaffold projects, generate tools, test them locally, and run the FastAPI server that exposes your tools via REST API.
🚀 Installation
To use the CLI, first install the persona-toolkit library (assuming it's published or available locally):
pip install persona-toolkit
Or if you're developing locally:
cd persona-toolkit/
poetry install
The CLI is exposed as:
persona-toolkit
📆 Features
init
Create a new project scaffold with Poetry and the required structure:
persona-toolkit init my-project
This will:
- Initialize a Poetry project
- Install
persona-toolkitas a dependency - Create a
tools/folder where your tools will live
add-tool
Add a new tool interactively:
persona-toolkit add-tool
You'll be prompted for a tool name. A new Python file will be created in the tools/ directory with a ready-to-edit
template including:
InputandOutputmodels (using Pydantic)- A
run()function
test-tool
Test a tool locally by manually entering its input values:
persona-toolkit test-tool echo
This will:
- Import the specified tool from the
tools/directory - Prompt for input fields
- Run the
run()function and show the output
You can use the cli to pass input values:
persona-toolkit test-tool echo --input '{"message": "Hello, World!"}'
run
Start the FastAPI server and expose your tools via HTTP:
persona-toolkit run --port 8000
You can now access:
GET /tools— list available toolsGET /tools/{tool}/schema— get tool schemaPOST /invocations— run a tool
🗂 Project Structure
my-project/
├── pyproject.toml # Poetry project config
├── tools/ # Directory for your tools
│ └── echo_test.py # Example tool
|── secret.py # Example secret validation
Each tool must define:
NAME(a str with tool name)Input(a Pydantic model)Output(a Pydantic model)run(context: AgentContext, input: Input) -> Output
💡 Example Tool
from pydantic import BaseModel, Field
from persona_toolkit.model import AgentContext
NAME = "echo"
class Input(BaseModel):
message: str = Field(description="Message to echo")
class Output(BaseModel):
message: str
def run(context: AgentContext, args: Input) -> Output:
"""
Echo the message back.
The `context` can be used to store and retrieve state across invocations.
For example, if a previous message exists in the context, it will be appended to the current message.
"""
previous_message = context.get("message")
if previous_message:
input.message = f"{previous_message} {input.message}"
context.set("message", args.message)
return Output(message=f"Echo: {args.message}")
Understanding kwargs and context
The context parameter is an instance of AgentContext, which is a dictionary-like object that provides access to the
current execution context of the tool, it includes the following keys:
project_id: The ID of the project where the tool is being executed.session_id: The ID of the current session, which can be used to track the state of the conversation or interaction.user_id: The ID of the user invoking the tool, which can be useful for personalizing responses or tracking user-specific data.
And expose a set of methods to manage the context:
get(key: str, default: Any = None): Retrieve a value from the context by key. If the key does not exist, return the default value.set(key: str, value: Any): Set a value in the context by key.delete(key: str): Delete a value from the context by key.
For example, if a tool needs to keep track of the last message sent by the user, it can store that message in the
context and retrieve it in subsequent invocations, it can be used to:
- Store intermediate results.
- Append or modify input values based on previous invocations.
- Share data across different tools in the same session.
Example of using kwargs
# tools/echo_test.py
from pydantic import BaseModel, Field
from persona_toolkit.model import AgentContext
NAME = "echo"
class Input(BaseModel):
message: str = Field(description="Message to echo")
class Output(BaseModel):
message: str
def run(context: AgentContext, args: Input) -> Output:
"""
Echo the message back.
"""
# Access primary infos from kwargs
project_id = context.project_id
session_id = context.session_id
user_id = context.user_id
# TODO: Do something with project_id, session_id, user_id
return Output(message=f"Echo: {args.message}")
ExternalToolException
The ExternalToolException is a special exception provided by the persona-toolkit to signal that a tool does not perform any internal operations but instead delegates its behavior to an external system. When this exception is raised, it generates a transaction inside the persona-core framework, which can then be handled by any external service or component responsible for managing the tool's behavior. This mechanism is particularly useful for tools that act as placeholders or triggers for external workflows, ensuring seamless integration between the persona-toolkit and external systems.
🔒 Secrets and Authentication
The persona-toolkit provides a mechanism to validate secrets using the SecretProvider. This can be used to add a basic authentication layer to your tools.
How to Configure Secrets
-
Define a Secret Validation Function
Create a function to validate the secret. It must be named
secret.pyand placed in the root of your project.from persona_toolkit.model import AgentContext def validate(secret: str, context: AgentContext, args: dict) -> bool: """Validate static secrets.""" return secret == "your-secret-key"
How Secrets Are Used
Once configured, the secret is checked by reading the x-persona-secret header from each tool request. The validation process works as follows:
- If the
x-persona-secretheader is present in the request, its value is validated using thevalidatefunction. - If the secret is valid, the request proceeds as expected.
- If the secret is invalid, the request is rejected with an appropriate error.
This mechanism ensures that tools can optionally enforce authentication while allowing unauthenticated access if no secret is provided.
💻 Local Development
To run the CLI locally, you can use the following command:
python persona_toolkit/cli.py --port 8001
You can use local tools folder to test your tools. Just make sure to set the PYTHONPATH to the root of the project:
✅ Requirements
- Python 3.10+
- Poetry
- Uvicorn (installed automatically)
📃 License
MIT License
Built for the Persona Agent System 🤖
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file persona_toolkit-1.0.36.tar.gz.
File metadata
- Download URL: persona_toolkit-1.0.36.tar.gz
- Upload date:
- Size: 11.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.11.4 Linux/6.1.79
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
30d513a07a2263fb3ae31311ad2cf567b5cf3b3172bad6b4d05b1d674170b058
|
|
| MD5 |
6427418052415422bf638b34420f78ad
|
|
| BLAKE2b-256 |
a71915bdf7dcae1e8528b406451338f7179316c6a5bb9674ea2ef52bbfa546bc
|
File details
Details for the file persona_toolkit-1.0.36-py3-none-any.whl.
File metadata
- Download URL: persona_toolkit-1.0.36-py3-none-any.whl
- Upload date:
- Size: 12.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.1.2 CPython/3.11.4 Linux/6.1.79
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
70c2113be60267f0ad7fe94727cfc8b8e09ba8acb828ed9e1119491935c0cca2
|
|
| MD5 |
bb42baf0a3951e72589fc5f658c20cee
|
|
| BLAKE2b-256 |
67e13c7b09b56f6cafe56008819875d66735470405d340e176c455951c6da98c
|