Initialize the client

NexmoClient is the main class used to interact with Android-Client-SDK. Prior to usage, you have to initialize the client by providing an instance of the Android Context class.

At the top of the MainActivity class define client property that will hold reference to the client:

private NexmoClient client;

Locate the onCreate method in the MainActivity class and initialize NexmoClient using the builder:

client = new NexmoClient.Builder().build(this);

IDE will display warning about unresolved reference:

Put caret on the red text and press Alt + Enter to import the reference.

Now below client initialization code add connection listener to monitor connection state:

client.setConnectionListener((connectionStatus, connectionStatusReason) -> {
    if (connectionStatus == NexmoConnectionListener.ConnectionStatus.CONNECTED) {
        Toast.makeText(this, "User connected", Toast.LENGTH_SHORT);

    } else if (connectionStatus == NexmoConnectionListener.ConnectionStatus.DISCONNECTED) {
        Toast.makeText(this, "User disconnected", Toast.LENGTH_SHORT);

        runOnUiThread(() -> {

The above listener allows determining that that user has logged in successfully and show the chat UI.

Add empty getConversation method. You will update it in the following steps:

private void getConversation() { }

Add the code to login the users at the bottom of the onCreate method. Please make sure to replace ALICE_JWT and BOB_JWT with the JWT you created during a previous step:

findViewById( -> {

    runOnUiThread(() -> loginContainer.setVisibility(View.GONE));

findViewById( -> {

    runOnUiThread(() -> loginContainer.setVisibility(View.GONE));

Finally in the same method add the code to logout the user:

findViewById( -> client.logout());

Run Build > Make project to make sure the project is compiling.