12345678910111213141516171819202122232425262728293031323334353637 |
- package com.oblivm.backend.gc.regular;
- import java.nio.ByteBuffer;
- import java.security.MessageDigest;
- import com.oblivm.backend.gc.GCSignal;
- final class Garbler {
- private MessageDigest sha1 = null;
- Garbler() {
- try {
- sha1 = MessageDigest.getInstance("SHA-1");
- } catch (Exception e) {
- e.printStackTrace();
- System.exit(1);
- }
- }
- public void enc(GCSignal lb0, GCSignal lb1, long k, GCSignal m, GCSignal ret) {
- getPadding(lb0, lb1, k, ret);
- GCSignal.xor(ret, m, ret);
- }
- public void dec(GCSignal lb0, GCSignal lb1, long k, GCSignal c, GCSignal ret) {
- getPadding(lb0, lb1, k, ret);
- GCSignal.xor(ret, c, ret);
- }
- ByteBuffer buffer = ByteBuffer.allocate(GCSignal.len * 2 + 8);
- private synchronized void getPadding(GCSignal lb0, GCSignal lb1, long k, GCSignal ret) {
- buffer.clear();
- sha1.update((buffer.put(lb0.bytes).put(lb1.bytes).putLong(k)));
- System.arraycopy(sha1.digest(), 0, ret.bytes, 0, GCSignal.len);
- }
- }
|