2020-01-09 21:52:27 +00:00
|
|
|
import 'dart:io';
|
|
|
|
import 'dart:math';
|
|
|
|
|
|
|
|
import 'package:famedlysdk/famedlysdk.dart';
|
|
|
|
import 'package:fluffychat/components/matrix.dart';
|
2020-01-20 12:46:39 +00:00
|
|
|
import 'package:fluffychat/i18n/i18n.dart';
|
2020-01-09 21:52:27 +00:00
|
|
|
import 'package:fluffychat/utils/app_route.dart';
|
2020-01-14 14:53:35 +00:00
|
|
|
import 'package:fluffychat/views/auth_web_view.dart';
|
2020-01-09 21:52:27 +00:00
|
|
|
import 'package:flutter/material.dart';
|
2020-01-09 22:15:32 +00:00
|
|
|
import 'package:toast/toast.dart';
|
2020-01-09 21:52:27 +00:00
|
|
|
|
|
|
|
import 'chat_list.dart';
|
|
|
|
|
|
|
|
class SignUpPassword extends StatefulWidget {
|
|
|
|
final File avatar;
|
|
|
|
final String username;
|
|
|
|
final String displayname;
|
|
|
|
const SignUpPassword(this.username, {this.avatar, this.displayname});
|
|
|
|
@override
|
|
|
|
_SignUpPasswordState createState() => _SignUpPasswordState();
|
|
|
|
}
|
|
|
|
|
|
|
|
class _SignUpPasswordState extends State<SignUpPassword> {
|
|
|
|
final TextEditingController passwordController = TextEditingController();
|
|
|
|
String passwordError;
|
|
|
|
bool loading = false;
|
|
|
|
bool showPassword = true;
|
|
|
|
|
|
|
|
void _signUpAction(BuildContext context, {Map<String, dynamic> auth}) async {
|
|
|
|
MatrixState matrix = Matrix.of(context);
|
|
|
|
if (passwordController.text.isEmpty) {
|
2020-01-20 12:46:39 +00:00
|
|
|
setState(() => passwordError = I18n.of(context).pleaseEnterYourPassword);
|
2020-01-09 21:52:27 +00:00
|
|
|
} else {
|
|
|
|
setState(() => passwordError = null);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (passwordController.text.isEmpty) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
2020-01-14 14:53:35 +00:00
|
|
|
setState(() => loading = true);
|
2020-01-14 12:21:15 +00:00
|
|
|
Future<LoginState> waitForLogin =
|
|
|
|
matrix.client.onLoginStateChanged.stream.first;
|
|
|
|
await matrix.client.register(
|
2020-01-09 21:52:27 +00:00
|
|
|
username: widget.username,
|
|
|
|
password: passwordController.text,
|
|
|
|
initialDeviceDisplayName: matrix.widget.clientName,
|
|
|
|
auth: auth,
|
|
|
|
);
|
2020-01-14 12:21:15 +00:00
|
|
|
await waitForLogin;
|
2020-01-09 21:52:27 +00:00
|
|
|
} on MatrixException catch (exception) {
|
2020-01-14 12:21:15 +00:00
|
|
|
if (exception.requireAdditionalAuthentication) {
|
2020-01-14 14:53:35 +00:00
|
|
|
final List<String> stages = exception.authenticationFlows
|
|
|
|
.firstWhere((a) => !a.stages.contains("m.login.email.identity"))
|
|
|
|
.stages;
|
|
|
|
|
2020-01-17 08:18:05 +00:00
|
|
|
final String currentStage =
|
|
|
|
exception.completedAuthenticationFlows == null
|
|
|
|
? stages.first
|
|
|
|
: stages.firstWhere((stage) =>
|
|
|
|
!exception.completedAuthenticationFlows.contains(stage) ??
|
|
|
|
true);
|
|
|
|
|
|
|
|
if (currentStage == "m.login.dummy") {
|
2020-01-09 22:15:32 +00:00
|
|
|
_signUpAction(context, auth: {
|
2020-01-17 08:18:05 +00:00
|
|
|
"type": currentStage,
|
2020-01-14 12:21:15 +00:00
|
|
|
"session": exception.session,
|
2020-01-09 22:15:32 +00:00
|
|
|
});
|
2020-01-14 12:21:15 +00:00
|
|
|
} else {
|
2020-01-14 14:53:35 +00:00
|
|
|
await Navigator.of(context).push(
|
|
|
|
AppRoute.defaultRoute(
|
|
|
|
context,
|
|
|
|
AuthWebView(
|
2020-01-17 08:18:05 +00:00
|
|
|
currentStage,
|
2020-01-14 14:53:35 +00:00
|
|
|
exception.session,
|
|
|
|
() => _signUpAction(context, auth: {
|
|
|
|
"session": exception.session,
|
|
|
|
}),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
2020-01-14 11:16:29 +00:00
|
|
|
return;
|
2020-01-09 22:15:32 +00:00
|
|
|
}
|
2020-01-14 12:21:15 +00:00
|
|
|
} else {
|
|
|
|
setState(() => passwordError = exception.errorMessage);
|
|
|
|
return setState(() => loading = false);
|
2020-01-09 22:15:32 +00:00
|
|
|
}
|
2020-01-14 12:21:15 +00:00
|
|
|
} catch (exception) {
|
2020-01-26 11:17:54 +00:00
|
|
|
debugPrint(exception);
|
2020-01-14 12:21:15 +00:00
|
|
|
setState(() => passwordError = exception.toString());
|
|
|
|
return setState(() => loading = false);
|
|
|
|
}
|
2020-01-29 09:36:30 +00:00
|
|
|
await matrix.client.onLoginStateChanged.stream
|
|
|
|
.firstWhere((l) => l == LoginState.logged);
|
2020-01-14 12:21:15 +00:00
|
|
|
try {
|
2020-01-27 10:12:33 +00:00
|
|
|
await matrix.client.setDisplayname(widget.displayname);
|
2020-01-14 12:21:15 +00:00
|
|
|
} catch (exception) {
|
2020-01-20 12:46:39 +00:00
|
|
|
Toast.show(I18n.of(context).couldNotSetDisplayname, context, duration: 5);
|
2020-01-14 12:21:15 +00:00
|
|
|
}
|
2020-01-29 09:36:30 +00:00
|
|
|
if (widget.avatar != null) {
|
|
|
|
try {
|
|
|
|
await matrix.client.setAvatar(
|
|
|
|
MatrixFile(
|
|
|
|
bytes: await widget.avatar.readAsBytes(),
|
|
|
|
path: widget.avatar.path,
|
|
|
|
),
|
|
|
|
);
|
|
|
|
} catch (exception) {
|
|
|
|
Toast.show(I18n.of(context).couldNotSetAvatar, context, duration: 5);
|
|
|
|
}
|
2020-01-14 14:53:35 +00:00
|
|
|
}
|
2020-01-29 09:36:30 +00:00
|
|
|
await Navigator.of(context).pushAndRemoveUntil(
|
|
|
|
AppRoute.defaultRoute(context, ChatListView()), (r) => false);
|
2020-01-09 21:52:27 +00:00
|
|
|
setState(() => loading = false);
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context) {
|
|
|
|
return Scaffold(
|
|
|
|
appBar: AppBar(
|
2020-01-20 12:46:39 +00:00
|
|
|
title: Text(I18n.of(context).secureYourAccountWithAPassword),
|
2020-01-09 21:52:27 +00:00
|
|
|
),
|
|
|
|
body: ListView(
|
|
|
|
padding: EdgeInsets.symmetric(
|
2020-01-27 09:59:03 +00:00
|
|
|
horizontal: max((MediaQuery.of(context).size.width - 600) / 2, 0)),
|
2020-01-09 21:52:27 +00:00
|
|
|
children: <Widget>[
|
|
|
|
Container(
|
|
|
|
height: 150,
|
|
|
|
color: Theme.of(context).secondaryHeaderColor,
|
|
|
|
child: Center(
|
|
|
|
child: Icon(
|
|
|
|
Icons.vpn_key,
|
|
|
|
color: Theme.of(context).primaryColor,
|
|
|
|
size: 40,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
ListTile(
|
|
|
|
leading: CircleAvatar(
|
2020-01-27 09:59:03 +00:00
|
|
|
backgroundColor: Colors.white,
|
|
|
|
child: Icon(Icons.lock, color: Theme.of(context).primaryColor),
|
2020-01-09 21:52:27 +00:00
|
|
|
),
|
|
|
|
title: TextField(
|
|
|
|
controller: passwordController,
|
|
|
|
obscureText: !showPassword,
|
|
|
|
autofocus: true,
|
|
|
|
autocorrect: false,
|
|
|
|
onSubmitted: (t) => _signUpAction(context),
|
|
|
|
decoration: InputDecoration(
|
|
|
|
hintText: "****",
|
|
|
|
errorText: passwordError,
|
|
|
|
suffixIcon: IconButton(
|
|
|
|
icon: Icon(
|
|
|
|
showPassword ? Icons.visibility_off : Icons.visibility),
|
|
|
|
onPressed: () =>
|
|
|
|
setState(() => showPassword = !showPassword),
|
|
|
|
),
|
2020-01-20 12:46:39 +00:00
|
|
|
labelText: I18n.of(context).password),
|
2020-01-09 21:52:27 +00:00
|
|
|
),
|
|
|
|
),
|
|
|
|
SizedBox(height: 20),
|
|
|
|
Container(
|
|
|
|
height: 50,
|
2020-01-27 09:59:03 +00:00
|
|
|
padding: EdgeInsets.symmetric(horizontal: 12),
|
2020-01-09 21:52:27 +00:00
|
|
|
child: RaisedButton(
|
|
|
|
elevation: 7,
|
|
|
|
color: Theme.of(context).primaryColor,
|
|
|
|
shape: RoundedRectangleBorder(
|
2020-01-27 09:59:03 +00:00
|
|
|
borderRadius: BorderRadius.circular(6),
|
2020-01-09 21:52:27 +00:00
|
|
|
),
|
|
|
|
child: loading
|
|
|
|
? CircularProgressIndicator()
|
|
|
|
: Text(
|
2020-01-27 09:59:03 +00:00
|
|
|
I18n.of(context).createAccountNow.toUpperCase(),
|
2020-01-09 21:52:27 +00:00
|
|
|
style: TextStyle(color: Colors.white, fontSize: 16),
|
|
|
|
),
|
|
|
|
onPressed: () => loading ? null : _signUpAction(context),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|