mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-14 16:59:52 +00:00
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, AsyncResult<ServiceResult> results) throws IOException {
|
||
|
super(selector, 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();
|
||
|
}
|
||
|
}
|
||
|
}
|