2019-06-09 11:57:33 +00:00
|
|
|
/*
|
|
|
|
* 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 Foobar. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2019-06-12 08:04:54 +00:00
|
|
|
import 'package:famedlysdk/src/responses/ErrorResponse.dart';
|
2019-06-09 10:16:48 +00:00
|
|
|
import 'package:famedlysdk/src/Client.dart';
|
|
|
|
import 'package:famedlysdk/src/utils/MxContent.dart';
|
|
|
|
import 'package:famedlysdk/src/Room.dart';
|
|
|
|
|
2019-06-09 11:57:33 +00:00
|
|
|
/// Represents a Matrix User which may be a participant in a Matrix Room.
|
2019-06-09 10:16:48 +00:00
|
|
|
class User {
|
2019-06-11 09:13:14 +00:00
|
|
|
/// The full qualified Matrix ID in the format @username:server.abc.
|
|
|
|
final String id;
|
2019-06-09 11:57:33 +00:00
|
|
|
|
|
|
|
/// The displayname of the user if the user has set one.
|
2019-06-09 10:16:48 +00:00
|
|
|
final String displayName;
|
2019-06-09 11:57:33 +00:00
|
|
|
|
2019-06-11 09:13:14 +00:00
|
|
|
/// The membership status of the user. One of:
|
|
|
|
/// join
|
|
|
|
/// invite
|
|
|
|
/// leave
|
|
|
|
/// ban
|
|
|
|
String membership;
|
|
|
|
|
2019-06-09 11:57:33 +00:00
|
|
|
/// The avatar if the user has one.
|
2019-06-11 09:13:14 +00:00
|
|
|
MxContent avatarUrl;
|
2019-06-09 11:57:33 +00:00
|
|
|
|
2019-06-11 09:13:14 +00:00
|
|
|
/// The powerLevel of the user. Normally:
|
|
|
|
/// 0=Normal user
|
|
|
|
/// 50=Moderator
|
|
|
|
/// 100=Admin
|
|
|
|
int powerLevel = 0;
|
2019-06-09 11:57:33 +00:00
|
|
|
|
2019-06-11 09:13:14 +00:00
|
|
|
/// All users normally belong to a room.
|
2019-06-09 10:16:48 +00:00
|
|
|
final Room room;
|
|
|
|
|
2019-06-11 09:13:14 +00:00
|
|
|
@Deprecated("Use membership instead!")
|
|
|
|
String get status => membership;
|
|
|
|
|
|
|
|
@Deprecated("Use ID instead!")
|
|
|
|
String get mxid => id;
|
|
|
|
|
|
|
|
@Deprecated("Use avatarUrl instead!")
|
|
|
|
MxContent get avatar_url => avatarUrl;
|
|
|
|
|
2019-06-12 08:04:54 +00:00
|
|
|
User(
|
|
|
|
this.id, {
|
2019-06-11 09:13:14 +00:00
|
|
|
this.membership,
|
2019-06-09 10:16:48 +00:00
|
|
|
this.displayName,
|
2019-06-11 09:13:14 +00:00
|
|
|
this.avatarUrl,
|
|
|
|
this.powerLevel,
|
2019-06-09 10:16:48 +00:00
|
|
|
this.room,
|
|
|
|
});
|
|
|
|
|
2019-06-09 11:57:33 +00:00
|
|
|
/// Returns the displayname or the local part of the Matrix ID if the user
|
|
|
|
/// has no displayname.
|
2019-06-12 08:04:54 +00:00
|
|
|
String calcDisplayname() => displayName.isEmpty
|
|
|
|
? mxid.replaceFirst("@", "").split(":")[0]
|
|
|
|
: displayName;
|
2019-06-09 10:16:48 +00:00
|
|
|
|
2019-06-09 11:57:33 +00:00
|
|
|
/// Creates a new User object from a json string like a row from the database.
|
2019-06-11 09:13:14 +00:00
|
|
|
static User fromJson(Map<String, dynamic> json, Room room) {
|
2019-06-09 10:16:48 +00:00
|
|
|
return User(json['matrix_id'],
|
|
|
|
displayName: json['displayname'],
|
2019-06-11 09:13:14 +00:00
|
|
|
avatarUrl: MxContent(json['avatar_url']),
|
2019-06-11 09:48:31 +00:00
|
|
|
membership: json['membership'],
|
2019-06-11 09:53:32 +00:00
|
|
|
powerLevel: json['power_level'],
|
2019-06-11 09:13:14 +00:00
|
|
|
room: room);
|
|
|
|
}
|
|
|
|
|
2019-06-11 11:32:14 +00:00
|
|
|
/// Checks if the client's user has the permission to kick this user.
|
|
|
|
Future<bool> get canKick async {
|
|
|
|
final int ownPowerLevel = await room.client.store.getPowerLevel(room.id);
|
2019-06-12 08:04:54 +00:00
|
|
|
return ownPowerLevel > powerLevel &&
|
|
|
|
ownPowerLevel >= room.powerLevels["power_kick"];
|
2019-06-11 11:32:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/// Checks if the client's user has the permission to ban or unban this user.
|
|
|
|
Future<bool> get canBan async {
|
|
|
|
final int ownPowerLevel = await room.client.store.getPowerLevel(room.id);
|
2019-06-12 08:04:54 +00:00
|
|
|
return ownPowerLevel > powerLevel &&
|
|
|
|
ownPowerLevel >= room.powerLevels["power_ban"];
|
2019-06-11 11:32:14 +00:00
|
|
|
}
|
|
|
|
|
2019-06-11 09:13:14 +00:00
|
|
|
/// Call the Matrix API to kick this user from this room.
|
|
|
|
Future<dynamic> kick() async {
|
|
|
|
dynamic res = await room.kick(id);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Call the Matrix API to ban this user from this room.
|
|
|
|
Future<dynamic> ban() async {
|
|
|
|
dynamic res = await room.ban(id);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Call the Matrix API to unban this banned user from this room.
|
|
|
|
Future<dynamic> unban() async {
|
|
|
|
dynamic res = await room.unban(id);
|
|
|
|
return res;
|
2019-06-09 10:16:48 +00:00
|
|
|
}
|
2019-06-11 11:09:26 +00:00
|
|
|
|
2019-06-11 11:32:14 +00:00
|
|
|
/// Call the Matrix API to change the power level of this user.
|
|
|
|
Future<dynamic> setPower(int power) async {
|
|
|
|
dynamic res = await room.setPower(id, power);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
2019-06-12 11:54:04 +00:00
|
|
|
/// Returns an existing direct chat ID with this user or creates a new one.
|
2019-06-14 06:07:51 +00:00
|
|
|
/// Returns null on error.
|
|
|
|
Future<String> startDirectChat() async {
|
2019-06-11 11:09:26 +00:00
|
|
|
// Try to find an existing direct chat
|
|
|
|
String roomID = await room.client?.store.getDirectChatRoomID(id);
|
|
|
|
if (roomID != null) return roomID;
|
|
|
|
|
|
|
|
// Start a new direct chat
|
2019-06-12 10:04:52 +00:00
|
|
|
final dynamic resp = await room.client.connection
|
2019-06-12 08:04:54 +00:00
|
|
|
.jsonRequest(type: "POST", action: "/client/r0/createRoom", data: {
|
|
|
|
"invite": [id],
|
2019-06-11 11:09:26 +00:00
|
|
|
"is_direct": true,
|
|
|
|
"preset": "trusted_private_chat"
|
|
|
|
});
|
|
|
|
|
2019-06-14 06:07:51 +00:00
|
|
|
if (resp is ErrorResponse) {
|
|
|
|
room.client.connection.onError.add(resp);
|
|
|
|
return null;
|
|
|
|
}
|
2019-06-12 08:02:07 +00:00
|
|
|
|
2019-06-12 10:04:52 +00:00
|
|
|
final String newRoomID = resp["room_id"];
|
2019-06-12 08:02:07 +00:00
|
|
|
|
2019-06-14 06:07:51 +00:00
|
|
|
if (newRoomID == null) return newRoomID;
|
|
|
|
|
2019-06-12 11:58:40 +00:00
|
|
|
await Room(id: newRoomID, client: room.client).addToDirectChat(id);
|
2019-06-12 08:02:07 +00:00
|
|
|
|
2019-06-12 10:04:52 +00:00
|
|
|
return newRoomID;
|
2019-06-11 11:09:26 +00:00
|
|
|
}
|
2019-06-09 10:16:48 +00:00
|
|
|
}
|