authPrompt: Fix hang if user types password really fast
It's possible for a user to type their password so quickly that GDM hasn't even had time to ask for the password yet, much less have time to process the answer. In that situation, we tuck the user response away as _preemptiveAnswer, and pass it along to GDM when GDM is finally ready for it. The problem is, there's a bug in the code, where we send null for the service name in the answer, instead of the right service name (say "gdm-password"). This commit addresses the bug by making sure we don't pass the answer along, until the service name is properly set in _queryingService. To ensure that, answering query (answerQuery) based on _preemptiveAnswer has been shifted right below this._queryingService = serviceName; https://bugzilla.gnome.org/show_bug.cgi?id=737586
This commit is contained in:
parent
0241ec7f13
commit
256b8e0a50
@ -193,17 +193,15 @@ const AuthPrompt = new Lang.Class({
|
|||||||
},
|
},
|
||||||
|
|
||||||
_onAskQuestion: function(verifier, serviceName, question, passwordChar) {
|
_onAskQuestion: function(verifier, serviceName, question, passwordChar) {
|
||||||
if (this._preemptiveAnswer) {
|
|
||||||
if (this._queryingService)
|
|
||||||
this._userVerifier.answerQuery(this._queryingService, this._preemptiveAnswer);
|
|
||||||
this._preemptiveAnswer = null;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this._queryingService)
|
if (this._queryingService)
|
||||||
this.clear();
|
this.clear();
|
||||||
|
|
||||||
this._queryingService = serviceName;
|
this._queryingService = serviceName;
|
||||||
|
if (this._preemptiveAnswer) {
|
||||||
|
this._userVerifier.answerQuery(this._queryingService, this._preemptiveAnswer);
|
||||||
|
this._preemptiveAnswer = null;
|
||||||
|
return;
|
||||||
|
}
|
||||||
this.setPasswordChar(passwordChar);
|
this.setPasswordChar(passwordChar);
|
||||||
this.setQuestion(question);
|
this.setQuestion(question);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user