PrePostProcessT.java 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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 util.Util;
  10. public class PrePostProcessT extends Protocol {
  11. public PrePostProcessT(Communication con1, Communication con2) {
  12. super(con1, con2);
  13. }
  14. public void runE(PreData predata, Timer timer) {
  15. timer.start(P.PPT, M.offline_read);
  16. predata.ppt_Li = con1.read();
  17. predata.ppt_Lip1 = con1.read();
  18. predata.ppt_s = con1.readObject();
  19. timer.stop(P.PPT, M.offline_read);
  20. }
  21. public void runD(PreData predata, PreData prev, int LiBytes, int Lip1Bytes, int tau, Timer timer) {
  22. timer.start(P.PPT, M.offline_comp);
  23. if (prev != null)
  24. predata.ppt_Li = prev.ppt_Lip1;
  25. else
  26. predata.ppt_Li = Util.nextBytes(LiBytes, Crypto.sr);
  27. predata.ppt_Lip1 = Util.nextBytes(Lip1Bytes, Crypto.sr);
  28. int twoTauPow = (int) Math.pow(2, tau);
  29. predata.ppt_alpha = Crypto.sr.nextInt(tau);
  30. predata.ppt_r = new byte[twoTauPow][];
  31. predata.ppt_s = new byte[twoTauPow][];
  32. for (int i = 0; i < twoTauPow; i++) {
  33. predata.ppt_r[i] = Util.nextBytes(Lip1Bytes, Crypto.sr);
  34. predata.ppt_s[i] = predata.ppt_r[i];
  35. }
  36. predata.ppt_s[predata.ppt_alpha] = Util.xor(predata.ppt_r[predata.ppt_alpha], predata.ppt_Lip1);
  37. timer.start(P.PPT, M.offline_write);
  38. con1.write(predata.ppt_Li);
  39. con1.write(predata.ppt_Lip1);
  40. con2.write(predata.ppt_alpha);
  41. con2.write(predata.ppt_r);
  42. con1.write(predata.ppt_s);
  43. timer.stop(P.PPT, M.offline_write);
  44. timer.stop(P.PPT, M.offline_comp);
  45. }
  46. public void runC(PreData predata, PreData prev, int LiBytes, int Lip1Bytes, Timer timer) {
  47. timer.start(P.PPT, M.offline_comp);
  48. if (prev != null)
  49. predata.ppt_Li = prev.ppt_Lip1;
  50. else
  51. predata.ppt_Li = Util.nextBytes(LiBytes, Crypto.sr);
  52. predata.ppt_Lip1 = Util.nextBytes(Lip1Bytes, Crypto.sr);
  53. timer.start(P.PPT, M.offline_read);
  54. predata.ppt_alpha = con2.readObject();
  55. predata.ppt_r = con2.readObject();
  56. timer.stop(P.PPT, M.offline_read);
  57. timer.stop(P.PPT, M.offline_comp);
  58. }
  59. @Override
  60. public void run(Party party, Metadata md, Forest forest) {
  61. }
  62. }