mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2025-01-12 02:32:54 +01:00
107 lines
3.3 KiB
Dart
107 lines
3.3 KiB
Dart
import 'dart:async';
|
|
|
|
import 'package:famedlysdk/famedlysdk.dart';
|
|
import 'package:fluffychat/config/app_config.dart';
|
|
import 'package:fluffychat/pages/views/sign_up_view.dart';
|
|
import 'package:fluffychat/utils/famedlysdk_store.dart';
|
|
|
|
import 'package:fluffychat/widgets/matrix.dart';
|
|
import 'package:flutter/cupertino.dart';
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:url_launcher/url_launcher.dart';
|
|
import 'package:universal_html/html.dart' as html;
|
|
|
|
class SignUp extends StatefulWidget {
|
|
@override
|
|
SignUpController createState() => SignUpController();
|
|
}
|
|
|
|
class SignUpController extends State<SignUp> {
|
|
Map<String, dynamic> _rawLoginTypes;
|
|
bool registrationSupported;
|
|
|
|
List<IdentityProvider> get identityProviders {
|
|
if (!ssoLoginSupported) return [];
|
|
final rawProviders = _rawLoginTypes.tryGetList('flows').singleWhere(
|
|
(flow) =>
|
|
flow['type'] == AuthenticationTypes.sso)['identity_providers'];
|
|
return (rawProviders as List)
|
|
.map((json) => IdentityProvider.fromJson(json))
|
|
.toList();
|
|
}
|
|
|
|
bool get passwordLoginSupported =>
|
|
Matrix.of(context)
|
|
.client
|
|
.supportedLoginTypes
|
|
.contains(AuthenticationTypes.password) &&
|
|
_rawLoginTypes
|
|
.tryGetList('flows')
|
|
.any((flow) => flow['type'] == AuthenticationTypes.password);
|
|
|
|
bool get ssoLoginSupported =>
|
|
Matrix.of(context)
|
|
.client
|
|
.supportedLoginTypes
|
|
.contains(AuthenticationTypes.sso) &&
|
|
_rawLoginTypes
|
|
.tryGetList('flows')
|
|
.any((flow) => flow['type'] == AuthenticationTypes.sso);
|
|
|
|
Future<Map<String, dynamic>> getLoginTypes() async {
|
|
_rawLoginTypes ??= await Matrix.of(context).client.request(
|
|
RequestType.GET,
|
|
'/client/r0/login',
|
|
);
|
|
if (registrationSupported == null) {
|
|
try {
|
|
await Matrix.of(context).client.register();
|
|
registrationSupported = true;
|
|
} on MatrixException catch (e) {
|
|
registrationSupported = e.requireAdditionalAuthentication ?? false;
|
|
}
|
|
}
|
|
return _rawLoginTypes;
|
|
}
|
|
|
|
static const String ssoHomeserverKey = 'sso-homeserver';
|
|
|
|
void ssoLoginAction(String id) {
|
|
if (kIsWeb) {
|
|
// We store the homserver in the local storage instead of a redirect
|
|
// parameter because of possible CSRF attacks.
|
|
Store().setItem(
|
|
ssoHomeserverKey, Matrix.of(context).client.homeserver.toString());
|
|
}
|
|
final redirectUrl = kIsWeb
|
|
? html.window.location.href
|
|
: AppConfig.appOpenUrlScheme.toLowerCase() + '://sso';
|
|
launch(
|
|
'${Matrix.of(context).client.homeserver?.toString()}/_matrix/client/r0/login/sso/redirect/${Uri.encodeComponent(id)}?redirectUrl=${Uri.encodeQueryComponent(redirectUrl)}');
|
|
}
|
|
|
|
void signUpAction() => launch(
|
|
'${Matrix.of(context).client.homeserver?.toString()}/_matrix/static/client/register');
|
|
|
|
@override
|
|
Widget build(BuildContext context) => SignUpView(this);
|
|
}
|
|
|
|
class IdentityProvider {
|
|
final String id;
|
|
final String name;
|
|
final String icon;
|
|
final String brand;
|
|
|
|
IdentityProvider({this.id, this.name, this.icon, this.brand});
|
|
|
|
factory IdentityProvider.fromJson(Map<String, dynamic> json) =>
|
|
IdentityProvider(
|
|
id: json['id'],
|
|
name: json['name'],
|
|
icon: json['icon'],
|
|
brand: json['brand'],
|
|
);
|
|
}
|