Search in sources :

Example 1 with KeyedDataQueueEntry

use of com.ibm.as400.access.KeyedDataQueueEntry in project camel by apache.

the class Jt400DataQueueConsumer method receive.

private Exchange receive(KeyedDataQueue queue, long timeout) throws Exception {
    String key = getEndpoint().getSearchKey();
    String searchType = getEndpoint().getSearchType().name();
    KeyedDataQueueEntry entry;
    if (timeout >= 0) {
        int seconds = (int) timeout / 1000;
        log.trace("Reading from data queue: {} with {} seconds timeout", queue.getName(), seconds);
        entry = queue.read(key, seconds, searchType);
    } else {
        log.trace("Reading from data queue: {} with no timeout", queue.getName());
        entry = queue.read(key, -1, searchType);
    }
    Exchange exchange = getEndpoint().createExchange();
    if (entry != null) {
        exchange.getIn().setHeader(Jt400Endpoint.SENDER_INFORMATION, entry.getSenderInformation());
        if (getEndpoint().getFormat() == Jt400Configuration.Format.binary) {
            exchange.getIn().setBody(entry.getData());
            exchange.getIn().setHeader(Jt400Endpoint.KEY, entry.getKey());
        } else {
            exchange.getIn().setBody(entry.getString());
            exchange.getIn().setHeader(Jt400Endpoint.KEY, entry.getKeyString());
        }
        return exchange;
    }
    return null;
}
Also used : Exchange(org.apache.camel.Exchange) KeyedDataQueueEntry(com.ibm.as400.access.KeyedDataQueueEntry)

Aggregations

KeyedDataQueueEntry (com.ibm.as400.access.KeyedDataQueueEntry)1 Exchange (org.apache.camel.Exchange)1