Files
agent-framework/python/samples/getting_started/agents/copilotstudio
T
Dmytro Struk e7cd03b32e Python: Added Copilot Studio Agent (#722)
* Small fix in dotnet conformance tests

* Added CopilotStudioAgent implementation

* Added examples

* Updated package README

* Small fixes

* Small improvements

* Fixed dotnet tests

* Add unit tests

* Updated tests

* Small updates

* Small test fixes

* Revert "Small test fixes"

This reverts commit 983ac44a70.

* Small fixes in documentation

* Updated test configuration

* Revert "Updated test configuration"

This reverts commit 2a16fea815.

* Small fix

* Reverted TODO item

* Small suppressions

* More fixes

* Small fixes

* Fixed tests

* Removed disallow_any_unimported rule in all packages

* Fixes
e7cd03b32e ยท 2025-09-15 23:21:07 +00:00
History
..

Copilot Studio Agent Examples

This folder contains examples demonstrating how to create and use agents with Microsoft Copilot Studio using the Agent Framework.

Prerequisites

Before running these examples, you need:

  1. Copilot Studio Environment: Access to a Microsoft Copilot Studio environment with a published copilot
  2. App Registration: An Azure AD App Registration with appropriate permissions
  3. Environment Variables: Set the following environment variables:
    • COPILOTSTUDIOAGENT__ENVIRONMENTID - Your Copilot Studio environment ID
    • COPILOTSTUDIOAGENT__SCHEMANAME - Your copilot's agent identifier/schema name
    • COPILOTSTUDIOAGENT__AGENTAPPID - Your App Registration client ID
    • COPILOTSTUDIOAGENT__TENANTID - Your Azure AD tenant ID

Examples

Example Description
copilotstudio_basic.py Basic non-streaming and streaming execution with simple questions
copilotstudio_with_explicit_settings.py Example with explicit settings and manual token acquisition

Authentication

The examples use MSAL (Microsoft Authentication Library) for authentication. The first time you run an example, you may need to complete an interactive authentication flow in your browser.

App Registration Setup

Your Azure AD App Registration should have:

  1. API Permissions:

  2. Redirect URIs:

    • For public client flows: http://localhost
    • Configure as appropriate for your authentication method
  3. Authentication:

    • Enable "Allow public client flows" if using interactive authentication

Usage Patterns

Basic Usage with Environment Variables

from agent_framework.copilotstudio import CopilotStudioAgent

# Uses environment variables for configuration
agent = CopilotStudioAgent()
result = await agent.run("What is the capital of France?")

Explicit Configuration

from agent_framework.copilotstudio import CopilotStudioAgent, acquire_token
from microsoft_agents.copilotstudio.client import ConnectionSettings, CopilotClient, PowerPlatformCloud, AgentType

# Acquire token manually
token = acquire_token(
    client_id="your-client-id",
    tenant_id="your-tenant-id"
)

# Create settings and client
settings = ConnectionSettings(
    environment_id="your-environment-id",
    agent_identifier="your-agent-schema-name",
    cloud=PowerPlatformCloud.PROD,
    copilot_agent_type=AgentType.PUBLISHED
)

client = CopilotClient(settings=settings, token=token)
agent = CopilotStudioAgent(client=client)

Troubleshooting

Common Issues

  1. Authentication Errors:

    • Verify your App Registration has correct permissions
    • Ensure environment variables are set correctly
    • Check that your tenant ID and client ID are valid
  2. Environment/Agent Not Found:

    • Verify your environment ID is correct
    • Ensure your copilot is published and the schema name is correct
    • Check that you have access to the specified environment
  3. Token Acquisition Failures:

    • Interactive authentication may require browser access
    • Corporate firewalls may block authentication flows
    • Try running with appropriate proxy settings if needed