Basic Event SampleΒΆ

This sample demonstrates how to register a callback to receive Event messages from the DXL fabric. Once the callback is registered, the sample sends a set number of Event messages to the fabric and waits for them all to be received by the callback.

Prior to running this sample make sure you have completed the samples configuration step (Samples Configuration).

To run this sample execute the sample\runsample script as follows:

c:\dxlclient-java-sdk-0.2.6>sample\runsample sample.basic.EventSample

The output should appear similar to the following:

Received event: 0
Received event: 1
Received event: 2
Received event: 3
Received event: 4
Received event: 5

...

Received event: 994
Received event: 995
Received event: 996
Received event: 997
Received event: 998
Received event: 999
Elapsed time (ms): 441.999912262

The code for the sample is broken into two main sections.

The first section is responsible for registering an EventCallback for a specific topic. The DxlClient.addEventCallback() method registers the callback and subscribes to the topic.

//
// Register callback and subscribe
//

// Create and add event listener
final EventCallback myEventCallback =
    event -> {
        try {
            System.out.println("Received event: "
                + new String(event.getPayload(), Message.CHARSET_UTF8));
        } catch (UnsupportedEncodingException ex) {
            ex.printStackTrace();
        }

        eventCountLock.lock();
        try {
            eventCount++;
            eventCountCondition.signalAll();

        } finally {
            eventCountLock.unlock();
        }
    };
client.addEventCallback(EVENT_TOPIC, myEventCallback);

The second section sends a set amount of Event messages via the DxlClient.sendEvent method of the DxlClient.

It then waits for all of the events to be received by the EventCallback that was previously registered.

//
// Send events
//

// Record the start time
final long startTime = System.currentTimeMillis();

// Loop and send the events
for (int count = 0; count < TOTAL_EVENTS; count++) {
    final Event event = new Event(EVENT_TOPIC);
    event.setPayload(Integer.toString(count).getBytes(Message.CHARSET_UTF8));
    client.sendEvent(event);
}

// Wait until all events have been received
System.out.println("Waiting for events to be received...");
eventCountLock.lock();
try {
    while (eventCount < TOTAL_EVENTS) {
        eventCountCondition.await();
    }
} finally {
    eventCountLock.unlock();
}

// Print the elapsed time
System.out.println("Elapsed time (ms): " + (System.currentTimeMillis() - startTime));