summaryrefslogtreecommitdiff
path: root/same/src/main/java/com/orbekk/same/Client.java
diff options
context:
space:
mode:
authorKjetil Ørbekk <kjetil.orbekk@gmail.com>2012-02-06 21:34:42 +0100
committerKjetil Ørbekk <kjetil.orbekk@gmail.com>2012-02-06 21:34:42 +0100
commit7e8f0f25129785068db661cab80cc13d658120a4 (patch)
tree10ef32cded6f01477495a80ad509165d38910cf6 /same/src/main/java/com/orbekk/same/Client.java
parent5a6fc8506af742694c856215dc0e182ba8790c08 (diff)
Support setting state in StateServlet.
Diffstat (limited to 'same/src/main/java/com/orbekk/same/Client.java')
-rw-r--r--same/src/main/java/com/orbekk/same/Client.java17
1 files changed, 17 insertions, 0 deletions
diff --git a/same/src/main/java/com/orbekk/same/Client.java b/same/src/main/java/com/orbekk/same/Client.java
index 2a5f11e..60faf1b 100644
--- a/same/src/main/java/com/orbekk/same/Client.java
+++ b/same/src/main/java/com/orbekk/same/Client.java
@@ -28,6 +28,23 @@ public class Client implements DiscoveryListener {
public State getState() {
return new State(state);
}
+
+ public void set(String name, String data) throws UpdateConflict {
+ String masterUrl = state.getDataOf(".masterUrl");
+ long revision = state.getRevision(name) + 1;
+ MasterService master = connections.getMaster(masterUrl);
+ try {
+ boolean success = master.updateStateRequest(name, data,
+ revision);
+ if (!success) {
+ throw new UpdateConflict("State update conflict when " +
+ "updating " + name);
+ }
+ } catch (Exception e) {
+ logger.error("Unable to contact master. Update fails.", e);
+ throw new UpdateConflict("Unable to contact master. Update fails.");
+ }
+ }
}
private ClientInterface clientInterface = new ClientInterface();