io.baltoro.client.ResponseWorker Maven / Gradle / Ivy
package io.baltoro.client;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.baltoro.client.util.ObjectUtil;
import io.baltoro.to.WSTO;
public class ResponseWorker extends Thread
{
private WSTO to;
//private Session session;
static ObjectMapper objectMapper = new ObjectMapper();
boolean run = true;
static int _count;
int count;
public ResponseWorker()
{
synchronized (ResponseWorker.class.getName().intern())
{
this.count = _count++;
}
}
void set(WSTO to)
{
this.to = to;
synchronized (this)
{
this.notify();
}
}
void clear()
{
this.to = null;
}
@Override
public void run()
{
while (run)
{
if(to == null)
{
synchronized (this)
{
try
{
//System.out.println("worker before waiting ..... "+this+", --- "+count);
this.wait(10000);
//System.out.println("worker after waiting ..... "+this+", --- "+count);
if(to == null)
{
//System.out.println("RESPONSE thread no work to do "+this+", --- "+count+",,,"+WorkerPool.info());
continue;
}
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
}
try
{
/*
String url = to.requestContext != null ? to.requestContext.getApiPath() : "null";
System.out.println("^^^^^^^^^ response triger :: url"+url+", uuid:"+to.uuid);
int len = to.responseContext != null ? to.responseContext.getData().length : -1;
System.out.println("^^^^^^^^^ response bytes :: "+len);
//*/
to.requestContext = null;
byte[] bytes = null;
if(to.responseContext.hasBinaryData)
{
bytes = to.responseContext.getData();
to.responseContext.setData(null);
}
String json = ObjectUtil.toJasonStr(to);
//ByteBuffer byteBuffer = ByteBuffer.wrap(json);
//session.getBasicRemote().sendBinary(byteBuffer);
Baltoro.cs.sendAPIResponse(to.uuid, json, bytes);
}
catch (Exception e)
{
e.printStackTrace();
}
finally
{
to = null;
WorkerPool.done(this);
}
}
}
@Override
public boolean equals(Object obj)
{
return count == ((ResponseWorker)obj).count;
}
}