2020-06-05 08:51:11 +00:00
|
|
|
/*
|
|
|
|
* Ansible inventory script used at Famedly GmbH for managing many hosts
|
|
|
|
* 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 'package:test/test.dart';
|
|
|
|
import 'package:olm/olm.dart' as olm;
|
|
|
|
|
|
|
|
import '../fake_client.dart';
|
|
|
|
|
|
|
|
void main() {
|
|
|
|
group('Key Manager', () {
|
|
|
|
var olmEnabled = true;
|
|
|
|
try {
|
|
|
|
olm.init();
|
|
|
|
olm.Account();
|
|
|
|
} catch (_) {
|
|
|
|
olmEnabled = false;
|
|
|
|
print('[LibOlm] Failed to load LibOlm: ' + _.toString());
|
|
|
|
}
|
|
|
|
print('[LibOlm] Enabled: $olmEnabled');
|
|
|
|
|
|
|
|
if (!olmEnabled) return;
|
|
|
|
|
|
|
|
Client client;
|
|
|
|
|
|
|
|
test('setupClient', () async {
|
|
|
|
client = await getClient();
|
|
|
|
});
|
|
|
|
|
|
|
|
test('handle new m.room_key', () async {
|
|
|
|
final validSessionId = 'ciM/JWTPrmiWPPZNkRLDPQYf9AW/I46bxyLSr+Bx5oU';
|
|
|
|
final validSenderKey = 'JBG7ZaPn54OBC7TuIEiylW3BZ+7WcGQhFBPB9pogbAg';
|
2020-06-05 08:56:51 +00:00
|
|
|
final sessionKey =
|
|
|
|
'AgAAAAAQcQ6XrFJk6Prm8FikZDqfry/NbDz8Xw7T6e+/9Yf/q3YHIPEQlzv7IZMNcYb51ifkRzFejVvtphS7wwG2FaXIp4XS2obla14iKISR0X74ugB2vyb1AydIHE/zbBQ1ic5s3kgjMFlWpu/S3FQCnCrv+DPFGEt3ERGWxIl3Bl5X53IjPyVkz65oljz2TZESwz0GH/QFvyOOm8ci0q/gceaF3S7Dmafg3dwTKYwcA5xkcc+BLyrLRzB6Hn+oMAqSNSscnm4mTeT5zYibIhrzqyUTMWr32spFtI9dNR/RFSzfCw';
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
client.encryption.keyManager.clearInboundGroupSessions();
|
|
|
|
var event = ToDeviceEvent(
|
2020-06-05 08:56:51 +00:00
|
|
|
sender: '@alice:example.com',
|
|
|
|
type: 'm.room_key',
|
|
|
|
content: {
|
|
|
|
'algorithm': 'm.megolm.v1.aes-sha2',
|
|
|
|
'room_id': '!726s6s6q:example.com',
|
|
|
|
'session_id': validSessionId,
|
|
|
|
'session_key': sessionKey,
|
|
|
|
},
|
|
|
|
encryptedContent: {
|
|
|
|
'sender_key': validSessionId,
|
|
|
|
});
|
2020-06-05 08:51:11 +00:00
|
|
|
await client.encryption.keyManager.handleToDeviceEvent(event);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getInboundGroupSession(
|
|
|
|
'!726s6s6q:example.com', validSessionId, validSenderKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
|
|
|
|
|
|
|
// now test a few invalid scenarios
|
|
|
|
|
|
|
|
// not encrypted
|
|
|
|
client.encryption.keyManager.clearInboundGroupSessions();
|
|
|
|
event = ToDeviceEvent(
|
2020-06-05 08:56:51 +00:00
|
|
|
sender: '@alice:example.com',
|
|
|
|
type: 'm.room_key',
|
|
|
|
content: {
|
|
|
|
'algorithm': 'm.megolm.v1.aes-sha2',
|
|
|
|
'room_id': '!726s6s6q:example.com',
|
|
|
|
'session_id': validSessionId,
|
|
|
|
'session_key': sessionKey,
|
|
|
|
});
|
2020-06-05 08:51:11 +00:00
|
|
|
await client.encryption.keyManager.handleToDeviceEvent(event);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getInboundGroupSession(
|
|
|
|
'!726s6s6q:example.com', validSessionId, validSenderKey) !=
|
|
|
|
null,
|
|
|
|
false);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('outbound group session', () async {
|
|
|
|
final roomId = '!726s6s6q:example.com';
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
|
|
|
var sess =
|
|
|
|
await client.encryption.keyManager.createOutboundGroupSession(roomId);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
true);
|
2020-06-05 08:51:11 +00:00
|
|
|
await client.encryption.keyManager.clearOutboundGroupSession(roomId);
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
true);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getInboundGroupSession(roomId,
|
|
|
|
sess.outboundGroupSession.session_id(), client.identityKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
// rotate after too many messages
|
|
|
|
sess.sentMessages = 300;
|
|
|
|
await client.encryption.keyManager.clearOutboundGroupSession(roomId);
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
// rotate if devices in room change
|
2020-06-05 08:56:51 +00:00
|
|
|
sess =
|
|
|
|
await client.encryption.keyManager.createOutboundGroupSession(roomId);
|
|
|
|
client.userDeviceKeys['@alice:example.com'].deviceKeys['JLAFKJWSCS']
|
|
|
|
.blocked = true;
|
2020-06-05 08:51:11 +00:00
|
|
|
await client.encryption.keyManager.clearOutboundGroupSession(roomId);
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
|
|
|
client.userDeviceKeys['@alice:example.com'].deviceKeys['JLAFKJWSCS']
|
|
|
|
.blocked = false;
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
// rotate if too far in the past
|
2020-06-05 08:56:51 +00:00
|
|
|
sess =
|
|
|
|
await client.encryption.keyManager.createOutboundGroupSession(roomId);
|
2020-06-05 08:51:11 +00:00
|
|
|
sess.creationTime = DateTime.now().subtract(Duration(days: 30));
|
|
|
|
await client.encryption.keyManager.clearOutboundGroupSession(roomId);
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
// force wipe
|
2020-06-05 08:56:51 +00:00
|
|
|
sess =
|
|
|
|
await client.encryption.keyManager.createOutboundGroupSession(roomId);
|
|
|
|
await client.encryption.keyManager
|
|
|
|
.clearOutboundGroupSession(roomId, wipe: true);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
// load from database
|
2020-06-05 08:56:51 +00:00
|
|
|
sess =
|
|
|
|
await client.encryption.keyManager.createOutboundGroupSession(roomId);
|
2020-06-05 08:51:11 +00:00
|
|
|
client.encryption.keyManager.clearOutboundGroupSessions();
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
false);
|
2020-06-05 08:51:11 +00:00
|
|
|
await client.encryption.keyManager.loadOutboundGroupSession(roomId);
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager.getOutboundGroupSession(roomId) != null,
|
|
|
|
true);
|
2020-06-05 08:51:11 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('inbound group session', () async {
|
|
|
|
final roomId = '!726s6s6q:example.com';
|
|
|
|
final sessionId = 'ciM/JWTPrmiWPPZNkRLDPQYf9AW/I46bxyLSr+Bx5oU';
|
|
|
|
final senderKey = 'JBG7ZaPn54OBC7TuIEiylW3BZ+7WcGQhFBPB9pogbAg';
|
|
|
|
final sessionContent = <String, dynamic>{
|
|
|
|
'algorithm': 'm.megolm.v1.aes-sha2',
|
|
|
|
'room_id': '!726s6s6q:example.com',
|
|
|
|
'session_id': 'ciM/JWTPrmiWPPZNkRLDPQYf9AW/I46bxyLSr+Bx5oU',
|
|
|
|
'session_key':
|
|
|
|
'AgAAAAAQcQ6XrFJk6Prm8FikZDqfry/NbDz8Xw7T6e+/9Yf/q3YHIPEQlzv7IZMNcYb51ifkRzFejVvtphS7wwG2FaXIp4XS2obla14iKISR0X74ugB2vyb1AydIHE/zbBQ1ic5s3kgjMFlWpu/S3FQCnCrv+DPFGEt3ERGWxIl3Bl5X53IjPyVkz65oljz2TZESwz0GH/QFvyOOm8ci0q/gceaF3S7Dmafg3dwTKYwcA5xkcc+BLyrLRzB6Hn+oMAqSNSscnm4mTeT5zYibIhrzqyUTMWr32spFtI9dNR/RFSzfCw'
|
|
|
|
};
|
|
|
|
client.encryption.keyManager.clearInboundGroupSessions();
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession(roomId, sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
false);
|
|
|
|
client.encryption.keyManager
|
|
|
|
.setInboundGroupSession(roomId, sessionId, senderKey, sessionContent);
|
2020-06-05 08:51:11 +00:00
|
|
|
await Future.delayed(Duration(milliseconds: 10));
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession(roomId, sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession(roomId, sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession('otherroom', sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession('otherroom', 'invalid', senderKey) !=
|
|
|
|
null,
|
|
|
|
false);
|
2020-06-05 08:51:11 +00:00
|
|
|
|
|
|
|
client.encryption.keyManager.clearInboundGroupSessions();
|
2020-06-05 08:56:51 +00:00
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession(roomId, sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
false);
|
|
|
|
await client.encryption.keyManager
|
|
|
|
.loadInboundGroupSession(roomId, sessionId, senderKey);
|
|
|
|
expect(
|
|
|
|
client.encryption.keyManager
|
|
|
|
.getInboundGroupSession(roomId, sessionId, senderKey) !=
|
|
|
|
null,
|
|
|
|
true);
|
2020-06-05 08:51:11 +00:00
|
|
|
});
|
2020-06-05 09:32:02 +00:00
|
|
|
|
|
|
|
test('dispose client', () async {
|
|
|
|
await client.dispose(closeDatabase: true);
|
|
|
|
});
|
2020-06-05 08:51:11 +00:00
|
|
|
});
|
|
|
|
}
|