mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-18 02:39:44 +00:00
68dbaef38d
Add stateful class to represent the state of the serval daemon, shifting some functions from BatPhone Add convenience functions to get pre-configured MDP and HTTP Restful client classes
97 lines
2.3 KiB
Java
97 lines
2.3 KiB
Java
package org.servalproject.servaldna;
|
|
|
|
import java.io.IOException;
|
|
import java.io.InputStream;
|
|
import java.nio.ByteBuffer;
|
|
import java.util.Properties;
|
|
|
|
/**
|
|
* Created by jeremy on 8/05/14.
|
|
*/
|
|
public class MdpServiceLookup extends AbstractMdpProtocol<MdpServiceLookup.ServiceResult> {
|
|
|
|
public static class ServiceResult extends Properties {
|
|
public final SubscriberId subscriberId;
|
|
public ServiceResult(SubscriberId subscriberId){
|
|
this.subscriberId = subscriberId;
|
|
}
|
|
|
|
public String toString(){
|
|
return "ServiceResult{subscriberId="+subscriberId+", "+super.toString()+"}";
|
|
}
|
|
}
|
|
|
|
public MdpServiceLookup(ChannelSelector selector, int loopbackMdpPort, AsyncResult<ServiceResult> results) throws IOException {
|
|
super(selector, loopbackMdpPort, results);
|
|
}
|
|
|
|
public void sendRequest(SubscriberId destination, String pattern) throws IOException {
|
|
MdpPacket request = new MdpPacket();
|
|
if (destination.isBroadcast())
|
|
request.setFlags(MdpPacket.MDP_FLAG_NO_CRYPT);
|
|
request.setRemoteSid(destination);
|
|
request.setRemotePort(MdpPacket.MDP_PORT_SERVICE_DISCOVERY);
|
|
request.payload.put(pattern.getBytes());
|
|
request.payload.put((byte)0);
|
|
request.payload.flip();
|
|
socket.send(request);
|
|
}
|
|
|
|
public static class BuffStream extends InputStream{
|
|
private final ByteBuffer buff;
|
|
public BuffStream(ByteBuffer buff){
|
|
this.buff = buff;
|
|
}
|
|
|
|
@Override
|
|
public boolean markSupported() {
|
|
return true;
|
|
}
|
|
|
|
@Override
|
|
public int read() throws IOException {
|
|
if (!buff.hasRemaining())
|
|
return -1;
|
|
return buff.get()&0xFF;
|
|
}
|
|
|
|
@Override
|
|
public void mark(int readLimit){
|
|
buff.mark();
|
|
}
|
|
|
|
@Override
|
|
public void reset() throws IOException {
|
|
buff.rewind();
|
|
}
|
|
|
|
@Override
|
|
public void close() throws IOException {
|
|
// noop
|
|
}
|
|
|
|
@Override
|
|
public int read(byte[] dst, int dstOffset, int charCount) throws IOException {
|
|
if (!buff.hasRemaining())
|
|
return -1;
|
|
if (charCount > buff.remaining())
|
|
charCount = buff.remaining();
|
|
buff.get(dst, dstOffset, charCount);
|
|
return charCount;
|
|
}
|
|
}
|
|
|
|
@Override
|
|
protected void parse(MdpPacket response) {
|
|
try {
|
|
ServiceResult result = new ServiceResult(response.getRemoteSid());
|
|
result.load(new BuffStream(response.payload));
|
|
results.result(result);
|
|
} catch (IOException e) {
|
|
e.printStackTrace();
|
|
} catch (AbstractId.InvalidBinaryException e) {
|
|
e.printStackTrace();
|
|
}
|
|
}
|
|
}
|