This commit is contained in:
Christian Pauly 2020-01-17 09:18:05 +01:00
parent 12f60d812a
commit dbf472665a
1 changed files with 10 additions and 9 deletions

View File

@ -24,7 +24,6 @@ class _SignUpPasswordState extends State<SignUpPassword> {
String passwordError;
bool loading = false;
bool showPassword = true;
int currentStage = 0;
void _signUpAction(BuildContext context, {Map<String, dynamic> auth}) async {
MatrixState matrix = Matrix.of(context);
@ -43,11 +42,6 @@ class _SignUpPasswordState extends State<SignUpPassword> {
setState(() => loading = true);
Future<LoginState> waitForLogin =
matrix.client.onLoginStateChanged.stream.first;
if (auth == null) {
currentStage = 0;
} else {
currentStage++;
}
await matrix.client.register(
username: widget.username,
password: passwordController.text,
@ -63,9 +57,16 @@ class _SignUpPasswordState extends State<SignUpPassword> {
.firstWhere((a) => !a.stages.contains("m.login.email.identity"))
.stages;
if (stages[currentStage] == "m.login.dummy") {
final String currentStage =
exception.completedAuthenticationFlows == null
? stages.first
: stages.firstWhere((stage) =>
!exception.completedAuthenticationFlows.contains(stage) ??
true);
if (currentStage == "m.login.dummy") {
_signUpAction(context, auth: {
"type": stages[currentStage],
"type": currentStage,
"session": exception.session,
});
} else {
@ -73,7 +74,7 @@ class _SignUpPasswordState extends State<SignUpPassword> {
AppRoute.defaultRoute(
context,
AuthWebView(
stages[currentStage],
currentStage,
exception.session,
() => _signUpAction(context, auth: {
"session": exception.session,