-
Notifications
You must be signed in to change notification settings - Fork 204
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
[Bug] System browser process on Linux writes junk to standard out/error #675
Comments
Can't reproduce. I installed a Chrome (Version 122.0.6261.94 (Official Build) (64-bit)) on my Debian-variation just now, set it as default, and then launch an equivalent script using MSAL 1.27 (the browser launching mechanism has remained the same in last many MSAL versions). See no extra output.
How bad was it? If it is just a one-liner "Opening in existing browser session", it sounds not that bad, even though it was not necessarily desirable.
Even if we could, where shall we redirect those stdout/stderr to? Wouldn't we still want them to be visible if a subprocess really wants to show some info/error? |
Did you open Chrome first before starting this process? You need an existing Chrome process open to see this issue.
It's problematic because you need to do the following in python. The issue with the hack is it blocks off stdout redirection from the Chrome process which leads to other output on stderr (not bad but annoying/confusing to users).
In this case, we would have stdout, stderr file arguments. If a developer wants to directly output, they can pass |
Yes, I double checked. I have a Chrome window opened. Still see no output on stdour/stderr. Could it be a Chrome version relative thing? Speaking about that, is Chrome's stdout/stderr behavior configurable? Also, what Linux distro are you using? Other than WSL, MSAL is just using Python built-in webbrowser.open("url"). Not sure whether it provides much control on capturing stdout/stderr.
That hack can be a good tactical fix, because it controls the blast radius. BTW, you are working on a Git Credential Msal project? Sounds cool! Starred. :-) Also a FYI, I just recently start using Git Credential OAuth, and it works reasonably well. |
Hi, I did not give good reproduction steps earlier.
You can then test with
Sorry for missing this detail.
It has a problem when implementing a git credential helper and working with
The problem with git credential oauth is that it depends on the git server also being the identity provider. It does not work for the use case where you solely use Microsoft for the identity provider of your bare git server running cgit like the linux kernel project. More details in my blog. |
Haven't fully followed your steps yet. But, a quick test indeed indicates that Chrome would output 2 dozen lines of logs into stdout/stderr, when and only when there was NO Chrome window already running. So, that is kind of the opposite of what you observed. That being said, if it is about
Thanks! I'll definitely give it a close look soon. |
So I am just using this to manually reproduce what other people have reported to me on different Linux distributions. This is not just a one off use case since I have users for my credential helper already. Anyways, here is the full demo fwiw. I could try getting their environment details and sharing them here. I myself use Firefox.
|
In that case, there are lots of setups to cater for. MSAL itself is not exactly in the browser configuration business. Just thinking out aloud. Could your script unset the BROWSER env var (if at all possible), before calling MSAL? |
So I agree configuring a browser in general is unreasonable. I think having control over the stdout and stderr of a subprocess spawned by library is reasonable design in general. I am pretty sure on their systems BROWSER is not set but xdg-open is invoked somehow. |
This is how MSAL Python currently opens a browser. It is already too complicated than we would like it to be. If you can provide some hints or links on how to configure their stdout and stderr, I'll see what we can do here. |
Sure, I actually do not mind even making a PR for this. I mostly wanted to gauge interest before investing any time. |
@rayluo - please remember to add "Public Client" / "Confidential Client" tags, as we monitor these bug / feature request queues separately. |
Describe the bug
When using msal-python to acquire tokens interactively, the stdout/stderr of the launched browser process is not redirected (at least on Linux). This leads to the browser output interfering with the program's stdout for any programming consuming msal-python in this manner.
A similar issue was already opened and resolved for the dotnet equivalent.
AzureAD/microsoft-authentication-library-for-dotnet#2427
To Reproduce
Steps to reproduce the behavior:
Expected behavior
No prints from the launched browser program should be propogated to the user (unless the user explicitly requests to see them/configures to suppress them).
What you see instead
The output
Opening in existing browser session
.The MSAL Python version you are using
Paste the output of this
python -c "import msal; print(msal.__version__)"
❯ python -c "import msal; print(msal.__version__)" 1.24.1
The text was updated successfully, but these errors were encountered: