CLI.java 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. package ui;
  2. import java.lang.reflect.Constructor;
  3. import java.lang.reflect.InvocationTargetException;
  4. import java.net.InetSocketAddress;
  5. import org.apache.commons.cli.CommandLine;
  6. import org.apache.commons.cli.CommandLineParser;
  7. import org.apache.commons.cli.GnuParser;
  8. import org.apache.commons.cli.Options;
  9. import org.apache.commons.cli.ParseException;
  10. import communication.Communication;
  11. import exceptions.NoSuchPartyException;
  12. import oram.Global;
  13. import oram.Metadata;
  14. import protocols.*;
  15. import struct.Party;
  16. import subprotocols.*;
  17. public class CLI {
  18. public static final int DEFAULT_PORT = 8000;
  19. public static final String DEFAULT_IP = "localhost";
  20. public static void main(String[] args) {
  21. // Setup command line argument parser
  22. Options options = new Options();
  23. options.addOption("config", true, "Config file");
  24. options.addOption("forest", true, "Forest file");
  25. options.addOption("eddie_ip", true, "IP to look for eddie");
  26. options.addOption("debbie_ip", true, "IP to look for debbie");
  27. options.addOption("protocol", true, "Algorithim to test");
  28. options.addOption("pipeline", false, "Whether to do pipelined eviction");
  29. // Parse the command line arguments
  30. CommandLineParser cmdParser = new GnuParser();
  31. CommandLine cmd = null;
  32. try {
  33. cmd = cmdParser.parse(options, args);
  34. } catch (ParseException e1) {
  35. e1.printStackTrace();
  36. }
  37. Global.pipeline = cmd.hasOption("pipeline");
  38. String configFile = cmd.getOptionValue("config", "config.yaml");
  39. String forestFile = cmd.getOptionValue("forest", null);
  40. String party = null;
  41. String[] positionalArgs = cmd.getArgs();
  42. if (positionalArgs.length > 0) {
  43. party = positionalArgs[0];
  44. } else {
  45. try {
  46. throw new ParseException("No party specified");
  47. } catch (ParseException e) {
  48. e.printStackTrace();
  49. System.exit(-1);
  50. }
  51. }
  52. int extra_port = 1;
  53. int eddiePort1 = DEFAULT_PORT;
  54. int eddiePort2 = eddiePort1 + extra_port;
  55. int debbiePort = eddiePort2 + extra_port;
  56. String eddieIp = cmd.getOptionValue("eddie_ip", DEFAULT_IP);
  57. String debbieIp = cmd.getOptionValue("debbie_ip", DEFAULT_IP);
  58. Class<? extends Protocol> operation = null;
  59. String protocol = cmd.getOptionValue("protocol", "retrieve").toLowerCase();
  60. if (protocol.equals("ur")) {
  61. operation = UpdateRoot.class;
  62. } else if (protocol.equals("evi")) {
  63. operation = Eviction.class;
  64. } else if (protocol.equals("pt")) {
  65. operation = PermuteTarget.class;
  66. } else if (protocol.equals("pi")) {
  67. operation = PermuteIndex.class;
  68. } else if (protocol.equals("xot")) {
  69. operation = SSXOT.class;
  70. } else if (protocol.equals("pircot")) {
  71. operation = PIRCOT.class;
  72. } else if (protocol.equals("piracc")) {
  73. operation = PIRAccess.class;
  74. } else if (protocol.equals("pirrtv")) {
  75. operation = PIRRetrieve.class;
  76. } else if (protocol.equals("sspir")) {
  77. operation = SSPIR.class;
  78. } else if (protocol.equals("shiftpir")) {
  79. operation = ShiftPIR.class;
  80. } else if (protocol.equals("tspir")) {
  81. operation = ThreeShiftPIR.class;
  82. } else if (protocol.equals("shiftxorpir")) {
  83. operation = ShiftXorPIR.class;
  84. } else if (protocol.equals("tsxpir")) {
  85. operation = ThreeShiftXorPIR.class;
  86. } else if (protocol.equals("shift")) {
  87. operation = Shift.class;
  88. } else if (protocol.equals("ff")) {
  89. operation = FlipFlag.class;
  90. } else if (protocol.equals("inslbl")) {
  91. operation = InsLbl.class;
  92. } else if (protocol.equals("ulit")) {
  93. operation = ULiT.class;
  94. } else {
  95. System.out.println("Protocol " + protocol + " not supported");
  96. System.exit(-1);
  97. }
  98. Constructor<? extends Protocol> operationCtor = null;
  99. try {
  100. operationCtor = operation.getDeclaredConstructor(Communication.class, Communication.class);
  101. } catch (NoSuchMethodException | SecurityException e1) {
  102. e1.printStackTrace();
  103. }
  104. // For now all logic happens here. Eventually this will get wrapped
  105. // up in party specific classes.
  106. System.out.println("Starting " + party + "...");
  107. Metadata md = new Metadata(configFile);
  108. int numComs = Global.pipeline ? md.getNumTrees() + 1 : 1;
  109. Communication[] con1 = new Communication[numComs];
  110. Communication[] con2 = new Communication[numComs];
  111. if (party.equals("eddie")) {
  112. System.out.print("Waiting to establish debbie connections...");
  113. for (int i = 0; i < numComs; i++) {
  114. con1[i] = new Communication();
  115. con1[i].start(eddiePort1);
  116. eddiePort1 += 3;
  117. while (con1[i].getState() != Communication.STATE_CONNECTED)
  118. ;
  119. }
  120. System.out.println(" done!");
  121. System.out.print("Waiting to establish charlie connections...");
  122. for (int i = 0; i < numComs; i++) {
  123. con2[i] = new Communication();
  124. con2[i].start(eddiePort2);
  125. eddiePort2 += 3;
  126. while (con2[i].getState() != Communication.STATE_CONNECTED)
  127. ;
  128. }
  129. System.out.println(" done!");
  130. for (int i = 0; i < numComs; i++) {
  131. con1[i].setTcpNoDelay(true);
  132. con2[i].setTcpNoDelay(true);
  133. }
  134. try {
  135. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  136. if (protocol.equals("pirrtv")) {
  137. ((PIRRetrieve) p).setCons(con1, con2);
  138. }
  139. if (!Global.usePIR) {
  140. p.run(Party.Eddie, md, forestFile);
  141. } else {
  142. p.run(Party.Eddie, md);
  143. }
  144. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  145. | InvocationTargetException e) {
  146. e.printStackTrace();
  147. }
  148. } else if (party.equals("debbie")) {
  149. System.out.print("Waiting to establish eddie connections...");
  150. for (int i = 0; i < numComs; i++) {
  151. con1[i] = new Communication();
  152. InetSocketAddress addr = new InetSocketAddress(eddieIp, eddiePort1);
  153. con1[i].connect(addr);
  154. eddiePort1 += 3;
  155. while (con1[i].getState() != Communication.STATE_CONNECTED)
  156. ;
  157. }
  158. System.out.println(" done!");
  159. System.out.print("Waiting to establish charlie connections...");
  160. for (int i = 0; i < numComs; i++) {
  161. con2[i] = new Communication();
  162. con2[i].start(debbiePort);
  163. debbiePort += 3;
  164. while (con2[i].getState() != Communication.STATE_CONNECTED)
  165. ;
  166. }
  167. System.out.println(" done!");
  168. for (int i = 0; i < numComs; i++) {
  169. con1[i].setTcpNoDelay(true);
  170. con2[i].setTcpNoDelay(true);
  171. }
  172. try {
  173. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  174. if (protocol.equals("pirrtv")) {
  175. ((PIRRetrieve) p).setCons(con1, con2);
  176. }
  177. if (!Global.usePIR) {
  178. p.run(Party.Debbie, md, forestFile);
  179. } else {
  180. p.run(Party.Debbie, md);
  181. }
  182. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  183. | InvocationTargetException e) {
  184. e.printStackTrace();
  185. }
  186. } else if (party.equals("charlie")) {
  187. System.out.print("Waiting to establish eddie connections...");
  188. for (int i = 0; i < numComs; i++) {
  189. con1[i] = new Communication();
  190. InetSocketAddress addr = new InetSocketAddress(eddieIp, eddiePort2);
  191. con1[i].connect(addr);
  192. eddiePort2 += 3;
  193. while (con1[i].getState() != Communication.STATE_CONNECTED)
  194. ;
  195. }
  196. System.out.println(" done!");
  197. System.out.print("Waiting to establish debbie connections...");
  198. for (int i = 0; i < numComs; i++) {
  199. con2[i] = new Communication();
  200. InetSocketAddress addr = new InetSocketAddress(debbieIp, debbiePort);
  201. con2[i].connect(addr);
  202. debbiePort += 3;
  203. while (con2[i].getState() != Communication.STATE_CONNECTED)
  204. ;
  205. }
  206. System.out.println(" done!");
  207. for (int i = 0; i < numComs; i++) {
  208. con1[i].setTcpNoDelay(true);
  209. con2[i].setTcpNoDelay(true);
  210. }
  211. try {
  212. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  213. if (protocol.equals("pirrtv")) {
  214. ((PIRRetrieve) p).setCons(con1, con2);
  215. }
  216. if (!Global.usePIR) {
  217. p.run(Party.Charlie, md, forestFile);
  218. } else {
  219. p.run(Party.Charlie, md);
  220. }
  221. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  222. | InvocationTargetException e) {
  223. e.printStackTrace();
  224. }
  225. } else {
  226. throw new NoSuchPartyException(party);
  227. }
  228. try {
  229. Thread.sleep(1000);
  230. } catch (InterruptedException e) {
  231. e.printStackTrace();
  232. }
  233. for (int i = 0; i < numComs; i++) {
  234. con1[i].stop();
  235. con2[i].stop();
  236. }
  237. System.out.println(party + " exiting...");
  238. }
  239. }