mirror of
https://github.com/microsoft/agent-framework.git
synced 2026-06-16 21:04:09 +08:00
cc0cfaaac8
* Python: fix OpenAI Azure routing and provider samples Prefer OpenAI when OPENAI_API_KEY is present unless Azure is explicitly requested. Clarify constructor docs, keep deprecated Azure wrappers compatible with stricter settings validation, and refresh the provider samples and tests to use the current client patterns. Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * fix bandit * Python: align OpenAI embedding Azure routing Extend the shared OpenAI-vs-Azure routing and credential behavior to the embedding client, add Azure embedding regression coverage, and refresh the embedding samples to use the generic client path. Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: fix embedding client pyright check Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: thin OpenAI embedding wrapper Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: document embedding overload routing Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: fix callable OpenAI key routing Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: fix Azure credential routing tests Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: address OpenAI review feedback Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: narrow Azure routing markers Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: refine OpenAI model fallback order Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: narrow Azure deployment docs Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: remove embedding routing wording Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: run embedding Azure integration tests Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * changed variable name * Python: expand OpenAI package README Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * clarified readme * Python: fix Azure OpenAI integration setup Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * Python: correct Azure integration env mapping Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com> * updated code to fix int tests * test updates * test fix * fix test setup * updates to tests and setup * remove openai assistants int tests * improvements in int tests * fix env var * fix env vars * fix azure responses test * trigger actions --------- Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
108 lines
3.2 KiB
Python
108 lines
3.2 KiB
Python
# Copyright (c) Microsoft. All rights reserved.
|
|
|
|
import asyncio
|
|
import base64
|
|
import tempfile
|
|
import urllib.request as urllib_request
|
|
from pathlib import Path
|
|
|
|
from agent_framework import Agent, Content
|
|
from agent_framework.openai import OpenAIChatClient
|
|
from dotenv import load_dotenv
|
|
|
|
# Load environment variables from .env file
|
|
load_dotenv()
|
|
|
|
"""
|
|
OpenAI Chat Client Image Generation Example
|
|
|
|
This sample demonstrates how to generate images using OpenAI's DALL-E models
|
|
through the Chat Client. Image generation capabilities enable AI to create visual content from text,
|
|
making it ideal for creative applications, content creation, design prototyping,
|
|
and automated visual asset generation.
|
|
"""
|
|
|
|
|
|
def save_image(output: Content) -> None:
|
|
"""Save the generated image to a temporary directory.
|
|
|
|
This sample is simplified, usually a async aware storing method would be better.
|
|
"""
|
|
filename = "generated_image.webp"
|
|
file_path = Path(tempfile.gettempdir()) / filename
|
|
|
|
data_bytes: bytes | None = None
|
|
uri = getattr(output, "uri", None)
|
|
|
|
if isinstance(uri, str):
|
|
if ";base64," in uri:
|
|
try:
|
|
b64 = uri.split(";base64,", 1)[1]
|
|
data_bytes = base64.b64decode(b64)
|
|
except Exception:
|
|
data_bytes = None
|
|
else:
|
|
try:
|
|
data_bytes = urllib_request.urlopen(uri).read()
|
|
except Exception:
|
|
data_bytes = None
|
|
|
|
if data_bytes is None:
|
|
raise RuntimeError("Image output present but could not retrieve bytes.")
|
|
|
|
with open(file_path, "wb") as f:
|
|
f.write(data_bytes)
|
|
|
|
print(f"Image downloaded and saved to: {file_path}")
|
|
|
|
|
|
async def main() -> None:
|
|
print("=== OpenAI Chat Image Generation Agent Example ===")
|
|
|
|
# Create an agent with customized image generation options
|
|
client = OpenAIChatClient()
|
|
agent = Agent(
|
|
client=client,
|
|
instructions="You are a helpful AI that can generate images.",
|
|
tools=[
|
|
client.get_image_generation_tool(
|
|
size="1024x1024",
|
|
output_format="webp",
|
|
)
|
|
],
|
|
)
|
|
|
|
query = "Generate a black furry cat."
|
|
print(f"User: {query}")
|
|
print("Generating image with parameters: 1024x1024 size, WebP format...")
|
|
|
|
result = await agent.run(query)
|
|
print(f"Agent: {result.text}")
|
|
|
|
# Find and save the generated image
|
|
image_saved = False
|
|
for message in result.messages:
|
|
for content in message.contents:
|
|
if content.type == "image_generation_tool_result" and content.outputs:
|
|
output = content.outputs
|
|
if isinstance(output, Content) and output.uri:
|
|
save_image(output)
|
|
image_saved = True
|
|
elif isinstance(output, list):
|
|
for out in output:
|
|
if isinstance(out, Content) and out.uri:
|
|
save_image(out)
|
|
image_saved = True
|
|
break
|
|
if image_saved:
|
|
break
|
|
if image_saved:
|
|
break
|
|
|
|
if not image_saved:
|
|
print("No image data found in the agent response.")
|
|
|
|
|
|
if __name__ == "__main__":
|
|
asyncio.run(main())
|