ByteArrayHandlerImpl.java 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package de.tudarmstadt.informatik.hostage.handler;
  2. import java.io.IOException;
  3. import java.io.InputStream;
  4. import java.io.OutputStream;
  5. import java.net.Socket;
  6. import java.util.List;
  7. import android.content.SharedPreferences;
  8. import android.preference.PreferenceManager;
  9. import de.tudarmstadt.informatik.hostage.HoneyListener;
  10. import de.tudarmstadt.informatik.hostage.HoneyService;
  11. import de.tudarmstadt.informatik.hostage.io.ByteArrayReaderWriter;
  12. import de.tudarmstadt.informatik.hostage.io.ReaderWriter;
  13. import de.tudarmstadt.informatik.hostage.logging.Record.TYPE;
  14. import de.tudarmstadt.informatik.hostage.protocol.Protocol;
  15. import de.tudarmstadt.informatik.hostage.protocol.Protocol.TALK_FIRST;
  16. import de.tudarmstadt.informatik.hostage.wrapper.ByteArray;
  17. public class ByteArrayHandlerImpl extends AbstractHandler {
  18. private int SLEEPTIME;
  19. public ByteArrayHandlerImpl(HoneyService service, HoneyListener listener,
  20. Protocol protocol, Socket client) {
  21. super(service, listener, protocol, client);
  22. SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(service);
  23. SLEEPTIME = pref.getInt("sleeptime", 500);
  24. }
  25. @Override
  26. protected void talkToClient(InputStream in, OutputStream out)
  27. throws IOException {
  28. ReaderWriter<ByteArray> stream = new ByteArrayReaderWriter(in, out, SLEEPTIME);
  29. ByteArray inputLine;
  30. List<ByteArray> outputLine;
  31. if (protocol.whoTalksFirst() == TALK_FIRST.SERVER) {
  32. outputLine = protocol.processMessage(null);
  33. stream.write(outputLine);
  34. for (ByteArray s : outputLine) {
  35. log.write(createRecord(TYPE.SEND, s.toString()));
  36. }
  37. }
  38. while (!thread.isInterrupted() && (inputLine = stream.read()) != null) {
  39. outputLine = protocol.processMessage(inputLine);
  40. log.write(createRecord(TYPE.RECEIVE, protocol.getRequestContent()));
  41. if (outputLine != null) {
  42. stream.write(outputLine);
  43. for (ByteArray s : outputLine) {
  44. log.write(createRecord(TYPE.SEND, s.toString()));
  45. }
  46. }
  47. if (protocol.isClosed()) {
  48. break;
  49. }
  50. }
  51. }
  52. }