-
Notifications
You must be signed in to change notification settings - Fork 343
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
Silent authentication call results in unexpected network call #1174
Comments
This is current expected behavior when starting a new process. We will look into how we can optimize this. If you have one process the result is stored in a process level static. |
Is there a possibility to store this kind of configuration information in a similar way to tokens ( |
@mjcheetham - yes, this is our current approach but I need to figure out how we do expiration (i.e. 24h expiry? more? ) and refresh (i.e. refresh when the info is missing or expired, or also try to refresh whenever a non silent request is made). Other proposals are:
|
@bgavrilMS my expectation is that if the token hasn't expired yet then there should no need to go out and update anything. If you have to do this then can it be done in a way that doesn't impact startup, especially on mobile? How often is this information expected to change? |
@stevehurcombe , I've added the scenarios for mobile as well. |
#1144 sounds like it's a closely related issue. |
yes, indeed. They all are related to the fact that MSAL does instance discovery (to discover the aliases of issuers across clouds), and this takes time, and prevents offline scenarios. |
A large part of the work for this has been shipped in 4.1 - AcquireTokenSilent (with a valid AT in cache) and GetAccounts are fixed. |
@bgavrilMS still seems much the same:
This is a Samsung S7 Edge. Maybe we need some more pieces?? Steve |
Thanks for checking @stevehurcombe . All this work is cross platform, so it should work for Xamarin. Are you saying that in your case a discovery call was made? |
Not necessarily. If I'm offline then the login process seems quicker. If I'm online then it's still as slow as before, even though the token has not expired. |
I see what you're saying. I can see a spike of ~600ms when it says "Looking up a token in the cache". This is understandable because it will access the token cache (on Android, we store in Shared Preferences, which are just files). I can't explain the 1s difference at the end though, after it found a valid token and it returns a token. Will need to investigate (that APK log message from Xamarin is strange) - I opened another issue for this #1256 Thanks for validating that we're not performing an extra network call. That should at least save some 400ms. |
I'll close this so that it's clear that is has been done in 4.1.
|
So to confirm this wont work for the Azure B2C case because the authority host is something like this: {tenantName}.b2clogin.com? If so, then I take it there would have to be a code adjustment to support the the vast array of URLs rather than just the provided list from this comment: #1174 (comment) |
@ckrempp91 - please open a new issue if needed, this has been fixed and closed more than 1 year ago. ATS should not make a network call unless required, e.g. if the access token expired (typically after 1h). |
Which Version of MSAL are you using ?
MSAL.NET 3.0.8
Platform
net45
What authentication flow has the issue?
Is this a new or existing app?
This is a new app or experiment.
Repro
Please see the following command line app which is a simplified model of how we are using MSAL:
https://gist.github.com/mjcheetham/d3faa36325beef54527a5434e6445ddb
The specific offending code is line 80:
Running the application once will perform an interactive authentication and store the AT/RT in a cache at
%UserProfile%\.gettoken\msal.cache
(using MSAL's cache extensibility APIs).Running the application a second time will perform a silent authentication for the same user as previous.
Expected behavior
No web call is performed (unless the access token has expired).
Actual behavior
An instance discovery web call is made.
Possible Solution
Unknown.
Additional context/ Logs / Screenshots
Fiddler shows the following request:
..with the following response:
The text was updated successfully, but these errors were encountered: