|
|
@ -1,6 +1,9 @@
|
|
|
|
|
|
|
|
import 'package:adaptive_dialog/adaptive_dialog.dart';
|
|
|
|
import 'package:adaptive_page_layout/adaptive_page_layout.dart';
|
|
|
|
import 'package:adaptive_page_layout/adaptive_page_layout.dart';
|
|
|
|
|
|
|
|
import 'package:email_validator/email_validator.dart';
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:famedlysdk/famedlysdk.dart';
|
|
|
|
import 'package:famedlysdk/famedlysdk.dart';
|
|
|
|
|
|
|
|
import 'package:fluffychat/utils/get_client_secret.dart';
|
|
|
|
import 'package:fluffychat/views/ui/sign_up_password_ui.dart';
|
|
|
|
import 'package:fluffychat/views/ui/sign_up_password_ui.dart';
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:fluffychat/views/widgets/matrix.dart';
|
|
|
|
import 'package:fluffychat/views/widgets/matrix.dart';
|
|
|
@ -19,7 +22,9 @@ class SignUpPassword extends StatefulWidget {
|
|
|
|
|
|
|
|
|
|
|
|
class SignUpPasswordController extends State<SignUpPassword> {
|
|
|
|
class SignUpPasswordController extends State<SignUpPassword> {
|
|
|
|
final TextEditingController passwordController = TextEditingController();
|
|
|
|
final TextEditingController passwordController = TextEditingController();
|
|
|
|
|
|
|
|
final TextEditingController emailController = TextEditingController();
|
|
|
|
String passwordError;
|
|
|
|
String passwordError;
|
|
|
|
|
|
|
|
String emailError;
|
|
|
|
bool loading = false;
|
|
|
|
bool loading = false;
|
|
|
|
bool showPassword = true;
|
|
|
|
bool showPassword = true;
|
|
|
|
|
|
|
|
|
|
|
@ -30,7 +35,7 @@ class SignUpPasswordController extends State<SignUpPassword> {
|
|
|
|
if (passwordController.text.isEmpty) {
|
|
|
|
if (passwordController.text.isEmpty) {
|
|
|
|
setState(() => passwordError = L10n.of(context).pleaseEnterYourPassword);
|
|
|
|
setState(() => passwordError = L10n.of(context).pleaseEnterYourPassword);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
setState(() => passwordError = null);
|
|
|
|
setState(() => passwordError = emailError = null);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (passwordController.text.isEmpty) {
|
|
|
|
if (passwordController.text.isEmpty) {
|
|
|
@ -39,6 +44,31 @@ class SignUpPasswordController extends State<SignUpPassword> {
|
|
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
setState(() => loading = true);
|
|
|
|
setState(() => loading = true);
|
|
|
|
|
|
|
|
if (emailController.text.isNotEmpty) {
|
|
|
|
|
|
|
|
emailController.text = emailController.text.trim();
|
|
|
|
|
|
|
|
if (!EmailValidator.validate(emailController.text)) {
|
|
|
|
|
|
|
|
setState(() => emailError = L10n.of(context).invalidEmail);
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
matrix.currentClientSecret = getClientSecret(30);
|
|
|
|
|
|
|
|
Logs().d('Request email token');
|
|
|
|
|
|
|
|
matrix.currentThreepidCreds = await matrix.client.requestEmailToken(
|
|
|
|
|
|
|
|
emailController.text,
|
|
|
|
|
|
|
|
matrix.currentClientSecret,
|
|
|
|
|
|
|
|
1,
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
if (OkCancelResult.ok !=
|
|
|
|
|
|
|
|
await showOkCancelAlertDialog(
|
|
|
|
|
|
|
|
context: context,
|
|
|
|
|
|
|
|
message: L10n.of(context).weSentYouAnEmail,
|
|
|
|
|
|
|
|
okLabel: L10n.of(context).confirm,
|
|
|
|
|
|
|
|
cancelLabel: L10n.of(context).cancel,
|
|
|
|
|
|
|
|
)) {
|
|
|
|
|
|
|
|
matrix.currentClientSecret = matrix.currentThreepidCreds = null;
|
|
|
|
|
|
|
|
setState(() => loading = false);
|
|
|
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
final waitForLogin = matrix.client.onLoginStateChanged.stream.first;
|
|
|
|
final waitForLogin = matrix.client.onLoginStateChanged.stream.first;
|
|
|
|
await matrix.client.uiaRequestBackground((auth) => matrix.client.register(
|
|
|
|
await matrix.client.uiaRequestBackground((auth) => matrix.client.register(
|
|
|
|
username: widget.username,
|
|
|
|
username: widget.username,
|
|
|
@ -46,13 +76,22 @@ class SignUpPasswordController extends State<SignUpPassword> {
|
|
|
|
initialDeviceDisplayName: PlatformInfos.clientName,
|
|
|
|
initialDeviceDisplayName: PlatformInfos.clientName,
|
|
|
|
auth: auth,
|
|
|
|
auth: auth,
|
|
|
|
));
|
|
|
|
));
|
|
|
|
|
|
|
|
if (matrix.currentClientSecret != null &&
|
|
|
|
|
|
|
|
matrix.currentThreepidCreds != null) {
|
|
|
|
|
|
|
|
Logs().d('Add third party identifier');
|
|
|
|
|
|
|
|
await matrix.client.addThirdPartyIdentifier(
|
|
|
|
|
|
|
|
matrix.currentClientSecret,
|
|
|
|
|
|
|
|
matrix.currentThreepidCreds.sid,
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
await waitForLogin;
|
|
|
|
await waitForLogin;
|
|
|
|
} catch (exception) {
|
|
|
|
} catch (exception) {
|
|
|
|
setState(() => passwordError = exception.toString());
|
|
|
|
setState(() => emailError = exception.toString());
|
|
|
|
return setState(() => loading = false);
|
|
|
|
return setState(() => loading = false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
await matrix.client.onLoginStateChanged.stream
|
|
|
|
await matrix.client.onLoginStateChanged.stream
|
|
|
|
.firstWhere((l) => l == LoginState.logged);
|
|
|
|
.firstWhere((l) => l == LoginState.logged);
|
|
|
|
|
|
|
|
// tchncs.de
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
await matrix.client
|
|
|
|
await matrix.client
|
|
|
|
.setDisplayname(matrix.client.userID, widget.displayname);
|
|
|
|
.setDisplayname(matrix.client.userID, widget.displayname);
|
|
|
|