fluffychat/lib/views/sign_up_password.dart

190 lines
6.0 KiB
Dart
Raw Normal View History

2020-01-09 22:52:27 +01:00
import 'dart:io';
import 'dart:math';
import 'package:famedlysdk/famedlysdk.dart';
import 'package:fluffychat/components/matrix.dart';
import 'package:fluffychat/utils/app_route.dart';
2020-01-14 15:53:35 +01:00
import 'package:fluffychat/views/auth_web_view.dart';
2020-01-09 22:52:27 +01:00
import 'package:flutter/material.dart';
2020-01-09 23:15:32 +01:00
import 'package:toast/toast.dart';
2020-01-09 22:52:27 +01: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) {
setState(() => passwordError = "Please enter your password.");
} else {
setState(() => passwordError = null);
}
if (passwordController.text.isEmpty) {
return;
}
try {
print("[Sign Up] Create account...");
2020-01-14 15:53:35 +01:00
setState(() => loading = true);
2020-01-14 13:21:15 +01:00
Future<LoginState> waitForLogin =
matrix.client.onLoginStateChanged.stream.first;
await matrix.client.register(
2020-01-09 22:52:27 +01:00
username: widget.username,
password: passwordController.text,
initialDeviceDisplayName: matrix.widget.clientName,
auth: auth,
);
2020-01-14 13:21:15 +01:00
await waitForLogin;
2020-01-09 22:52:27 +01:00
} on MatrixException catch (exception) {
2020-01-14 13:21:15 +01:00
if (exception.requireAdditionalAuthentication) {
print(exception.raw);
2020-01-09 23:15:32 +01:00
2020-01-14 15:53:35 +01:00
final List<String> stages = exception.authenticationFlows
.firstWhere((a) => !a.stages.contains("m.login.email.identity"))
.stages;
2020-01-17 09:18:05 +01: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 23:15:32 +01:00
_signUpAction(context, auth: {
2020-01-17 09:18:05 +01:00
"type": currentStage,
2020-01-14 13:21:15 +01:00
"session": exception.session,
2020-01-09 23:15:32 +01:00
});
2020-01-14 13:21:15 +01:00
} else {
2020-01-14 15:53:35 +01:00
await Navigator.of(context).push(
AppRoute.defaultRoute(
context,
AuthWebView(
2020-01-17 09:18:05 +01:00
currentStage,
2020-01-14 15:53:35 +01:00
exception.session,
() => _signUpAction(context, auth: {
"session": exception.session,
}),
),
),
);
2020-01-14 12:16:29 +01:00
return;
2020-01-09 23:15:32 +01:00
}
2020-01-14 13:21:15 +01:00
} else {
setState(() => passwordError = exception.errorMessage);
return setState(() => loading = false);
2020-01-09 23:15:32 +01:00
}
2020-01-14 13:21:15 +01:00
} catch (exception) {
print(exception);
setState(() => passwordError = exception.toString());
return setState(() => loading = false);
}
try {
await matrix.client.jsonRequest(
type: HTTPType.PUT,
action: "/client/r0/profile/${matrix.client.userID}/displayname",
data: {"displayname": widget.displayname},
);
} catch (exception) {
Toast.show("Could not set displayname", context, duration: 5);
}
try {
await matrix.client.setAvatar(
MatrixFile(
bytes: await widget.avatar.readAsBytes(),
path: widget.avatar.path,
),
);
} catch (exception) {
Toast.show("Could not set profile picture", context, duration: 5);
2020-01-09 23:15:32 +01:00
}
2020-01-14 15:53:35 +01:00
if (matrix.client.isLogged()) {
await Navigator.of(context).pushAndRemoveUntil(
AppRoute.defaultRoute(context, ChatListView()), (r) => false);
}
2020-01-09 22:52:27 +01:00
setState(() => loading = false);
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("Secure your account with a password"),
),
body: ListView(
padding: EdgeInsets.symmetric(
vertical: 16,
horizontal: max((MediaQuery.of(context).size.width - 600) / 2, 16)),
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(
backgroundColor: Colors.yellow,
child: Icon(Icons.lock),
),
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),
),
labelText: "Password"),
),
),
SizedBox(height: 20),
Container(
height: 50,
child: RaisedButton(
elevation: 7,
color: Theme.of(context).primaryColor,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(50),
),
child: loading
? CircularProgressIndicator()
: Text(
"Create account now",
style: TextStyle(color: Colors.white, fontSize: 16),
),
onPressed: () => loading ? null : _signUpAction(context),
),
),
],
),
);
}
}