Merge pull request #54 from pangeachat/rules-migration

fix for room rules migration
This commit is contained in:
wcjord 2024-01-29 17:36:34 -05:00 committed by GitHub
commit 8af20b67be
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 28 additions and 0 deletions

View file

@ -425,5 +425,11 @@ class ChatDetailsController extends State<ChatDetails> {
bool showEditNameIcon = false;
void hoverEditNameIcon(bool hovering) =>
setState(() => showEditNameIcon = !showEditNameIcon);
@override
void initState() {
super.initState();
MatrixState.pangeaController.classController.addMissingRoomRules(roomId);
}
// Pangea#
}

View file

@ -3,9 +3,11 @@ import 'dart:developer';
import 'package:collection/collection.dart';
import 'package:fluffychat/pangea/constants/local.key.dart';
import 'package:fluffychat/pangea/constants/pangea_event_types.dart';
import 'package:fluffychat/pangea/controllers/pangea_controller.dart';
import 'package:fluffychat/pangea/extensions/client_extension.dart';
import 'package:fluffychat/pangea/extensions/pangea_room_extension.dart';
import 'package:fluffychat/pangea/models/class_model.dart';
import 'package:fluffychat/pangea/utils/class_code.dart';
import 'package:fluffychat/pangea/utils/error_handler.dart';
import 'package:flutter/foundation.dart';
@ -156,4 +158,24 @@ class ClassController extends BaseController {
// BE - check class code and if class code is correct, invite student to room
// FE - look for invite from room and automatically accept
}
Future<void> addMissingRoomRules(String? roomId) async {
if (roomId == null) return;
final Room? room = _pangeaController.matrixState.client.getRoomById(roomId);
if (room == null) return;
if (room.classSettings != null && room.pangeaRoomRules == null) {
try {
await _pangeaController.matrixState.client.setRoomStateWithKey(
roomId,
PangeaEventTypes.rules,
'',
PangeaRoomRules().toJson(),
);
} catch (err, stack) {
debugger(when: kDebugMode);
ErrorHandler.logError(e: err, s: stack);
}
}
}
}