From 220bb30a4056a5d1b64b29ef4c1730f8bf5e44a1 Mon Sep 17 00:00:00 2001 From: bdemsky Date: Sat, 23 Jul 2016 21:32:06 -0700 Subject: [PATCH] more updates --- src/java/iotcloud/CloudComm.java | 3 ++ src/java/iotcloud/Slot.java | 4 +++ src/java/iotcloud/SlotBuffer.java | 6 ++++ src/java/iotcloud/Table.java | 43 ++++++++++++++++++++++------ src/java/iotcloud/Test.java | 21 ++++++++++++++ src/java/iotcloud/TestCloudComm.java | 35 ++++++++++++++++++++++ 6 files changed, 103 insertions(+), 9 deletions(-) create mode 100644 src/java/iotcloud/Test.java create mode 100644 src/java/iotcloud/TestCloudComm.java diff --git a/src/java/iotcloud/CloudComm.java b/src/java/iotcloud/CloudComm.java index 1993a8d..6d421b5 100644 --- a/src/java/iotcloud/CloudComm.java +++ b/src/java/iotcloud/CloudComm.java @@ -10,6 +10,9 @@ class CloudComm { Cipher decryptcipher; Mac mac; + CloudComm() { + } + CloudComm(String _baseurl, Cipher _encrypt, Cipher _decrypt, Mac _mac) { this.baseurl=_baseurl; this.encryptcipher = _encrypt; diff --git a/src/java/iotcloud/Slot.java b/src/java/iotcloud/Slot.java index dc5389e..115c761 100644 --- a/src/java/iotcloud/Slot.java +++ b/src/java/iotcloud/Slot.java @@ -33,6 +33,10 @@ class Slot implements Liveness { this(_seqnum, _machineid, _prevhmac, new byte[HMAC_SIZE]); } + Slot(long _seqnum, long _machineid) { + this(_seqnum, _machineid, new byte[HMAC_SIZE], new byte[HMAC_SIZE]); + } + byte[] getHMAC() { return hmac; } diff --git a/src/java/iotcloud/SlotBuffer.java b/src/java/iotcloud/SlotBuffer.java index 8a8662b..e3ababf 100644 --- a/src/java/iotcloud/SlotBuffer.java +++ b/src/java/iotcloud/SlotBuffer.java @@ -10,6 +10,8 @@ class SlotBuffer { SlotBuffer() { array=new Slot[DEFAULT_SIZE+1]; + head=tail=0; + oldestseqn=0; } int size() { @@ -18,6 +20,10 @@ class SlotBuffer { return (array.length + head) - tail; } + int capacity() { + return array.length - 1; + } + void resize(int newsize) { if (newsize == (array.length-1)) return; diff --git a/src/java/iotcloud/Table.java b/src/java/iotcloud/Table.java index c2adbc9..c31aed8 100644 --- a/src/java/iotcloud/Table.java +++ b/src/java/iotcloud/Table.java @@ -21,10 +21,18 @@ final public class Table { public Table(String baseurl, String password, long _localmachineid) { localmachineid=_localmachineid; buffer = new SlotBuffer(); + numslots = buffer.capacity(); sequencenumber = 1; initCloud(baseurl, password); } + public Table(CloudComm _cloud, long _localmachineid) { + localmachineid=_localmachineid; + buffer = new SlotBuffer(); + sequencenumber = 1; + cloud=_cloud; + } + private void initCloud(String baseurl, String password) { try { SecretKeySpec secret=getKey(password); @@ -64,21 +72,37 @@ final public class Table { return null; } + public void initTable() { + Slot s=new Slot(1, localmachineid); + TableStatus status=new TableStatus(s, numslots); + s.addEntry(status); + Slot[] array=cloud.putSlot(s, numslots); + if (array == null) { + array = new Slot[] {s}; + validateandupdate(array); // update data structure + } else { + throw new Error("Error on initialization"); + } + } + public IoTString put(IoTString key, IoTString value) { while(true) { KeyValue oldvalue=table.get(key); - if (tryput(key, value)) { + if (tryput(key, value, false)) { return oldvalue.getValue(); } } } - private boolean tryput(IoTString key, IoTString value) { - Slot s=new Slot(sequencenumber+1, localmachineid, buffer.getSlot(sequencenumber).getHMAC()); - boolean forcedresize = false; - + private boolean tryput(IoTString key, IoTString value, boolean forcedresize) { + Slot s=new Slot(sequencenumber+1, localmachineid, buffer.getSlot(sequencenumber).getHMAC()); long seqn = buffer.getOldestSeqNum(); - + + if (forcedresize) { + TableStatus status=new TableStatus(s, FORCED_RESIZE_INCREMENT + numslots); + s.addEntry(status); + } + if ((numslots - buffer.size()) < FREE_SLOTS) { //have to check whether we have enough free slots seqn = buffer.getNewestSeqNum() + 1 - numslots; @@ -93,9 +117,10 @@ final public class Table { else if (i==0) { if (s.canFit(liveentry)) s.addEntry(liveentry); - else - forcedresize = true; - } + else if (!forcedresize) { + return tryput(key, value, true); + } + } } } } diff --git a/src/java/iotcloud/Test.java b/src/java/iotcloud/Test.java new file mode 100644 index 0000000..5ecd9d2 --- /dev/null +++ b/src/java/iotcloud/Test.java @@ -0,0 +1,21 @@ +package iotcloud; + +public class Test { + public static void main(String[] args) { + TestCloudComm cc=new TestCloudComm(); + Table t1=new Table(cc, 6513); + t1.initTable(); + Table t2=new Table(cc, 6512); + t2.update(); + for(int i=0;i<100;i++) { + String a="STR"+i; + String b="ABR"+i; + IoTString ia=new IoTString(a); + IoTString ib=new IoTString(b); + t1.put(ia, ia); + t2.put(ib, ib); + System.out.println(ib+"->"+t1.get(ib)); + System.out.println(ia+"->"+t2.get(ia)); + } + } +} diff --git a/src/java/iotcloud/TestCloudComm.java b/src/java/iotcloud/TestCloudComm.java new file mode 100644 index 0000000..ce5b9ba --- /dev/null +++ b/src/java/iotcloud/TestCloudComm.java @@ -0,0 +1,35 @@ +package iotcloud; +import java.io.*; +import java.net.*; +import java.util.Arrays; +import javax.crypto.*; + +class TestCloudComm extends CloudComm { + SlotBuffer buffer; + + TestCloudComm() { + buffer = new SlotBuffer(); + } + + public synchronized Slot[] putSlot(Slot slot, int max) { + if (buffer.getNewestSeqNum()+1 == slot.getSequenceNumber()) { + if (max!=0) + buffer.resize(max); + buffer.putSlot(slot); + return null; + } else + return getSlots(slot.getSequenceNumber()); + } + + public synchronized Slot[] getSlots(long sequencenumber) { + long newestseqnum=buffer.getNewestSeqNum(); + long oldestseqnum=buffer.getOldestSeqNum(); + if (sequencenumber < oldestseqnum) + sequencenumber=oldestseqnum; + int numslots=(int)((newestseqnum - sequencenumber)+1); + Slot[] slots=new Slot[numslots]; + for(int i=0;i