mirror of
https://github.com/michaelrausch/Party-Parrots-At-Sea.git
synced 2026-05-09 14:28:43 +00:00
8cbd1cc4aa
#story[820]
199 lines
5.9 KiB
Java
199 lines
5.9 KiB
Java
package seng302.models.parsers;
|
|
|
|
|
|
import org.w3c.dom.Document;
|
|
import org.xml.sax.InputSource;
|
|
import org.xml.sax.SAXException;
|
|
|
|
import javax.xml.parsers.DocumentBuilder;
|
|
import javax.xml.parsers.DocumentBuilderFactory;
|
|
import javax.xml.parsers.ParserConfigurationException;
|
|
import java.io.ByteArrayInputStream;
|
|
import java.io.IOException;
|
|
import java.io.StringReader;
|
|
import java.util.Arrays;
|
|
|
|
/**
|
|
* Created by kre39 on 23/04/17.
|
|
*/
|
|
public class StreamParser {
|
|
|
|
static void parsePacket(StreamPacket packet) {
|
|
switch (packet.getType()){
|
|
case HEARTBEAT:
|
|
extractHeartBeat(packet);
|
|
break;
|
|
case RACE_STATUS:
|
|
extractRaceStatus(packet);
|
|
break;
|
|
case DISPLAY_TEXT_MESSAGE:
|
|
extractDisplayMessage(packet);
|
|
break;
|
|
case XML_MESSAGE:
|
|
extractXmlMessage(packet);
|
|
break;
|
|
case RACE_START_STATUS:
|
|
extractRaceStartStatus(packet);
|
|
break;
|
|
case YACHT_EVENT_CODE:
|
|
extractYachtEventCode(packet);
|
|
break;
|
|
case YACHT_ACTION_CODE:
|
|
extractYachtActionCode(packet);
|
|
break;
|
|
case CHATTER_TEXT:
|
|
extractChatterText(packet);
|
|
break;
|
|
case BOAT_LOCATION:
|
|
extractBoatLocation(packet);
|
|
break;
|
|
case MARK_ROUNDING:
|
|
extractMarkRounding(packet);
|
|
break;
|
|
case COURSE_WIND:
|
|
extractCourseWind(packet);
|
|
break;
|
|
case AVG_WIND:
|
|
extractAvgWind(packet);
|
|
break;
|
|
default:
|
|
System.out.println(packet.getType().toString());
|
|
}
|
|
}
|
|
|
|
private static void extractHeartBeat(StreamPacket packet){
|
|
System.out.println(bytesToLong(packet.getPayload()));
|
|
}
|
|
|
|
private static void extractRaceStatus(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractDisplayMessage(StreamPacket packet){
|
|
|
|
}
|
|
|
|
static void extractXmlMessage(StreamPacket packet){
|
|
|
|
byte[] payload = packet.getPayload();
|
|
String xmlMessage = "";
|
|
|
|
ByteArrayInputStream payloadStream = new ByteArrayInputStream(payload);
|
|
|
|
//Bunch of data we don't want (Message Version Number, AckNumber, Timestamp)
|
|
payloadStream.skip(9);
|
|
int xmlMessageSubType = payloadStream.read();
|
|
payloadStream.skip(2);
|
|
|
|
//checks the length of the xml message itself
|
|
int xmlMessageLength = payloadStream.read() | payloadStream.read() << 8;
|
|
|
|
//Converts XML message to string to be parsed
|
|
int currentChar;
|
|
while (payloadStream.available() > 0 && (currentChar = payloadStream.read()) != 0) {
|
|
xmlMessage += (char)currentChar;
|
|
}
|
|
|
|
//Create XML document Object
|
|
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
|
|
DocumentBuilder db = null;
|
|
try {
|
|
db = dbf.newDocumentBuilder();
|
|
Document doc = db.parse(new InputSource(new StringReader(xmlMessage)));
|
|
// TODO: 25/04/17 ajm412: Check that the object matches expected structure and return Document object.
|
|
} catch (ParserConfigurationException e) {
|
|
e.printStackTrace();
|
|
} catch (SAXException e) {
|
|
e.printStackTrace();
|
|
} catch (IOException e) {
|
|
e.printStackTrace();
|
|
}
|
|
|
|
}
|
|
|
|
private static void extractRaceStartStatus(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractYachtEventCode(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractYachtActionCode(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractChatterText(StreamPacket packet){
|
|
|
|
}
|
|
|
|
|
|
static void extractBoatLocation(StreamPacket packet){
|
|
byte[] payload = packet.getPayload();
|
|
byte deviceType = payload[15];
|
|
byte[] seqBytes = Arrays.copyOfRange(payload,11,15);
|
|
byte[] latBytes = Arrays.copyOfRange(payload,16,20);
|
|
byte[] lonBytes = Arrays.copyOfRange(payload,20,24);
|
|
byte[] boatIdBytes = Arrays.copyOfRange(payload,8,12);
|
|
extractTimeStamp(Arrays.copyOfRange(payload,1,7), 6);
|
|
// int boatSeq = ByteBuffer.wrap(seqBytes).getInt();
|
|
long seq = bytesToLong(seqBytes);
|
|
long boatId = bytesToLong(boatIdBytes);
|
|
long lat = bytesToLong(latBytes);
|
|
long lon = bytesToLong(lonBytes);
|
|
|
|
if (boatId != 0){
|
|
// System.out.println("boatId = " + boatId);
|
|
// System.out.println("deviceType = " + (long)deviceType);
|
|
// System.out.println("seq = " + seq);
|
|
//needs to be validated
|
|
// System.out.println("lon = " + ((180d * (double)lon)/Math.pow(2,31)));
|
|
// System.out.println("lat = " + ((180d *(double)lat)/Math.pow(2,31)));
|
|
}
|
|
|
|
}
|
|
|
|
|
|
private static void extractMarkRounding(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractCourseWind(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractAvgWind(StreamPacket packet){
|
|
|
|
}
|
|
|
|
private static void extractTimeStamp(byte[] timeStampBytes, int noOfBytes){
|
|
long timeStamp = 0;
|
|
long multiplier=1;
|
|
for(int i = 0;i < noOfBytes;i++) {
|
|
timeStamp += timeStampBytes[i]*multiplier;
|
|
multiplier *= 256;
|
|
}
|
|
System.out.println("timeStamp = " + timeStamp);
|
|
}
|
|
|
|
/**
|
|
* takes an array of up to 7 bytes and returns a positive
|
|
* long constructed from the input bytes
|
|
*
|
|
* @return a positive long if there is less than 7 bytes -1 otherwise
|
|
*/
|
|
private static long bytesToLong(byte[] bytes){
|
|
long partialLong = 0;
|
|
int index = 0;
|
|
for (byte b: bytes){
|
|
if (index > 6){
|
|
return -1;
|
|
}
|
|
partialLong = partialLong | (b & 0xFFL) << (index * 8);
|
|
index++;
|
|
}
|
|
return partialLong;
|
|
}
|
|
}
|
|
|