use of org.jboss.narayana.blacktie.jatmibroker.xatmi.Response in project narayana by jbosstm.
the class BlacktieStompAdministrationService method tpservice.
public Response tpservice(TPSVCINFO svcinfo) {
log.debug("Message received");
X_OCTET recv = (X_OCTET) svcinfo.getBuffer();
String string = new String(recv.getByteArray());
StringTokenizer st = new StringTokenizer(string, ",", false);
String operation = st.nextToken();
String serverName = st.nextToken();
String serviceName = st.nextToken();
byte[] success = new byte[1];
String server = null;
try {
if (serviceName.indexOf(".") > -1) {
server = serviceName.substring(1);
server = server.replaceAll("[0-9]", "");
} else {
ServerInfo info = SERVICE_OWNERS.get(serviceName);
if (info == null) {
server = serverName;
} else {
server = info.name;
}
}
if (server != null && server.equals(serverName)) {
log.trace("Service " + serviceName + " exists for server: " + server);
if (operation.equals("tpadvertise")) {
log.trace("Advertising: " + serviceName);
boolean conversational = st.nextToken().equals("1");
String type = st.nextToken();
String version = st.nextToken();
success[0] = (byte) deployQueue(serviceName, serverName, conversational, type, version);
log.trace("Advertised: " + serviceName);
} else if (operation.equals("decrementconsumer")) {
log.trace("Decrement consumer: " + serviceName);
success[0] = (byte) decrementConsumer(serviceName);
log.trace("Decremented consumer: " + serviceName);
} else {
log.error("Unknown operation " + operation);
success[0] = 0;
}
} else {
log.error("Service " + serviceName + " already exists for a different server (" + server + ")");
success[0] = 0;
}
X_OCTET buffer = (X_OCTET) svcinfo.getConnection().tpalloc("X_OCTET", null);
buffer.setByteArray(success);
log.debug("Responding");
return new Response(Connection.TPSUCCESS, 0, buffer, 0);
} catch (ConnectionException e) {
return new Response(Connection.TPFAIL, 0, null, 0);
} catch (ConfigurationException e) {
return new Response(Connection.TPFAIL, 0, null, 0);
} catch (UnknownHostException e) {
return new Response(Connection.TPFAIL, 0, null, 0);
}
}
use of org.jboss.narayana.blacktie.jatmibroker.xatmi.Response in project narayana by jbosstm.
the class AdministrationProxy method getServiceCounterById.
public long getServiceCounterById(String serverName, int id, String serviceName) {
log.trace("getServiceCounterById");
long counter = 0;
String command = "counter," + serviceName + ",";
try {
Response buf = callAdminService(serverName, id, command);
if (buf != null) {
byte[] received = ((X_OCTET) buf.getBuffer()).getByteArray();
counter = Long.parseLong(new String(received, 1, received.length - 1));
}
} catch (ConnectionException e) {
log.error("call server " + serverName + " id " + id + " failed with " + e.getTperrno());
} catch (ConfigurationException e) {
log.error("call server " + serverName + " id " + id + " failed with configuration exception", e);
}
return counter;
}
use of org.jboss.narayana.blacktie.jatmibroker.xatmi.Response in project narayana by jbosstm.
the class AdministrationProxy method getErrorCounterById.
public long getErrorCounterById(String serverName, int id, String serviceName) {
log.trace("getErrorCounterById");
long counter = 0;
String command = "error_counter," + serviceName + ",";
try {
Response buf = callAdminService(serverName, id, command);
if (buf != null) {
byte[] received = ((X_OCTET) buf.getBuffer()).getByteArray();
counter = Long.parseLong(new String(received, 1, received.length - 1));
}
} catch (ConnectionException e) {
log.error("call server " + serverName + " id " + id + " failed with " + e.getTperrno());
} catch (ConfigurationException e) {
log.error("call server " + serverName + " id " + id + " failed with configuration exception", e);
}
return counter;
}
use of org.jboss.narayana.blacktie.jatmibroker.xatmi.Response in project narayana by jbosstm.
the class AdministrationProxy method getResponseTimeById.
public String getResponseTimeById(String serverName, int id, String serviceName) {
log.trace("getResponseTimeById");
String command = "responsetime," + serviceName + ",";
log.trace("response command is " + command);
try {
Response buf = callAdminService(serverName, id, command);
if (buf != null) {
byte[] received = ((X_OCTET) buf.getBuffer()).getByteArray();
String result = new String(received, 1, received.length - 1);
log.trace("response result is " + result);
return result;
}
} catch (ConnectionException e) {
log.error("call server " + serverName + " id " + id + " failed with " + e.getTperrno(), e);
} catch (RuntimeException e) {
log.error("Could not get response time from server: " + e.getMessage(), e);
throw e;
} catch (ConfigurationException e) {
log.error("call server " + serverName + " id " + id + " failed with configuration exception", e);
}
return null;
}
use of org.jboss.narayana.blacktie.jatmibroker.xatmi.Response in project narayana by jbosstm.
the class BlacktieStompAdministrationServiceTest method processStompCommand.
private void processStompCommand(String command, int expectation) throws ConnectionException, ConfigurationException {
byte[] toSend = command.getBytes();
X_OCTET buffer = (X_OCTET) connection.tpalloc("X_OCTET", null);
buffer.setByteArray(toSend);
Response response = connection.tpcall("BTStompAdmin", buffer, 0);
byte[] responseData = ((X_OCTET) response.getBuffer()).getByteArray();
assertEquals(expectation, responseData[0]);
}
Aggregations