PreReshuffle.java 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package protocols;
  2. import communication.Communication;
  3. import crypto.Crypto;
  4. import measure.M;
  5. import measure.P;
  6. import measure.Timer;
  7. import oram.Forest;
  8. import oram.Metadata;
  9. import oram.Tuple;
  10. import util.Util;
  11. public class PreReshuffle extends Protocol {
  12. public PreReshuffle(Communication con1, Communication con2) {
  13. super(con1, con2);
  14. }
  15. public void runE(PreData predata, Timer timer) {
  16. timer.start(P.RSF, M.offline_comp);
  17. predata.reshuffle_pi = Util.inversePermutation(predata.access_sigma);
  18. timer.start(P.RSF, M.offline_read);
  19. predata.reshuffle_r = con1.readObject();
  20. timer.stop(P.RSF, M.offline_read);
  21. timer.stop(P.RSF, M.offline_comp);
  22. }
  23. public void runD(PreData predata, int[] tupleParam, Timer timer) {
  24. timer.start(P.RSF, M.offline_comp);
  25. predata.reshuffle_pi = Util.inversePermutation(predata.access_sigma);
  26. int numTuples = predata.reshuffle_pi.length;
  27. predata.reshuffle_p = new Tuple[numTuples];
  28. predata.reshuffle_r = new Tuple[numTuples];
  29. Tuple[] a = new Tuple[numTuples];
  30. for (int i = 0; i < numTuples; i++) {
  31. predata.reshuffle_p[i] = new Tuple(tupleParam[0], tupleParam[1], tupleParam[2], tupleParam[3], Crypto.sr);
  32. predata.reshuffle_r[i] = new Tuple(tupleParam[0], tupleParam[1], tupleParam[2], tupleParam[3], Crypto.sr);
  33. a[i] = predata.reshuffle_p[i].xor(predata.reshuffle_r[i]);
  34. }
  35. predata.reshuffle_a_prime = Util.permute(a, predata.reshuffle_pi);
  36. timer.start(P.RSF, M.offline_write);
  37. con2.write(predata.reshuffle_p);
  38. con2.write(predata.reshuffle_a_prime);
  39. con1.write(predata.reshuffle_r);
  40. timer.stop(P.RSF, M.offline_write);
  41. timer.stop(P.RSF, M.offline_comp);
  42. }
  43. public void runC(PreData predata, Timer timer) {
  44. timer.start(P.RSF, M.offline_read);
  45. predata.reshuffle_p = con2.readObject();
  46. predata.reshuffle_a_prime = con2.readObject();
  47. timer.stop(P.RSF, M.offline_read);
  48. }
  49. @Override
  50. public void run(Party party, Metadata md, Forest forest) {
  51. }
  52. }