CLI.java 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274
  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 if (protocol.equals("ssot")) {
  95. operation = SSOT.class;
  96. } else {
  97. System.out.println("Protocol " + protocol + " not supported");
  98. System.exit(-1);
  99. }
  100. Constructor<? extends Protocol> operationCtor = null;
  101. try {
  102. operationCtor = operation.getDeclaredConstructor(Communication.class, Communication.class);
  103. } catch (NoSuchMethodException | SecurityException e1) {
  104. e1.printStackTrace();
  105. }
  106. // For now all logic happens here. Eventually this will get wrapped
  107. // up in party specific classes.
  108. System.out.println("Starting " + party + "...");
  109. Metadata md = new Metadata(configFile);
  110. int numComs = Global.pipeline ? md.getNumTrees() + 1 : 1;
  111. Communication[] con1 = new Communication[numComs];
  112. Communication[] con2 = new Communication[numComs];
  113. if (party.equals("eddie")) {
  114. System.out.print("Waiting to establish debbie connections...");
  115. for (int i = 0; i < numComs; i++) {
  116. con1[i] = new Communication();
  117. con1[i].start(eddiePort1);
  118. eddiePort1 += 3;
  119. while (con1[i].getState() != Communication.STATE_CONNECTED)
  120. ;
  121. }
  122. System.out.println(" done!");
  123. System.out.print("Waiting to establish charlie connections...");
  124. for (int i = 0; i < numComs; i++) {
  125. con2[i] = new Communication();
  126. con2[i].start(eddiePort2);
  127. eddiePort2 += 3;
  128. while (con2[i].getState() != Communication.STATE_CONNECTED)
  129. ;
  130. }
  131. System.out.println(" done!");
  132. for (int i = 0; i < numComs; i++) {
  133. con1[i].setTcpNoDelay(true);
  134. con2[i].setTcpNoDelay(true);
  135. }
  136. try {
  137. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  138. if (protocol.equals("pirrtv")) {
  139. ((PIRRetrieve) p).setCons(con1, con2);
  140. }
  141. if (!Global.usePIR) {
  142. p.run(Party.Eddie, md, forestFile);
  143. } else {
  144. p.run(Party.Eddie, md);
  145. }
  146. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  147. | InvocationTargetException e) {
  148. e.printStackTrace();
  149. }
  150. } else if (party.equals("debbie")) {
  151. System.out.print("Waiting to establish eddie connections...");
  152. for (int i = 0; i < numComs; i++) {
  153. con1[i] = new Communication();
  154. InetSocketAddress addr = new InetSocketAddress(eddieIp, eddiePort1);
  155. con1[i].connect(addr);
  156. eddiePort1 += 3;
  157. while (con1[i].getState() != Communication.STATE_CONNECTED)
  158. ;
  159. }
  160. System.out.println(" done!");
  161. System.out.print("Waiting to establish charlie connections...");
  162. for (int i = 0; i < numComs; i++) {
  163. con2[i] = new Communication();
  164. con2[i].start(debbiePort);
  165. debbiePort += 3;
  166. while (con2[i].getState() != Communication.STATE_CONNECTED)
  167. ;
  168. }
  169. System.out.println(" done!");
  170. for (int i = 0; i < numComs; i++) {
  171. con1[i].setTcpNoDelay(true);
  172. con2[i].setTcpNoDelay(true);
  173. }
  174. try {
  175. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  176. if (protocol.equals("pirrtv")) {
  177. ((PIRRetrieve) p).setCons(con1, con2);
  178. }
  179. if (!Global.usePIR) {
  180. p.run(Party.Debbie, md, forestFile);
  181. } else {
  182. p.run(Party.Debbie, md);
  183. }
  184. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  185. | InvocationTargetException e) {
  186. e.printStackTrace();
  187. }
  188. } else if (party.equals("charlie")) {
  189. System.out.print("Waiting to establish eddie connections...");
  190. for (int i = 0; i < numComs; i++) {
  191. con1[i] = new Communication();
  192. InetSocketAddress addr = new InetSocketAddress(eddieIp, eddiePort2);
  193. con1[i].connect(addr);
  194. eddiePort2 += 3;
  195. while (con1[i].getState() != Communication.STATE_CONNECTED)
  196. ;
  197. }
  198. System.out.println(" done!");
  199. System.out.print("Waiting to establish debbie connections...");
  200. for (int i = 0; i < numComs; i++) {
  201. con2[i] = new Communication();
  202. InetSocketAddress addr = new InetSocketAddress(debbieIp, debbiePort);
  203. con2[i].connect(addr);
  204. debbiePort += 3;
  205. while (con2[i].getState() != Communication.STATE_CONNECTED)
  206. ;
  207. }
  208. System.out.println(" done!");
  209. for (int i = 0; i < numComs; i++) {
  210. con1[i].setTcpNoDelay(true);
  211. con2[i].setTcpNoDelay(true);
  212. }
  213. try {
  214. Protocol p = operationCtor.newInstance(con1[0], con2[0]);
  215. if (protocol.equals("pirrtv")) {
  216. ((PIRRetrieve) p).setCons(con1, con2);
  217. }
  218. if (!Global.usePIR) {
  219. p.run(Party.Charlie, md, forestFile);
  220. } else {
  221. p.run(Party.Charlie, md);
  222. }
  223. } catch (InstantiationException | IllegalAccessException | IllegalArgumentException
  224. | InvocationTargetException e) {
  225. e.printStackTrace();
  226. }
  227. } else {
  228. throw new NoSuchPartyException(party);
  229. }
  230. try {
  231. Thread.sleep(1000);
  232. } catch (InterruptedException e) {
  233. e.printStackTrace();
  234. }
  235. for (int i = 0; i < numComs; i++) {
  236. con1[i].stop();
  237. con2[i].stop();
  238. }
  239. System.out.println(party + " exiting...");
  240. }
  241. }