Skip to main content

Microsoft Agents M365 Copilot Python SDK (V1.0)

Project description

Microsoft 365 Copilot APIs V1 Python Client Library

Integrate the Microsoft 365 Copilot APIs into your Python application!

Installation

To install the client libraries via PyPi:

pip install microsoft-agents-m365copilot

Create a Copilot APIs client and make an API call

The following code example shows how to create an instance of a Microsoft 365 Copilot APIs client with an authentication provider in the supported languages. The authentication provider handles acquiring access tokens for the application. Many different authentication providers are available for each language and platform. The different authentication providers support different client scenarios. For details about which provider and options are appropriate for your scenario, see Choose an Authentication Provider.

The example also shows how to make a call to the Microsoft 365 Copilot Retrieval API. To call this API, you first need to create a request object and then run the POST method on the request.

The client ID is the app registration ID that is generated when you register your app in the Azure portal.

  1. Create a .env file with the following values:

    TENANT_ID = "YOUR_TENANT_ID"
    CLIENT_ID = "YOUR_CLIENT_ID"
    

    Note:

    Your tenant must have a Microsoft 365 Copilot license.

  2. Create a main.py file with the following snippet:

    import asyncio
    import os
    from datetime import datetime
    
    from azure.identity import DeviceCodeCredential
    from dotenv import load_dotenv
    from kiota_abstractions.api_error import APIError
    
    from microsoft_agents_m365copilot import AgentsM365CopilotServiceClient
    from microsoft_agents_m365copilot.generated.copilot.retrieval.retrieval_post_request_body import (
        RetrievalPostRequestBody,
    )
    from microsoft_agents_m365copilot.generated.models.retrieval_data_source import RetrievalDataSource
    
    load_dotenv()
    
    TENANT_ID = os.getenv("TENANT_ID")
    CLIENT_ID = os.getenv("CLIENT_ID")
    
    # Define a proper callback function that accepts all three parameters
    def auth_callback(verification_uri: str, user_code: str, expires_on: datetime):
        print(f"\nTo sign in, use a web browser to open the page {verification_uri}")
        print(f"Enter the code {user_code} to authenticate.")
        print(f"The code will expire at {expires_on}")
    
    # Create device code credential with correct callback
    credentials = DeviceCodeCredential(
        client_id=CLIENT_ID,
        tenant_id=TENANT_ID,
        prompt_callback=auth_callback
    )
    
    # Use the Graph API V1 endpoint explicitly
    scopes = ['https://graph.microsoft.com/.default']
    client = AgentsM365CopilotBetaServiceClient(credentials=credentials, scopes=scopes)
    
    # Make sure the base URL is set to V1
    client.request_adapter.base_url = "https://graph.microsoft.com/v1.0"
    
    async def retrieve():
        try:
            # Print the URL being used
            print(f"Using API base URL: {client.request_adapter.base_url}\n")
            
            # Create the retrieval request body
            retrieval_body = RetrievalPostRequestBody()
            retrieval_body.data_source = RetrievalDataSource.SharePoint
            retrieval_body.query_string = "What is the latest in my organization?"
            
            # Try more parameters that might be required
            # retrieval_body.maximum_number_of_results = 10
            
            # Make the API call
            print("Making retrieval API request...")
            retrieval = await client.copilot.retrieval.post(retrieval_body)
            
            # Process the results
            if retrieval and hasattr(retrieval, "retrieval_hits"):
                print(f"Received {len(retrieval.retrieval_hits)} hits")
                for r in retrieval.retrieval_hits:
                    print(f"Web URL: {r.web_url}\n")
                    for extract in r.extracts:
                        print(f"Text:\n{extract.text}\n")
            else:
                print(f"Retrieval response structure: {dir(retrieval)}")
        except APIError as e:
            print(f"Error: {e.error.code}: {e.error.message}")
            if hasattr(e, 'error') and hasattr(e.error, 'inner_error'):
                print(f"Inner error details: {e.error.inner_error}")
            raise e
    
    
    # Run the async function
    asyncio.run(retrieve())
    
  3. If successful, you should get a list of retrievalHits collection.

Issues

To view or log issues, see issues.

Contributing

This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.

When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repos using our CLA.

This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.

Trademarks

This project may contain trademarks or logos for projects, products, or services. Authorized use of Microsoft trademarks or logos is subject to and must follow Microsoft's Trademark & Brand Guidelines. Use of Microsoft trademarks or logos in modified versions of this project must not cause confusion or imply Microsoft sponsorship. Any use of third-party trademarks or logos are subject to those third-party's policies.

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

microsoft_agents_m365copilot-1.6.0.tar.gz (41.4 kB view details)

Uploaded Source

Built Distribution

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

microsoft_agents_m365copilot-1.6.0-py3-none-any.whl (142.9 kB view details)

Uploaded Python 3

File details

Details for the file microsoft_agents_m365copilot-1.6.0.tar.gz.

File metadata

File hashes

Hashes for microsoft_agents_m365copilot-1.6.0.tar.gz
Algorithm Hash digest
SHA256 cc3ccc74d937c52c2690806004248d2adbe20b05ce2c7b0d0149318e0645bf6a
MD5 376cc19af0729fedc346333b0171c2b7
BLAKE2b-256 91bdf7f6094f2a7c5c4e587672360159b1595e7003fedde8f02ba3cc0ad9d177

See more details on using hashes here.

File details

Details for the file microsoft_agents_m365copilot-1.6.0-py3-none-any.whl.

File metadata

File hashes

Hashes for microsoft_agents_m365copilot-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 fe112d8cf4cca982ee64c186a4c2a5818122da5cdcafe70b789814b8fa502157
MD5 6c1495bf89a042e99850f7a0a7a04ac2
BLAKE2b-256 06ae51c01a3243d3d25749efcb487c136eae4cb61627f668fb48b755d6ec2000

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