Merge branch 'identifier-feature-implement-string-extension' into 'master'

[Identifier] Implement string extension

See merge request famedly/famedlysdk!183
This commit is contained in:
Christian Pauly 2020-02-10 11:37:15 +00:00
commit 38f7bf9476
6 changed files with 80 additions and 5 deletions

View file

@ -29,6 +29,7 @@ export 'package:famedlysdk/src/sync/user_update.dart';
export 'package:famedlysdk/src/utils/device_keys_list.dart'; export 'package:famedlysdk/src/utils/device_keys_list.dart';
export 'package:famedlysdk/src/utils/matrix_exception.dart'; export 'package:famedlysdk/src/utils/matrix_exception.dart';
export 'package:famedlysdk/src/utils/matrix_file.dart'; export 'package:famedlysdk/src/utils/matrix_file.dart';
export 'package:famedlysdk/src/utils/matrix_id_string_extension.dart';
export 'package:famedlysdk/src/utils/mx_content.dart'; export 'package:famedlysdk/src/utils/mx_content.dart';
export 'package:famedlysdk/src/utils/open_id_credentials.dart'; export 'package:famedlysdk/src/utils/open_id_credentials.dart';
export 'package:famedlysdk/src/utils/profile.dart'; export 'package:famedlysdk/src/utils/profile.dart';

View file

@ -421,7 +421,7 @@ class Client {
Future<List<User>> loadFamedlyContacts() async { Future<List<User>> loadFamedlyContacts() async {
List<User> contacts = []; List<User> contacts = [];
Room contactDiscoveryRoom = Room contactDiscoveryRoom =
this.getRoomByAlias("#famedlyContactDiscovery:${userID.split(":")[1]}"); this.getRoomByAlias("#famedlyContactDiscovery:${userID.domain}");
if (contactDiscoveryRoom != null) { if (contactDiscoveryRoom != null) {
contacts = await contactDiscoveryRoom.requestParticipants(); contacts = await contactDiscoveryRoom.requestParticipants();
} else { } else {

View file

@ -213,7 +213,7 @@ class Room {
if (canonicalAlias != null && if (canonicalAlias != null &&
canonicalAlias.isNotEmpty && canonicalAlias.isNotEmpty &&
canonicalAlias.length > 3) { canonicalAlias.length > 3) {
return canonicalAlias.substring(1, canonicalAlias.length).split(":")[0]; return canonicalAlias.localpart;
} }
List<String> heroes = []; List<String> heroes = [];
if (mHeroes != null && if (mHeroes != null &&

View file

@ -103,9 +103,7 @@ class User extends Event {
/// Returns the displayname or the local part of the Matrix ID if the user /// Returns the displayname or the local part of the Matrix ID if the user
/// has no displayname. /// has no displayname.
String calcDisplayname() => (displayName == null || displayName.isEmpty) String calcDisplayname() => (displayName == null || displayName.isEmpty)
? (stateKey != null ? (stateKey != null ? stateKey.localpart : "Unknown User")
? stateKey.replaceFirst("@", "").split(":")[0]
: "Unknown User")
: displayName; : displayName;
/// Call the Matrix API to kick this user from this room. /// Call the Matrix API to kick this user from this room.

View file

@ -0,0 +1,26 @@
extension MatrixIdExtension on String {
static const Set<String> VALID_SIGILS = {"@", "!", "#", "\$", "+"};
static const int MAX_LENGTH = 255;
bool get isValidMatrixId {
if (this.length > MAX_LENGTH) return false;
if (!VALID_SIGILS.contains(this.substring(0, 1))) {
return false;
}
final List<String> parts = this.substring(1).split(":");
if (parts.length != 2 || parts[0].isEmpty || parts[1].isEmpty) {
return false;
}
return true;
}
String get sigil => isValidMatrixId ? this.substring(0, 1) : null;
String get localpart =>
isValidMatrixId ? this.substring(1).split(":").first : null;
String get domain => isValidMatrixId ? this.substring(1).split(":")[1] : null;
bool equals(String other) => this.toLowerCase() == other.toLowerCase();
}

View file

@ -0,0 +1,50 @@
/*
* Copyright (c) 2019 Zender & Kurtz GbR.
*
* Authors:
* Christian Pauly <krille@famedly.com>
* Marcel Radzio <mtrnord@famedly.com>
*
* This file is part of famedlysdk.
*
* famedlysdk is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* famedlysdk is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with famedlysdk. If not, see <http://www.gnu.org/licenses/>.
*/
import 'package:test/test.dart';
import 'package:famedlysdk/src/utils/matrix_id_string_extension.dart';
void main() {
/// All Tests related to the ChatTime
group("Matrix ID String Extension", () {
test("Matrix ID String Extension", () async {
final String mxId = "@test:example.com";
expect(mxId.isValidMatrixId, true);
expect("#test:example.com".isValidMatrixId, true);
expect("!test:example.com".isValidMatrixId, true);
expect("+test:example.com".isValidMatrixId, true);
expect("\$test:example.com".isValidMatrixId, true);
expect("test:example.com".isValidMatrixId, false);
expect("@testexample.com".isValidMatrixId, false);
expect("@:example.com".isValidMatrixId, false);
expect("@test:".isValidMatrixId, false);
expect(mxId.sigil, "@");
expect("#test:example.com".sigil, "#");
expect("!test:example.com".sigil, "!");
expect("+test:example.com".sigil, "+");
expect("\$test:example.com".sigil, "\$");
expect(mxId.localpart, "test");
expect(mxId.domain, "example.com");
});
});
}