An Agent Framework agent with a
Monty-backed CodeAct context provider hosted using the Responses protocol.
The model receives one tool (execute_code) and runs Python inside a
Monty interpreter; the registered host
tools (compute, fetch_data) are only reachable from inside the sandbox via
typed await compute(...) calls or the generic call_tool(...) fallback.
Note
agent-framework-monty is an alpha package, so the pyproject.toml
sets [tool.uv] prerelease = "allow" to let uv sync pick up the
1.0.0a* release from PyPI.
The agent uses FoundryChatClient to create a Responses client from the project
endpoint and the model deployment. The agent supports both streaming (SSE
events) and non-streaming (JSON) response modes.
See main.py for the full implementation.
MontyCodeActProvider is added to the agent via context_providers=[...]. On
every run it injects:
- An
execute_codetool that runs Python in the Monty interpreter. - Dynamic CodeAct instructions describing the available host tools and DSL.
The host tools (compute, fetch_data) are not exposed as direct agent
tools — the model can only call them from inside execute_code, either as
typed async functions (await compute(operation="multiply", a=6, b=7)) or via
the generic call_tool("compute", operation="multiply", a=6, b=7) fallback.
Code is type-checked against the host tool signatures using
ty before any tool runs.
OS-level access (filesystem, network, subprocess) is blocked inside the sandbox; the registered host tools retain full Python access.
Agent Framework's native OpenTelemetry instrumentation is enabled by setting these env vars in agent.yaml / agent.manifest.yaml:
ENABLE_INSTRUMENTATION=true— turns on the framework's span/metric/log emitters.ENABLE_SENSITIVE_DATA=true— includes prompts, tool inputs, tool outputs, and completions in telemetry. Dev/test only.
main.py wires Azure Monitor at startup:
- Reads
APPLICATIONINSIGHTS_CONNECTION_STRING(Foundry hosting injects this automatically for the project's attached Application Insights resource; set it yourself when running locally). - Calls
azure.monitor.opentelemetry.configure_azure_monitor(connection_string=...)to register Azure Monitor exporters with the global OTel tracer/meter/logger providers. - Calls
agent_framework.observability.enable_instrumentation()so Agent Framework emits itsinvoke_agent,chat,execute_tool, andexecute_codespans on those providers.
Trace linking happens automatically: the Foundry hosting layer's incoming Responses request becomes the parent span, and every framework / tool span (including the execute_code invocation that runs Monty) becomes a child via OpenTelemetry context propagation since both layers share the same global tracer provider. In Application Insights you can click any operation and see the full tree from inbound HTTP all the way down to individual compute(...) / fetch_data(...) calls inside the Monty sandbox.
This sample uses pyproject.toml + uv sync rather than the parent
README's requirements.txt flow. To run locally:
-
Install dependencies into a local virtual environment:
uv sync
-
Set the environment variables described in the parent README (Foundry project endpoint, model deployment, optional Application Insights), then start the host:
uv run python main.py
Refer to the parent README for the shared azd / Docker / invocation /
deployment guidance.
Depending on how you run the agent host, you can invoke the agent using
curl(Invoke-WebRequestin PowerShell) orazd. Please refer to the parent README for more details. Use this README for sample queries you can send to the agent.
Send a POST request to the server with a JSON body containing an "input"
field. Try queries that benefit from combining Python with multiple tool calls:
curl -X POST http://localhost:8088/responses \
-H "Content-Type: application/json" \
-d '{"input": "Fetch all users, find the admins, then multiply the count by 7. Use a single execute_code call."}'curl -X POST http://localhost:8088/responses \
-H "Content-Type: application/json" \
-d '{"input": "Compute the total price for one of every product in the products table. Use execute_code."}'The model should respond with one execute_code call whose code looks like:
users = await fetch_data(table="users")
admins = [u for u in users if u["role"] == "admin"]
result = await compute(operation="multiply", a=len(admins), b=7)
print(result)To host the agent on Foundry, follow the instructions in the Deploying the Agent to Foundry section of the README in the parent directory.