From 60e9c9071913a28bc14609d37ba8ad2a8389e715 Mon Sep 17 00:00:00 2001 From: Simon Bernard Date: Fri, 21 Jun 2019 15:12:42 +0200 Subject: [PATCH] Make JSONFileBootstapStore thread safe --- .../demo/JSONFileBootstrapStore.java | 40 ++++++++++++++++--- 1 file changed, 34 insertions(+), 6 deletions(-) diff --git a/leshan-bsserver-demo/src/main/java/org/eclipse/leshan/server/bootstrap/demo/JSONFileBootstrapStore.java b/leshan-bsserver-demo/src/main/java/org/eclipse/leshan/server/bootstrap/demo/JSONFileBootstrapStore.java index ffa79dbc31..c43f7fdb4f 100644 --- a/leshan-bsserver-demo/src/main/java/org/eclipse/leshan/server/bootstrap/demo/JSONFileBootstrapStore.java +++ b/leshan-bsserver-demo/src/main/java/org/eclipse/leshan/server/bootstrap/demo/JSONFileBootstrapStore.java @@ -23,6 +23,9 @@ import java.io.OutputStreamWriter; import java.lang.reflect.Type; import java.util.Map; +import java.util.concurrent.locks.Lock; +import java.util.concurrent.locks.ReadWriteLock; +import java.util.concurrent.locks.ReentrantReadWriteLock; import org.eclipse.leshan.server.bootstrap.BootstrapConfig; import org.eclipse.leshan.server.bootstrap.EditableBootstrapConfigStore; @@ -43,6 +46,11 @@ public class JSONFileBootstrapStore extends InMemoryBootstrapConfigStore { private static final Logger LOG = LoggerFactory.getLogger(JSONFileBootstrapStore.class); + // lock for the two maps + private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock(); + private final Lock readLock = readWriteLock.readLock(); + private final Lock writeLock = readWriteLock.writeLock(); + // default location for persistence public static final String DEFAULT_FILE = "data/bootstrap.json"; @@ -68,21 +76,41 @@ public JSONFileBootstrapStore(String filename) { this.loadFromFile(); } + @Override + public Map getBootstrapConfigs() { + readLock.lock(); + try { + return super.getBootstrapConfigs(); + } finally { + readLock.unlock(); + } + } + public void addToStore(String endpoint, BootstrapConfig config) throws InvalidConfigurationException { super.addConfig(endpoint, config); } @Override public void addConfig(String endpoint, BootstrapConfig config) throws InvalidConfigurationException { - addToStore(endpoint, config); - saveToFile(); + writeLock.lock(); + try { + addToStore(endpoint, config); + saveToFile(); + } finally { + writeLock.unlock(); + } } @Override public BootstrapConfig removeConfig(String enpoint) { - BootstrapConfig res = super.removeConfig(enpoint); - saveToFile(); - return res; + writeLock.lock(); + try { + BootstrapConfig res = super.removeConfig(enpoint); + saveToFile(); + return res; + } finally { + writeLock.unlock(); + } } // /////// File persistence @@ -103,7 +131,7 @@ private void loadFromFile() { } } - private synchronized void saveToFile() { + private void saveToFile() { try { // Create file if it does not exists. File file = new File(filename);