1
0
mirror of https://github.com/matrix-org/matrix-js-sdk.git synced 2025-08-09 10:22:46 +03:00

Save the completed flows (#389)

Otherwise we get very confused and go back to the start when given
a response with no flows etc.

Only copy data if none of the 3 fields are defined, since that's
more the situation we actually want to handle.
This commit is contained in:
David Baker
2017-03-15 11:15:35 +00:00
committed by Richard van der Hoff
parent 49be37dcf9
commit 8b4b0e0d39

View File

@@ -272,10 +272,16 @@ InteractiveAuth.prototype = {
// doesn't look like an interactive-auth failure. fail the whole lot.
throw error;
}
// if the error didn't come with flows or session ID,
// copy over the ones we have
if (!error.data.flows) error.data.flows = self._data.flows;
if (!error.data.session) error.data.session = self._data.session;
// if the error didn't come with flows, completed flows or session ID,
// copy over the ones we have. Synapse sometimes sends responses without
// any UI auth data (eg. when polling for email validation, if the email
// has not yet been validated). This appears to be a Synapse bug, which
// we workaround here.
if (!error.data.flows && !error.data.completed && !error.data.session) {
error.data.flows = self._data.flows;
error.data.completed = self._data.completed;
error.data.session = self._data.session;
}
self._data = error.data;
self._startNextAuthStage();
},