Search in sources :

Example 41 with Event

use of org.matrix.androidsdk.rest.model.Event in project matrix-android-sdk by matrix-org.

the class CryptoTest method test23_testFirstMessageSentWhileSessionWasPaused.

@Test
public void test23_testFirstMessageSentWhileSessionWasPaused() throws Exception {
    Log.e(LOG_TAG, "test23_testFirstMessageSentWhileSessionWasPaused");
    Context context = InstrumentationRegistry.getContext();
    final String messageFromAlice = "Hello I'm Alice!";
    final HashMap<String, Object> results = new HashMap<>();
    doE2ETestWithAliceAndBobInARoom(true);
    mBobSession.getCrypto().setWarnOnUnknownDevices(false);
    mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
    final Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
    final Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
    assertTrue(roomFromBobPOV.isEncrypted());
    assertTrue(roomFromAlicePOV.isEncrypted());
    mBobSession.pauseEventStream();
    // wait that the bob session is really suspended
    SystemClock.sleep(30000);
    final CountDownLatch lock0 = new CountDownLatch(1);
    roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
            results.put("sendEvent", "sendEvent");
            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(2000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("sendEvent"));
    final CountDownLatch lock2 = new CountDownLatch(2);
    MXEventListener eventListener = 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("onLiveEvent", "onLiveEvent");
                        lock2.countDown();
                    }
                }
            } catch (Exception e) {
            }
        }
    };
    roomFromBobPOV.addEventListener(eventListener);
    mBobSession.getDataHandler().addListener(new MXEventListener() {

        @Override
        public void onToDeviceEvent(Event event) {
            results.put("onToDeviceEvent", event);
            lock2.countDown();
        }
    });
    mBobSession.resumeEventStream();
    lock2.await(10000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("onToDeviceEvent"));
    assertTrue(results.containsKey("onLiveEvent"));
    mBobSession.clear(context);
    mAliceSession.clear(context);
}
Also used : Context(android.content.Context) HashMap(java.util.HashMap) CountDownLatch(java.util.concurrent.CountDownLatch) MXEventListener(org.matrix.androidsdk.listeners.MXEventListener) Event(org.matrix.androidsdk.rest.model.Event) JsonObject(com.google.gson.JsonObject) MatrixError(org.matrix.androidsdk.rest.model.MatrixError) Room(org.matrix.androidsdk.data.Room) RoomState(org.matrix.androidsdk.data.RoomState) Test(org.junit.Test)

Example 42 with Event

use of org.matrix.androidsdk.rest.model.Event in project matrix-android-sdk by matrix-org.

the class CryptoTest method test18_testAliceAndBobWithNewDevice.

@Test
public void test18_testAliceAndBobWithNewDevice() throws Exception {
    Log.e(LOG_TAG, "test18_testAliceAndBobWithNewDevice");
    Context context = InstrumentationRegistry.getContext();
    final HashMap<String, Object> results = new HashMap<>();
    doE2ETestWithAliceAndBobInARoom(true);
    mBobSession.getCrypto().setWarnOnUnknownDevices(false);
    mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
    final Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
    final Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
    String bobDeviceId1 = mBobSession.getCredentials().deviceId;
    assertTrue(roomFromBobPOV.isEncrypted());
    assertTrue(roomFromAlicePOV.isEncrypted());
    final CountDownLatch lock1 = new CountDownLatch(2);
    MXEventListener bobEventListener = new MXEventListener() {

        @Override
        public void onToDeviceEvent(Event event) {
            if (!results.containsKey("onToDeviceEvent")) {
                results.put("onToDeviceEvent", event);
                lock1.countDown();
            }
        }
    };
    mBobSession.getDataHandler().addListener(bobEventListener);
    final ArrayList<Event> receivedEvents = new ArrayList<>();
    EventTimeline.EventTimelineListener eventTimelineListener = new EventTimeline.EventTimelineListener() {

        public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
            if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
                receivedEvents.add(event);
                lock1.countDown();
            }
        }
    };
    roomFromBobPOV.getLiveTimeLine().addEventTimelineListener(eventTimelineListener);
    String aliceMessage1 = "Hello I'm Alice!";
    roomFromAlicePOV.sendEvent(buildTextEvent(aliceMessage1, mAliceSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock1.await(2000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("onToDeviceEvent"));
    assertTrue(1 == receivedEvents.size());
    Event event = receivedEvents.get(0);
    assertTrue(checkEncryptedEvent(event, mRoomId, aliceMessage1, mAliceSession));
    // logout
    final CountDownLatch lock2 = new CountDownLatch(1);
    String bobId = mBobSession.getCredentials().userId;
    mBobSession.logout(context, new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
            results.put("logout", "logout");
            lock2.countDown();
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock2.await(1000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("logout"));
    final CountDownLatch lock3 = new CountDownLatch(1);
    MXEventListener aliceEventListener = new MXEventListener() {

        @Override
        public void onToDeviceEvent(Event event) {
            if (!results.containsKey("onToDeviceEvent2")) {
                results.put("onToDeviceEvent2", event);
                lock3.countDown();
            }
        }
    };
    mAliceSession.getDataHandler().addListener(aliceEventListener);
    // login with a new device id
    MXSession bobSession2 = CryptoTestHelper.logAccountAndSync(context, bobId, MXTESTS_BOB_PWD);
    String bobDeviceId2 = bobSession2.getCredentials().deviceId;
    assertTrue(!TextUtils.equals(bobDeviceId2, bobDeviceId1));
    // before sending a message, wait that the device event is received.
    lock3.await(10000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("onToDeviceEvent2"));
    SystemClock.sleep(1000);
    final Room roomFromBobPOV2 = bobSession2.getDataHandler().getRoom(mRoomId);
    assertTrue(null != roomFromBobPOV2);
    final ArrayList<Event> receivedEvents4 = new ArrayList<>();
    final CountDownLatch lock4 = new CountDownLatch(1);
    EventTimeline.EventTimelineListener eventTimelineListener4 = new EventTimeline.EventTimelineListener() {

        public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
            if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
                receivedEvents4.add(event);
                lock4.countDown();
            } else {
                results.put("event4", event.getType() + "");
                lock4.countDown();
            }
        }
    };
    roomFromBobPOV2.getLiveTimeLine().addEventTimelineListener(eventTimelineListener4);
    String aliceMessage2 = "Hello I'm still Alice!";
    roomFromAlicePOV.sendEvent(buildTextEvent(aliceMessage2, mAliceSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock4.await(5000, TimeUnit.MILLISECONDS);
    assertTrue("received event of type " + results.get("event4"), 1 == receivedEvents4.size());
    event = receivedEvents4.get(0);
    assertTrue(checkEncryptedEvent(event, mRoomId, aliceMessage2, mAliceSession));
}
Also used : Context(android.content.Context) HashMap(java.util.HashMap) ArrayList(java.util.ArrayList) EventTimeline(org.matrix.androidsdk.data.EventTimeline) CountDownLatch(java.util.concurrent.CountDownLatch) MXEventListener(org.matrix.androidsdk.listeners.MXEventListener) Event(org.matrix.androidsdk.rest.model.Event) JsonObject(com.google.gson.JsonObject) MatrixError(org.matrix.androidsdk.rest.model.MatrixError) Room(org.matrix.androidsdk.data.Room) RoomState(org.matrix.androidsdk.data.RoomState) Test(org.junit.Test)

Example 43 with Event

use of org.matrix.androidsdk.rest.model.Event in project matrix-android-sdk by matrix-org.

the class CryptoTest method test16_testRoomKeyReshare.

@Test
public void test16_testRoomKeyReshare() throws Exception {
    Log.e(LOG_TAG, "test16_testRoomKeyReshare");
    final HashMap<String, Object> results = new HashMap<>();
    doE2ETestWithAliceAndBobInARoom(true);
    mBobSession.getCrypto().setWarnOnUnknownDevices(false);
    mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
    String messageFromAlice = "Hello I'm Alice!";
    final Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
    final Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
    assertTrue(roomFromBobPOV.isEncrypted());
    assertTrue(roomFromAlicePOV.isEncrypted());
    final CountDownLatch lock1 = new CountDownLatch(2);
    MXEventListener bobEventListener = new MXEventListener() {

        @Override
        public void onToDeviceEvent(Event event) {
            if (!results.containsKey("onToDeviceEvent")) {
                results.put("onToDeviceEvent", event);
                lock1.countDown();
            }
        }
    };
    mBobSession.getDataHandler().addListener(bobEventListener);
    final ArrayList<Event> receivedEvents = new ArrayList<>();
    EventTimeline.EventTimelineListener eventTimelineListener = new EventTimeline.EventTimelineListener() {

        public void onEvent(Event event, EventTimeline.Direction direction, RoomState roomState) {
            if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE)) {
                receivedEvents.add(event);
                lock1.countDown();
            }
        }
    };
    roomFromBobPOV.getLiveTimeLine().addEventTimelineListener(eventTimelineListener);
    roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock1.await(2000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("onToDeviceEvent"));
    assertTrue(1 == receivedEvents.size());
    Event event = receivedEvents.get(0);
    assertTrue(checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession));
    // Reinject a modified version of the received room_key event from Alice.
    // From Bob pov, that mimics Alice resharing her keys but with an advanced outbound group session.
    Event toDeviceEvent = (Event) results.get("onToDeviceEvent");
    String sessionId = toDeviceEvent.getContentAsJsonObject().get("session_id").getAsString();
    String newSessionKey = mAliceSession.getCrypto().getOlmDevice().getSessionKey(sessionId);
    JsonObject content = toDeviceEvent.getClearEvent().getContentAsJsonObject();
    content.add("session_key", new JsonPrimitive(newSessionKey));
    mBobSession.getDataHandler().onToDeviceEvent(toDeviceEvent);
    // We still must be able to decrypt the event
    // ie, the implementation must have ignored the new room key with the advanced outbound group
    // session key
    event.setClearData(null);
    mBobSession.getDataHandler().decryptEvent(event, null);
    assertTrue(checkEncryptedEvent(event, mRoomId, messageFromAlice, mAliceSession));
}
Also used : HashMap(java.util.HashMap) JsonPrimitive(com.google.gson.JsonPrimitive) ArrayList(java.util.ArrayList) JsonObject(com.google.gson.JsonObject) EventTimeline(org.matrix.androidsdk.data.EventTimeline) CountDownLatch(java.util.concurrent.CountDownLatch) MXEventListener(org.matrix.androidsdk.listeners.MXEventListener) Event(org.matrix.androidsdk.rest.model.Event) JsonObject(com.google.gson.JsonObject) MatrixError(org.matrix.androidsdk.rest.model.MatrixError) Room(org.matrix.androidsdk.data.Room) RoomState(org.matrix.androidsdk.data.RoomState) Test(org.junit.Test)

Example 44 with Event

use of org.matrix.androidsdk.rest.model.Event in project matrix-android-sdk by matrix-org.

the class CryptoTest method test13_testAliceAndNotCryptedBobInACryptedRoom.

@Test
public void test13_testAliceAndNotCryptedBobInACryptedRoom() throws Exception {
    Log.e(LOG_TAG, "test13_testAliceAndNotCryptedBobInACryptedRoom");
    final HashMap<String, Object> results = new HashMap();
    doE2ETestWithAliceAndBobInARoom(false);
    mAliceSession.getCrypto().setWarnOnUnknownDevices(false);
    Room roomFromBobPOV = mBobSession.getDataHandler().getRoom(mRoomId);
    Room roomFromAlicePOV = mAliceSession.getDataHandler().getRoom(mRoomId);
    assertTrue(roomFromBobPOV.isEncrypted());
    assertTrue(roomFromAlicePOV.isEncrypted());
    final String messageFromAlice = "Hello I'm Alice!";
    final CountDownLatch lock1 = new CountDownLatch(1);
    MXEventListener bobEventListener = new MXEventListener() {

        @Override
        public void onLiveEvent(Event event, RoomState roomState) {
            if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED) && !TextUtils.equals(event.getSender(), mBobSession.getMyUserId())) {
                results.put("bobEcho", event);
                lock1.countDown();
            }
        }
    };
    roomFromBobPOV.addEventListener(bobEventListener);
    roomFromAlicePOV.sendEvent(buildTextEvent(messageFromAlice, mAliceSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock1.await(1000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("bobEcho"));
    Event event = (Event) results.get("bobEcho");
    assertTrue(event.isEncrypted());
    assertTrue(TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE_ENCRYPTED));
    assertTrue(null != event.getContentAsJsonObject());
    assertTrue(!event.getContentAsJsonObject().has("body"));
    assertTrue(null != event.getCryptoError());
    assertTrue(TextUtils.equals(event.getCryptoError().errcode, MXCryptoError.ENCRYPTING_NOT_ENABLED_ERROR_CODE));
    final CountDownLatch lock2 = new CountDownLatch(1);
    MXEventListener aliceEventListener = new MXEventListener() {

        @Override
        public void onLiveEvent(Event event, RoomState roomState) {
            if (TextUtils.equals(event.getType(), Event.EVENT_TYPE_MESSAGE) && !TextUtils.equals(event.getSender(), mAliceSession.getMyUserId())) {
                results.put("aliceEcho", event);
                lock2.countDown();
            }
        }
    };
    roomFromAlicePOV.addEventListener(aliceEventListener);
    roomFromBobPOV.sendEvent(buildTextEvent("Hello I'm Bob!", mBobSession), new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
        }

        @Override
        public void onNetworkError(Exception e) {
        }

        @Override
        public void onMatrixError(MatrixError e) {
        }

        @Override
        public void onUnexpectedError(Exception e) {
        }
    });
    lock2.await(1000, TimeUnit.MILLISECONDS);
    assertTrue(results.containsKey("aliceEcho"));
    event = (Event) results.get("aliceEcho");
    assertTrue(!event.isEncrypted());
}
Also used : HashMap(java.util.HashMap) CountDownLatch(java.util.concurrent.CountDownLatch) MXEventListener(org.matrix.androidsdk.listeners.MXEventListener) Event(org.matrix.androidsdk.rest.model.Event) JsonObject(com.google.gson.JsonObject) MatrixError(org.matrix.androidsdk.rest.model.MatrixError) Room(org.matrix.androidsdk.data.Room) RoomState(org.matrix.androidsdk.data.RoomState) Test(org.junit.Test)

Example 45 with Event

use of org.matrix.androidsdk.rest.model.Event in project matrix-android-sdk by matrix-org.

the class MXCall method sendHangup.

/**
 * send an hang up event
 *
 * @param reason the reason
 */
protected void sendHangup(String reason) {
    JsonObject hangupContent = new JsonObject();
    hangupContent.add("version", new JsonPrimitive(0));
    hangupContent.add("call_id", new JsonPrimitive(this.mCallId));
    if (!TextUtils.isEmpty(reason)) {
        hangupContent.add("reason", new JsonPrimitive(reason));
    }
    Event event = new Event(Event.EVENT_TYPE_CALL_HANGUP, hangupContent, mSession.getCredentials().userId, mCallSignalingRoom.getRoomId());
    // local notification to indicate the end of call
    mUIThreadHandler.post(new Runnable() {

        @Override
        public void run() {
            dispatchOnCallEnd(END_CALL_REASON_USER_HIMSELF);
        }
    });
    Log.d(LOG_TAG, "## sendHangup(): reason=" + reason);
    // send hang up event to the server
    mCallSignalingRoom.sendEvent(event, new ApiCallback<Void>() {

        @Override
        public void onSuccess(Void info) {
            Log.d(LOG_TAG, "## sendHangup(): onSuccess");
        }

        @Override
        public void onNetworkError(Exception e) {
            Log.d(LOG_TAG, "## sendHangup(): onNetworkError Msg=" + e.getMessage());
        }

        @Override
        public void onMatrixError(MatrixError e) {
            Log.d(LOG_TAG, "## sendHangup(): onMatrixError Msg=" + e.getMessage());
        }

        @Override
        public void onUnexpectedError(Exception e) {
            Log.d(LOG_TAG, "## sendHangup(): onUnexpectedError Msg=" + e.getMessage());
        }
    });
}
Also used : JsonPrimitive(com.google.gson.JsonPrimitive) JsonObject(com.google.gson.JsonObject) Event(org.matrix.androidsdk.rest.model.Event) MatrixError(org.matrix.androidsdk.rest.model.MatrixError)

Aggregations

Event (org.matrix.androidsdk.rest.model.Event)73 ArrayList (java.util.ArrayList)31 JsonObject (com.google.gson.JsonObject)28 Room (org.matrix.androidsdk.data.Room)27 MatrixError (org.matrix.androidsdk.rest.model.MatrixError)27 HashMap (java.util.HashMap)23 CountDownLatch (java.util.concurrent.CountDownLatch)22 RoomState (org.matrix.androidsdk.data.RoomState)21 Test (org.junit.Test)20 MXEventListener (org.matrix.androidsdk.listeners.MXEventListener)19 Context (android.content.Context)14 MotionEvent (android.view.MotionEvent)9 EventTimeline (org.matrix.androidsdk.data.EventTimeline)9 IMXStore (org.matrix.androidsdk.data.store.IMXStore)7 ReceiptData (org.matrix.androidsdk.rest.model.ReceiptData)6 RoomMember (org.matrix.androidsdk.rest.model.RoomMember)6 Credentials (org.matrix.androidsdk.rest.model.login.Credentials)6 Uri (android.net.Uri)5 File (java.io.File)4 MessageRow (org.matrix.androidsdk.adapters.MessageRow)4