Skip to content
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

Error while trying to use JwtTokenValidation.authenticate_request #2114

Open
Loprock opened this issue May 26, 2024 · 11 comments
Open

Error while trying to use JwtTokenValidation.authenticate_request #2114

Loprock opened this issue May 26, 2024 · 11 comments
Labels
bug Indicates an unexpected problem or an unintended behavior. needs-triage The issue has just been created and it has not been reviewed by the team.

Comments

@Loprock
Copy link

Loprock commented May 26, 2024

Github issues should be used for bugs and feature requests. Use Stack Overflow for general "how-to" questions.

Version

botbuilder-schema==4.11.0
botframework-connector==4.11.0

Describe the bug

Using python.
After using the following request 'JwtTokenValidation.authenticate_request' we started getting the error:
[Errno Unauthorized. Invalid AppId passed on token: ] b*******-4***-4***-8***-a***********
this issue started occurring from ~March 2024

To Reproduce

Steps to reproduce the behavior:
the whole flow is represented in the code snippet. after the main init we try to setup a webhook which is failing

Expected behavior

we want the auth to get approved and manage to communicate

Screenshots

If applicable, add screenshots to help explain your problem.

Additional context

adding a code snippet to show the flow (only relevant for this issue)

 class MicrosoftTeamsMainloop(FrameworkMainloop):
    def __init__(self, config):
        super().__init__(config)
        self.client = MicrosoftTeamsClient(config.bot_id, config.app_password)
        self.user_cache = TeamsUsersCache(self.client)
        self.app = Flask(__name__)
        self.setup_webhook_app()
        self._maybe_setup_global_proxy_for_process()

    def setup_webhook_app(self):
        @self.app.route("/", methods=["POST"])
        def webhook():
            # pass on the flask global request object
            return self.handle_post(request)

    def authenticate_webhook(self, current_request: Request, activity: Activity):
        logger = get_algobot_logger()
        loop = asyncio.new_event_loop()
        try:
            loop.run_until_complete(
                JwtTokenValidation.authenticate_request(
                    activity,
                    current_request.headers.get("Authorization"),
                    self.credential_provider,
                )
            )
            return True
        except Exception as e:
            logger.error('exception {} thrown while trying to authenticate webhook.'.format(e))
            return False
        finally:
            loop.close()

@Loprock Loprock added bug Indicates an unexpected problem or an unintended behavior. needs-triage The issue has just been created and it has not been reviewed by the team. labels May 26, 2024
@tracyboehrer
Copy link
Member

@Loprock That error indicates the token the bot received does not contain the correct audience claim. The expectation is that the audience claim matches the bots AppId. Is 4.11.0 correct? That was released in Nov 2020. If accurate, this is ually because the config for the bot is wrong.

@Loprock
Copy link
Author

Loprock commented Jun 19, 2024

The config was correct.. i verified it multiple times. but the issue persists

@tracyboehrer
Copy link
Member

As a start, I would recommend updating to the latest released version, and review what changed around March. But if you've been using this bot without changes, and it started happening in March, this would lead to some other change outside the bot happening.

@Loprock
Copy link
Author

Loprock commented Jun 19, 2024

Tried doing it on multiple bots, each with a different AppId, getting the same error every time, with the new AppId in the logs.
getting the exact same error - > [Errno Unauthorized. Invalid AppId passed on token: ]
I can try and upgrade the whole project but the code I'm using didn't change since it was written as far as I can tell from what I saw in the repo (the whole Auth section)

@tracyboehrer
Copy link
Member

The exact cause is the 'aud' claim in the token the bot received doesn't match the bots appId in config. This is part of token validation. If your bot hasn't changed then this is a config issue elsewhere. Did your Azure resources change? If you run the bot in debug, and break in your app.py, 'messages' function. Take the token in the 'Authorization' header and decode it (search for 'JWT token decoder'). You'll be able to see what 'aud' claim is being sent.

@Loprock
Copy link
Author

Loprock commented Jun 19, 2024

I actually run the bot from within a script that runs on a VM I use (as part of a bigger product), when I do that I can't really break the code in that exact spot since it's a production environment so I can only throw logs outside while it's active.
is there any way to see this 'aud' claim without a breakpoint? can I get it through a field within the class? or add it to the exception data somehow?

@tracyboehrer
Copy link
Member

You could log it. I would recommend removing that log message when done though.

@tracyboehrer
Copy link
Member

Actually... the error message should have the appId it received in it.

@Loprock
Copy link
Author

Loprock commented Jun 20, 2024

The AppID I got matches exactly to the one I have in my Azure app and the same one I set over the .conf file over the machine

@Loprock
Copy link
Author

Loprock commented Jun 20, 2024

@tracyboehrer I also saw this thread, which was magically solved one day, I think the issue isn't on my end, is it possible that it's on Microsoft's end?
#1983

@Kevv-J
Copy link

Kevv-J commented Sep 13, 2024

Hi @Loprock

I can see you're using version 4.11 where single-tenant Azure Bots are not compatible, only multi-tenant are.

I have faced a similar issue in the past where I was trying to configure my BotFramework Python SDK with single-tenant.

While creating the bot you need to select multi-tenant as shown in image
image

To verify this issue you can import this curl request into POSTMAN and test it with your Azure Bot APP_ID and APP_PASSWORD.

curl --location 'https://login.microsoftonline.com/botframework.com/oauth2/v2.0/token'
--header 'Content-Type: application/x-www-form-urlencoded'
--data-urlencode 'grant_type=client_credentials'
--data-urlencode 'scope=https://api.botframework.com/.default'
--data-urlencode 'client_id=<APP_ID>'
--data-urlencode 'client_secret=<APP_PASSWORD>'

If you're not able to generate an access token using your credentials, your Azure Bot is probably not configured properly.

You can always change your bot from single-tenant to multi-tenant if that's the underlying issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Indicates an unexpected problem or an unintended behavior. needs-triage The issue has just been created and it has not been reviewed by the team.
Projects
None yet
Development

No branches or pull requests

3 participants