All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.zbus.rpc.transport.mq.RpcMessageInvoker Maven / Gradle / Ivy

package io.zbus.rpc.transport.mq;

import java.io.IOException;

import io.zbus.mq.Producer;
import io.zbus.mq.ProducerConfig;
import io.zbus.rpc.MessageInvoker;
import io.zbus.transport.ResultCallback;
import io.zbus.transport.http.Message; 

public class RpcMessageInvoker implements MessageInvoker {
	private final Producer producer;
	private final String topic; 
	
	public RpcMessageInvoker(ProducerConfig config, String topic){ 
		this.topic = topic;
		if(this.topic == null){
			throw new IllegalArgumentException("Missing topic in config");
		}
		this.producer = new Producer(config); 
	}
	
	@Override
	public Message invokeSync(Message req, int timeout) throws IOException, InterruptedException { 
		io.zbus.mq.Message message = new io.zbus.mq.Message(req);
		message.setAck(false);
		message.setTopic(this.topic);
		return this.producer.publish(message, timeout); 
	}

	@Override
	public void invokeAsync(Message req, final ResultCallback callback) throws IOException {   
		io.zbus.mq.Message message = new io.zbus.mq.Message(req);
		message.setAck(false);
		message.setTopic(this.topic);
		
		this.producer.publishAsync(message, new ResultCallback() { 
			@Override
			public void onReturn(io.zbus.mq.Message result) { 
				callback.onReturn(result);
			}
		});
	}  
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy