84 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
			
		
		
	
	
			84 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Dart
		
	
	
	
/*
 | 
						|
 *   Famedly Matrix SDK
 | 
						|
 *   Copyright (C) 2020 Famedly GmbH
 | 
						|
 *
 | 
						|
 *   This program is free software: you can redistribute it and/or modify
 | 
						|
 *   it under the terms of the GNU Affero General Public License as
 | 
						|
 *   published by the Free Software Foundation, either version 3 of the
 | 
						|
 *   License, or (at your option) any later version.
 | 
						|
 *
 | 
						|
 *   This program 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 Affero General Public License for more details.
 | 
						|
 *
 | 
						|
 *   You should have received a copy of the GNU Affero General Public License
 | 
						|
 *   along with this program.  If not, see <https://www.gnu.org/licenses/>.
 | 
						|
 */
 | 
						|
 | 
						|
import 'package:famedlysdk/famedlysdk.dart';
 | 
						|
import './encryption.dart';
 | 
						|
import './utils/key_verification.dart';
 | 
						|
 | 
						|
class KeyVerificationManager {
 | 
						|
  final Encryption encryption;
 | 
						|
  Client get client => encryption.client;
 | 
						|
 | 
						|
  KeyVerificationManager(this.encryption);
 | 
						|
 | 
						|
  final Map<String, KeyVerification> _requests = {};
 | 
						|
 | 
						|
  Future<void> cleanup() async {
 | 
						|
    for (final entry in _requests.entries) {
 | 
						|
      var dispose = entry.value.canceled ||
 | 
						|
          entry.value.state == KeyVerificationState.done ||
 | 
						|
          entry.value.state == KeyVerificationState.error;
 | 
						|
      if (!dispose) {
 | 
						|
        dispose = !(await entry.value.verifyActivity());
 | 
						|
      }
 | 
						|
      if (dispose) {
 | 
						|
        entry.value.dispose();
 | 
						|
        _requests.remove(entry.key);
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  void addRequest(KeyVerification request) {
 | 
						|
    if (request.transactionId == null) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    _requests[request.transactionId] = request;
 | 
						|
  }
 | 
						|
 | 
						|
  Future<void> handleToDeviceEvent(ToDeviceEvent event) async {
 | 
						|
    if (!event.type.startsWith('m.key.verification')) {
 | 
						|
      return;
 | 
						|
    }
 | 
						|
    // we have key verification going on!
 | 
						|
    final transactionId = KeyVerification.getTransactionId(event.content);
 | 
						|
    if (transactionId == null) {
 | 
						|
      return; // TODO: send cancel with unknown transaction id
 | 
						|
    }
 | 
						|
    if (_requests.containsKey(transactionId)) {
 | 
						|
      await _requests[transactionId].handlePayload(event.type, event.content);
 | 
						|
    } else {
 | 
						|
      final newKeyRequest =
 | 
						|
          KeyVerification(encryption: encryption, userId: event.sender);
 | 
						|
      await newKeyRequest.handlePayload(event.type, event.content);
 | 
						|
      if (newKeyRequest.state != KeyVerificationState.askAccept) {
 | 
						|
        // okay, something went wrong (unknown transaction id?), just dispose it
 | 
						|
        newKeyRequest.dispose();
 | 
						|
      } else {
 | 
						|
        _requests[transactionId] = newKeyRequest;
 | 
						|
        client.onKeyVerificationRequest.add(newKeyRequest);
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  void dispose() {
 | 
						|
    for (final req in _requests.values) {
 | 
						|
      req.dispose();
 | 
						|
    }
 | 
						|
  }
 | 
						|
}
 |