-
Notifications
You must be signed in to change notification settings - Fork 205
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Issue with Oauth2 redirect upon signing in on Declarative Agent with existing API plugin #12722
Comments
Hi, @michellekeoy
The redirect URI is used to receive the token and will automatically close after consent, it will not return to any chat/agent. Regarding your issue, it seems the Copilot API call failed with the token, so that it ask your consent again. This could be due to an invalid scope or other reasons. Could you share your OAuth registration info so I can take a look? |
@SLdragon Noted. Yes, where can I share that info in a secure place? Why did the API call fail if Okta has returned a success and I receive a 200? Scope is correct or else the access token would not have been granted. |
Do you mean that your API service responded with a 200 status? Can you check the API call logs in the service backend to see if it received the correct token and parameters? |
@SLdragon Yes, checked, correct. It is successful. It may be clearer if we hop on a call to debug instead, as I'm not sure I can send sensitive information in this forum. My timezone EST though |
OK, you can find me on Teams rentu@microsoft.com |
@SLdragon Requested you on Teams |
Just talked with @michellekeoy , seems the issue is related to the declarative agent backend, and still investigate the root cause |
Spoke to @jofri-msft on this issue. MS currently sends client credentials in both header and body. The auth provider Okta's token endpoint supports only one method of client credentials delivery at a time, which leads to the following error message: Requesting if MS would be able to make the client authentication method configurable between header vs POST request similar to OpenAI GPT config. |
Thank you @michellekeoy for your feedback. We will track this issue and inform you of any backend updates. |
I have stumbled upon a similar issue. In my case, OAuth token provider is Miro. Declarative agent goes through the token retrieval process, I see in the network tab eventually a call to store the retrieved auth token, but the call to my locally running service (behind ngrok) never comes. Just out of curiosity I've tried using the OAuth client generated by this exercise - https://learn.microsoft.com/en-us/training/modules/copilot-declarative-agent-api-plugin-auth/5-exercise-integrate-api-plugin-oauth - and it worked. Could it be that at current stage only some specific token or scope formats are supported? |
@ilia-beliaev-miro, the problem may same as michellekeoy mentioned, token exchanged step failed, so you will never receive the calls to your locally running service. If you can access Miro backend, maybe you can take a look token exchange logs to check whether there are some error logs~ |
@SLdragon I see token retrieval also going on as planned and resulting in 200 OK. I also see the code getting seemingly stored (see screenshot). Just after the token request nothing happens. |
OK, you can decode the response token to check whether scope and other properties is expected. |
@SLdragon Even if the scope were not correct, the request would still have been issued, right? It would potentially later fail on the receiving side, but that' not what I observe. The request after the OAuth is never executed. |
Hi, @ilia-beliaev-miro , If you could check the logs from your identity provider for the token exchange/consent steps, it would help identify the problem. |
Hi @michellekeoy, I'm facing the same issue that you have mentioned. I built a copilot agent that calls MS Graph API with OAuth enabled. Until yesterday, it was working but now when I sign in, the login popup is blank and show below error. Error: 'Something went wrong. Please try again.' Timestamp: '2024-12-20T02:42:54.7026739+00:00' RequestId: 'NoContext-f97f6cc5-8a87-41fb-9ae7-b769e95eb*'** |
Hi, @swamisnawale , please take look about this comment to check whether you Microsoft Entra App has already setup identify URI correctly: |
Yes, I've checked and it is working now. Thanks @SLdragon Also, is there someone with whom I can connect with because I have few questions to ask regarding copilot agent development. I found MS Copilot forum but it is specifically for Copilot studios |
Hi @SLdragon, the OAuth token retrieval also goes through my ngrok proxy so I can see request ending up in 200 OK HTTP response code as well as the request body. The response looks like this: {
"user_id": "00000000",
"expires_in": 0,
"team_id": "00000000",
"token_type": "bearer",
"access_token": "my_token...",
"scope": ""
} The scope field is empty as in the current scenario I don't need any scopes. |
Hello @swamisnawale, I come from Teams Toolkit product team, happy to connect! This is my LI profile: www.linkedin.com/in/junjieli0909 feel free to send me your contact information privately and I will reach out |
For the future reference, I've figured out what the problem was in my case: the OAuth token endpoint returned the |
Hi, @ilia-beliaev-miro , thanks for your information about the problem. According to my understanding, there is no official documentation stating that expires_in = 0 indicates a token never expires. It may be better to set expires_in to a large number to indicate a long-lived token for compatibility. |
Describe the bug
Context: I am creating a custom declarative agent with an existing API plugin using OAuth2 authorization code flow.
What has been done so far:
OAUTH2_CONFIGURATION_ID
has been added to manifest.If your OAuth provider requires specifying allowed redirect URIs when registering your app, include https://teams.microsoft.com/api/platform/v1.0/oAuthRedirect in the allowed redirect URIs.
Side note: I am confused about this redirect URI specifically. How does it know which chat/agent to return to?/authorize
and/token
endpoints are hit and successfully grant an access token)To Reproduce
Not sure if you would be able to reproduce the behaviour, but I am happy to connect and show you on a call.
Expected behavior
I would assume we get redirected to the copilot chat with my custom declarative agent.
Screenshots
Screenshots have sensitive information, but they don't provide much. I have described to best ability above, let me know if you need more details!
VS Code Extension Information (please complete the following information):
CLI Information (please complete the following information):
The text was updated successfully, but these errors were encountered: