use of org.matrix.androidsdk.crypto.data.MXUsersDevicesMap in project matrix-android-sdk by matrix-org.
the class CryptoRestClient method claimOneTimeKeysForUsersDevices.
/**
* Claim one-time keys.
*
* @param usersDevicesKeyTypesMap a list of users, devices and key types to retrieve keys for.
* @param callback the asynchronous callback
*/
public void claimOneTimeKeysForUsersDevices(final MXUsersDevicesMap<String> usersDevicesKeyTypesMap, final ApiCallback<MXUsersDevicesMap<MXKey>> callback) {
final String description = "claimOneTimeKeysForUsersDevices";
HashMap<String, Object> params = new HashMap<>();
params.put("one_time_keys", usersDevicesKeyTypesMap.getMap());
try {
mApi.claimOneTimeKeysForUsersDevices(params, new RestAdapterCallback<KeysClaimResponse>(description, mUnsentEventsManager, callback, new RestAdapterCallback.RequestRetryCallBack() {
@Override
public void onRetry() {
claimOneTimeKeysForUsersDevices(usersDevicesKeyTypesMap, callback);
}
}) {
@Override
public void success(KeysClaimResponse keysClaimResponse, Response response) {
onEventSent();
HashMap<String, Map<String, MXKey>> map = new HashMap();
if (null != keysClaimResponse.oneTimeKeys) {
for (String userId : keysClaimResponse.oneTimeKeys.keySet()) {
Map<String, Map<String, Map<String, Object>>> mapByUserId = keysClaimResponse.oneTimeKeys.get(userId);
HashMap<String, MXKey> keysMap = new HashMap<>();
for (String deviceId : mapByUserId.keySet()) {
try {
keysMap.put(deviceId, new MXKey(mapByUserId.get(deviceId)));
} catch (Exception e) {
Log.e(LOG_TAG, "## claimOneTimeKeysForUsersDevices : fail to create a MXKey " + e.getMessage());
}
}
if (keysMap.size() != 0) {
map.put(userId, keysMap);
}
}
}
callback.onSuccess(new MXUsersDevicesMap<>(map));
}
});
} catch (Throwable t) {
callback.onUnexpectedError(new Exception(t));
}
}
use of org.matrix.androidsdk.crypto.data.MXUsersDevicesMap in project matrix-android-sdk by matrix-org.
the class MXMegolmEncryption method getDevicesInRoom.
/**
* Get the list of devices which can encrypt data to.
* This method must be called in getDecryptingThreadHandler() thread.
*
* @param userIds the user ids whose devices must be checked.
* @param callback the asynchronous callback
*/
private void getDevicesInRoom(final List<String> userIds, final ApiCallback<MXUsersDevicesMap<MXDeviceInfo>> callback) {
// We are happy to use a cached version here: we assume that if we already
// have a list of the user's devices, then we already share an e2e room
// with them, which means that they will have announced any new devices via
// an m.new_device.
mCrypto.getDeviceList().downloadKeys(userIds, false, new ApiCallback<MXUsersDevicesMap<MXDeviceInfo>>() {
@Override
public void onSuccess(final MXUsersDevicesMap<MXDeviceInfo> devices) {
mCrypto.getEncryptingThreadHandler().post(new Runnable() {
@Override
public void run() {
boolean encryptToVerifiedDevicesOnly = mCrypto.getGlobalBlacklistUnverifiedDevices() || mCrypto.isRoomBlacklistUnverifiedDevices(mRoomId);
final MXUsersDevicesMap<MXDeviceInfo> devicesInRoom = new MXUsersDevicesMap<>();
final MXUsersDevicesMap<MXDeviceInfo> unknownDevices = new MXUsersDevicesMap<>();
List<String> userIds = devices.getUserIds();
for (String userId : userIds) {
List<String> deviceIds = devices.getUserDeviceIds(userId);
for (String deviceId : deviceIds) {
MXDeviceInfo deviceInfo = devices.getObject(deviceId, userId);
if (mCrypto.warnOnUnknownDevices() && deviceInfo.isUnknown()) {
// The device is not yet known by the user
unknownDevices.setObject(deviceInfo, userId, deviceId);
continue;
}
if (deviceInfo.isBlocked()) {
// Remove any blocked devices
continue;
}
if (!deviceInfo.isVerified() && encryptToVerifiedDevicesOnly) {
continue;
}
if (TextUtils.equals(deviceInfo.identityKey(), mCrypto.getOlmDevice().getDeviceCurve25519Key())) {
// Don't bother sending to ourself
continue;
}
devicesInRoom.setObject(deviceInfo, userId, deviceId);
}
}
mCrypto.getUIHandler().post(new Runnable() {
@Override
public void run() {
// if so, warn the user so they can verify or ignore.
if (0 != unknownDevices.getMap().size()) {
callback.onMatrixError(new MXCryptoError(MXCryptoError.UNKNOWN_DEVICES_CODE, MXCryptoError.UNABLE_TO_ENCRYPT, MXCryptoError.UNKNOWN_DEVICES_REASON, unknownDevices));
} else {
callback.onSuccess(devicesInRoom);
}
}
});
}
});
}
@Override
public void onNetworkError(Exception e) {
callback.onNetworkError(e);
}
@Override
public void onMatrixError(MatrixError e) {
callback.onMatrixError(e);
}
@Override
public void onUnexpectedError(Exception e) {
callback.onUnexpectedError(e);
}
});
}
use of org.matrix.androidsdk.crypto.data.MXUsersDevicesMap in project matrix-android-sdk by matrix-org.
the class CryptoRestTest method test03_testClaimOneTimeKeysForUsersDevices.
@Test
public void test03_testClaimOneTimeKeysForUsersDevices() throws Exception {
Context context = InstrumentationRegistry.getContext();
createBobAccount();
createAliceAccount();
final HashMap<String, Object> results = new HashMap<>();
final HashMap<String, Object> otks = new HashMap<>();
{
HashMap<String, Object> map = new HashMap<>();
map.put("key", "ueuHES/Q0P1MZ4J3IUpC8iQTkgQNX66ZpxVLUaTDuB8");
HashMap<String, String> signaturesubMap = new HashMap<>();
signaturesubMap.put("ed25519:deviceId1", "signature1");
HashMap<String, Object> signatureMap = new HashMap<>();
signatureMap.put("@user1", signaturesubMap);
map.put("signatures", signatureMap);
otks.put("curve25519:AAAABQ", map);
}
{
HashMap<String, Object> map = new HashMap<>();
map.put("key", "PmyaaB68Any+za9CuZXzFsQZW31s/TW6XbAB9akEpQs");
HashMap<String, String> signaturesubMap = new HashMap<>();
signaturesubMap.put("ed25519:deviceId2", "signature2");
HashMap<String, Object> signatureMap = new HashMap<>();
signatureMap.put("@user2", signaturesubMap);
map.put("signatures", signatureMap);
otks.put("curve25519:AAAABA", map);
}
final CountDownLatch lock1 = new CountDownLatch(1);
mBobSession.getCryptoRestClient().uploadKeys(null, otks, "dev1", new ApiCallback<KeysUploadResponse>() {
@Override
public void onSuccess(KeysUploadResponse keysUploadResponse) {
results.put("keysUploadResponse", keysUploadResponse);
lock1.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock1.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock1.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock1.countDown();
}
});
lock1.await(1000, TimeUnit.MILLISECONDS);
KeysUploadResponse bobKeysUploadResponse = (KeysUploadResponse) results.get("keysUploadResponse");
assertTrue(null != bobKeysUploadResponse);
MXUsersDevicesMap<String> usersDevicesKeyTypesMap = new MXUsersDevicesMap<>();
usersDevicesKeyTypesMap.setObject("curve25519", mBobSession.getMyUserId(), "dev1");
final CountDownLatch lock2 = new CountDownLatch(1);
mAliceSession.getCryptoRestClient().claimOneTimeKeysForUsersDevices(usersDevicesKeyTypesMap, new ApiCallback<MXUsersDevicesMap<MXKey>>() {
@Override
public void onSuccess(MXUsersDevicesMap<MXKey> usersDevicesMap) {
results.put("usersDevicesMap", usersDevicesMap);
lock2.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock2.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock2.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock2.countDown();
}
});
lock2.await(1000, TimeUnit.MILLISECONDS);
MXUsersDevicesMap<MXKey> oneTimeKeys = (MXUsersDevicesMap<MXKey>) results.get("usersDevicesMap");
assertTrue(null != oneTimeKeys);
assertTrue(null != oneTimeKeys.getMap());
assertTrue(1 == oneTimeKeys.getMap().size());
MXKey bobOtk = oneTimeKeys.getObject("dev1", mBobSession.getMyUserId());
assertTrue(null != bobOtk);
assertTrue(TextUtils.equals(bobOtk.type, MXKey.KEY_CURVE_25519_TYPE));
assertTrue(TextUtils.equals(bobOtk.keyId, "AAAABA"));
assertTrue(TextUtils.equals(bobOtk.getKeyFullId(), "curve25519:AAAABA"));
assertTrue(TextUtils.equals(bobOtk.value, "PmyaaB68Any+za9CuZXzFsQZW31s/TW6XbAB9akEpQs"));
assertTrue(null != bobOtk.signatures);
ArrayList<String> keys = new ArrayList<>(bobOtk.signatures.keySet());
assertTrue(keys.size() == 1);
mBobSession.clear(context);
mAliceSession.clear(context);
}
use of org.matrix.androidsdk.crypto.data.MXUsersDevicesMap in project matrix-android-sdk by matrix-org.
the class CryptoRestTest method test01_testDeviceKeys.
public void test01_testDeviceKeys() throws Exception {
Context context = InstrumentationRegistry.getContext();
createBobAccount();
final HashMap<String, Object> results = new HashMap<>();
String ed25519key = "wV5E3EUSHpHuoZLljNzojlabjGdXT3Mz7rugG9zgbkI";
MXDeviceInfo bobDevice = new MXDeviceInfo("dev1");
bobDevice.userId = mBobSession.getMyUserId();
bobDevice.algorithms = Arrays.asList(MXCryptoAlgorithms.MXCRYPTO_ALGORITHM_OLM);
HashMap<String, String> keysMap = new HashMap();
keysMap.put("ed25519:" + bobDevice.deviceId, ed25519key);
bobDevice.keys = keysMap;
final CountDownLatch lock0 = new CountDownLatch(1);
mBobSession.getCryptoRestClient().uploadKeys(bobDevice.JSONDictionary(), null, "dev1", new ApiCallback<KeysUploadResponse>() {
@Override
public void onSuccess(KeysUploadResponse keysUploadResponse) {
results.put("keysUploadResponse", keysUploadResponse);
lock0.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock0.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock0.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock0.countDown();
}
});
lock0.await(1000, TimeUnit.MILLISECONDS);
KeysUploadResponse keysUploadResponse = (KeysUploadResponse) results.get("keysUploadResponse");
assertTrue(null != keysUploadResponse);
assertTrue(null != keysUploadResponse.oneTimeKeyCounts);
assertTrue(0 == keysUploadResponse.oneTimeKeyCounts.size());
assertTrue(0 == keysUploadResponse.oneTimeKeyCountsForAlgorithm("deded"));
final CountDownLatch lock1 = new CountDownLatch(1);
mBobSession.getCryptoRestClient().downloadKeysForUsers(Arrays.asList(mBobSession.getMyUserId()), null, new ApiCallback<KeysQueryResponse>() {
@Override
public void onSuccess(KeysQueryResponse keysQueryResponse) {
results.put("keysQueryResponse", keysQueryResponse);
lock1.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock1.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock1.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock1.countDown();
}
});
lock1.await(1000, TimeUnit.MILLISECONDS);
KeysQueryResponse keysQueryResponse = (KeysQueryResponse) results.get("keysQueryResponse");
assertTrue(null != keysQueryResponse);
assertTrue(null != keysQueryResponse.deviceKeys);
MXUsersDevicesMap<MXDeviceInfo> deviceInfos = new MXUsersDevicesMap<>(keysQueryResponse.deviceKeys);
assertTrue(null != deviceInfos.getUserIds());
assertTrue(1 == deviceInfos.getUserIds().size());
List<String> deviceIds = deviceInfos.getUserDeviceIds(mBobSession.getMyUserId());
assertTrue(null != deviceIds);
assertTrue(1 == deviceIds.size());
MXDeviceInfo bobDevice2 = deviceInfos.getObject("dev1", mBobSession.getMyUserId());
assertTrue(null != bobDevice2);
assertTrue(TextUtils.equals(bobDevice2.deviceId, "dev1"));
assertTrue(TextUtils.equals(bobDevice2.userId, mBobSession.getMyUserId()));
mBobSession.clear(context);
}
use of org.matrix.androidsdk.crypto.data.MXUsersDevicesMap in project matrix-android-sdk by matrix-org.
the class CryptoTest method test26_testBlackListUnverifiedDevices.
@Test
public // Check that the message can be decrypted by the Bob's device and the Sam's device
void test26_testBlackListUnverifiedDevices() throws Exception {
Log.e(LOG_TAG, "test26_testBlackListUnverifiedDevices");
Context context = InstrumentationRegistry.getContext();
final HashMap<String, Object> results = new HashMap<>();
doE2ETestWithAliceAndBobAndSamInARoom();
final String messageFromAlice = "Hello I'm Alice!";
Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
Room roomFromSamPOV = mSamSession.getDataHandler().getRoom(mRoomId);
assertTrue(roomFromBobPOV.isEncrypted());
assertTrue(roomFromAlicePOV.isEncrypted());
assertTrue(roomFromSamPOV.isEncrypted());
final CountDownLatch lock1 = new CountDownLatch(1);
roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock1.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock1.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
results.put("sendEventError", e);
lock1.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock1.countDown();
}
});
lock1.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("sendEventError"));
MXCryptoError error = (MXCryptoError) results.get("sendEventError");
assertTrue(TextUtils.equals(error.errcode, MXCryptoError.UNKNOWN_DEVICES_CODE));
MXUsersDevicesMap<MXDeviceInfo> unknownDevices = (MXUsersDevicesMap<MXDeviceInfo>) error.mExceptionData;
// only one bob device
List<String> deviceInfos = unknownDevices.getUserDeviceIds(mBobSession.getMyUserId());
assertTrue(1 == deviceInfos.size());
assertTrue(deviceInfos.contains(mBobSession.getCrypto().getMyDevice().deviceId));
// only one Sam device
deviceInfos = unknownDevices.getUserDeviceIds(mSamSession.getMyUserId());
assertTrue(1 == deviceInfos.size());
assertTrue(deviceInfos.contains(mSamSession.getCrypto().getMyDevice().deviceId));
final CountDownLatch lock2 = new CountDownLatch(1);
mAliceSession.getCrypto().setDevicesKnown(Arrays.asList(mBobSession.getCrypto().getMyDevice(), mSamSession.getCrypto().getMyDevice()), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setDevicesKnown", "setDevicesKnown");
lock2.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock2.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock2.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock2.countDown();
}
});
lock2.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setDevicesKnown"));
final CountDownLatch lock3 = new CountDownLatch(5);
MXEventListener eventListenerBob1 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession)) {
results.put("onLiveEventBob1", "onLiveEvent");
lock3.countDown();
}
}
} catch (Exception e) {
}
}
};
MXEventListener eventListenerSam1 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession)) {
results.put("onLiveEventSam1", "onLiveEvent");
lock3.countDown();
}
}
} catch (Exception e) {
}
}
};
mBobSession.getDataHandler().addListener(new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
results.put("onToDeviceEventBob", event);
lock3.countDown();
}
});
mSamSession.getDataHandler().addListener(new MXEventListener() {
@Override
public void onToDeviceEvent(Event event) {
results.put("onToDeviceEventSam", event);
lock3.countDown();
}
});
roomFromBobPOV.addEventListener(eventListenerBob1);
roomFromSamPOV.addEventListener(eventListenerSam1);
roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock3.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock3.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock3.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock3.countDown();
}
});
lock3.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("onToDeviceEventBob"));
assertTrue(results.containsKey("onToDeviceEventSam"));
assertTrue(results.containsKey("onLiveEventBob1"));
assertTrue(results.containsKey("onLiveEventSam1"));
roomFromBobPOV.removeEventListener(eventListenerBob1);
roomFromSamPOV.removeEventListener(eventListenerSam1);
// play with the device black listing
final List<CountDownLatch> activeLock = new ArrayList<>();
final List<String> activeMessage = new ArrayList<>();
MXEventListener eventListenerBob2 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, activeMessage.get(0), mAliceSession)) {
results.put("eventListenerBob2", "onLiveEvent");
activeLock.get(0).countDown();
}
} else if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED)) {
results.put("eventListenerEncyptedBob2", "onLiveEvent");
activeLock.get(0).countDown();
}
} catch (Exception e) {
}
}
};
MXEventListener eventListenerSam2 = new MXEventListener() {
@Override
public void onLiveEvent(Event event, RoomState roomState) {
try {
if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
if (checkEncryptedEvent(event, mRoomId, activeMessage.get(0), mAliceSession)) {
results.put("eventListenerSam2", "onLiveEvent");
activeLock.get(0).countDown();
}
} else if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED)) {
results.put("eventListenerEncyptedSam2", "onLiveEvent");
activeLock.get(0).countDown();
}
} catch (Exception e) {
}
}
};
roomFromBobPOV.addEventListener(eventListenerBob2);
roomFromSamPOV.addEventListener(eventListenerSam2);
final CountDownLatch lock4 = new CountDownLatch(1);
mAliceSession.getCrypto().setGlobalBlacklistUnverifiedDevices(true, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setGlobalBlacklistUnverifiedDevicesTrue", "setGlobalBlacklistUnverifiedDevices");
lock4.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock4.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock4.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock4.countDown();
}
});
lock4.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setGlobalBlacklistUnverifiedDevicesTrue"));
// ensure that there is no received message
results.clear();
final CountDownLatch lock5 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock5);
activeMessage.clear();
activeMessage.add("message 1");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock5.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock5.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock5.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock5.countDown();
}
});
lock5.await(3000, TimeUnit.MILLISECONDS);
assertTrue(!results.containsKey("eventListenerBob2"));
assertTrue(!results.containsKey("eventListenerSam2"));
assertTrue(results.containsKey("eventListenerEncyptedBob2"));
assertTrue(results.containsKey("eventListenerEncyptedSam2"));
final CountDownLatch lock6 = new CountDownLatch(1);
mAliceSession.getCrypto().setGlobalBlacklistUnverifiedDevices(false, new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setGlobalBlacklistUnverifiedDevicesfalse", "setGlobalBlacklistUnverifiedDevices");
lock6.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock6.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock6.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock6.countDown();
}
});
lock6.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setGlobalBlacklistUnverifiedDevicesfalse"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock7 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock7);
activeMessage.clear();
activeMessage.add("message 2");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock7.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock7.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock7.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock7.countDown();
}
});
lock7.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(!results.containsKey("eventListenerEncyptedSam2"));
// verify the bob device
final CountDownLatch lock8 = new CountDownLatch(3);
mAliceSession.getCrypto().setDeviceVerification(MXDeviceInfo.DEVICE_VERIFICATION_VERIFIED, mBobSession.getCrypto().getMyDevice().deviceId, mBobSession.getMyUserId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setDeviceVerificationBob", "setDeviceVerificationBob");
lock8.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock8.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock8.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock8.countDown();
}
});
lock8.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setDeviceVerificationBob"));
final CountDownLatch lock9 = new CountDownLatch(3);
mAliceSession.getCrypto().setRoomBlacklistUnverifiedDevices(roomFromAlicePOV.getRoomId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setRoomBlacklistUnverifiedDevices", "setRoomBlacklistUnverifiedDevices");
lock9.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock9.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock9.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock9.countDown();
}
});
lock9.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setRoomBlacklistUnverifiedDevices"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock10 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock10);
activeMessage.clear();
activeMessage.add("message 3");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock10.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock10.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock10.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock10.countDown();
}
});
lock10.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(!results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(results.containsKey("eventListenerEncyptedSam2"));
final CountDownLatch lock11 = new CountDownLatch(3);
mAliceSession.getCrypto().setRoomUnblacklistUnverifiedDevices(roomFromAlicePOV.getRoomId(), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
results.put("setRoomUnblacklistUnverifiedDevices", "setRoomUnblacklistUnverifiedDevices");
lock11.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock11.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock11.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock11.countDown();
}
});
lock11.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("setRoomUnblacklistUnverifiedDevices"));
// ensure that the messages are received
results.clear();
final CountDownLatch lock12 = new CountDownLatch(3);
activeLock.clear();
activeLock.add(lock12);
activeMessage.clear();
activeMessage.add("message 3");
roomFromAlicePOV.sendEvent(buildTextEvent(activeMessage.get(0), mAliceSession), new ApiCallback<Void>() {
@Override
public void onSuccess(Void info) {
lock12.countDown();
}
@Override
public void onNetworkError(Exception e) {
lock12.countDown();
}
@Override
public void onMatrixError(MatrixError e) {
lock12.countDown();
}
@Override
public void onUnexpectedError(Exception e) {
lock12.countDown();
}
});
lock12.await(3000, TimeUnit.MILLISECONDS);
assertTrue(results.containsKey("eventListenerBob2"));
assertTrue(results.containsKey("eventListenerSam2"));
assertTrue(!results.containsKey("eventListenerEncyptedBob2"));
assertTrue(!results.containsKey("eventListenerEncyptedSam2"));
mBobSession.clear(context);
}
Aggregations