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

Add refresh token support for Azure AD OAuth provider #1599

Open
wants to merge 10 commits into
base: main
Choose a base branch
from

Conversation

SigveSjovold
Copy link

Description

This PR adds support for handling refresh tokens in the Azure AD OAuth provider. This enables applications to maintain long-term access to Azure AD resources without requiring users to re-authenticate.

Changes

  • Added refresh token retrieval in get_token method
  • Store refresh token in provider instance
  • Include refresh token in user metadata
  • Added offline_access scope to enable refresh token support

Testing

I have tested these changes by:

  • Authenticating with Azure AD
  • Verifying refresh token is properly retrieved
  • Confirming refresh token is accessible in user metadata

- Store refresh token from OAuth response in provider instance
- Add refresh token to user metadata in get_user_info method
- Enable offline_access scope to receive refresh tokens

This enhancement allows applications to persist refresh tokens
for maintaining long-term access to Azure AD resources.
@dosubot dosubot bot added size:XS This PR changes 0-9 lines, ignoring generated files. auth Pertaining to authentication. backend Pertains to the Python backend. labels Dec 20, 2024
@hayescode
Copy link
Contributor

@SigveSjovold nice PR! Can you add this to the AzureHybrid class as well?

@dosubot dosubot bot added size:S This PR changes 10-29 lines, ignoring generated files. and removed size:XS This PR changes 0-9 lines, ignoring generated files. labels Jan 8, 2025
@SigveSjovold
Copy link
Author

@hayescode Thanks! Added it now.

@dokterbob
Copy link
Collaborator

The code looks good to me, but I am not working with Azure so not really in a position to test it.

It would be amazing to have feedback from someone else before merging.

@hayescode Any chance you could give this one a go?

@hayescode
Copy link
Contributor

The code looks good to me, but I am not working with Azure so not really in a position to test it.

It would be amazing to have feedback from someone else before merging.

@hayescode Any chance you could give this one a go?

@dokterbob works great for me using Azure Hybrid authentication. It adds a new key to user.metadata called 'refresh_token'.

@cl.oauth_callback
def login(
    provider_id: str,
    token: str,
    raw_user_data: Dict[str, str],
    default_user: cl.User,
    id_token: Optional[str],
) -> Optional[cl.PersistedUser]:
    print("Default User Metadata:")
    for key, value in default_user.metadata.items():
        print(f"{key}: {value}")

image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
auth Pertaining to authentication. backend Pertains to the Python backend. size:S This PR changes 10-29 lines, ignoring generated files.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants