diff options
author | Ashlee Young <ashlee@onosfw.com> | 2015-09-09 22:15:21 -0700 |
---|---|---|
committer | Ashlee Young <ashlee@onosfw.com> | 2015-09-09 22:15:21 -0700 |
commit | 13d05bc8458758ee39cb829098241e89616717ee (patch) | |
tree | 22a4d1ce65f15952f07a3df5af4b462b4697cb3a /framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java | |
parent | 6139282e1e93c2322076de4b91b1c85d0bc4a8b3 (diff) |
ONOS checkin based on commit tag e796610b1f721d02f9b0e213cf6f7790c10ecd60
Change-Id: Ife8810491034fe7becdba75dda20de4267bd15cd
Diffstat (limited to 'framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java')
-rw-r--r-- | framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java | 141 |
1 files changed, 141 insertions, 0 deletions
diff --git a/framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java b/framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java new file mode 100644 index 00000000..0e11794e --- /dev/null +++ b/framework/src/onos/core/store/dist/src/main/java/org/onosproject/store/consistent/impl/DefaultConsistentMapBuilder.java @@ -0,0 +1,141 @@ +/* + * Copyright 2015 Open Networking Laboratory + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.onosproject.store.consistent.impl; + +import org.onosproject.core.ApplicationId; +import org.onosproject.store.service.AsyncConsistentMap; +import org.onosproject.store.service.ConsistentMap; +import org.onosproject.store.service.ConsistentMapBuilder; +import org.onosproject.store.service.Serializer; + +import static com.google.common.base.Preconditions.checkArgument; +import static com.google.common.base.Preconditions.checkState; + +/** + * Default Consistent Map builder. + * + * @param <K> type for map key + * @param <V> type for map value + */ +public class DefaultConsistentMapBuilder<K, V> implements ConsistentMapBuilder<K, V> { + + private Serializer serializer; + private String name; + private ApplicationId applicationId; + private boolean purgeOnUninstall = false; + private boolean partitionsEnabled = true; + private boolean readOnly = false; + private boolean metering = true; + private boolean relaxedReadConsistency = false; + private final DatabaseManager manager; + + public DefaultConsistentMapBuilder(DatabaseManager manager) { + this.manager = manager; + } + + @Override + public ConsistentMapBuilder<K, V> withName(String name) { + checkArgument(name != null && !name.isEmpty()); + this.name = name; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withApplicationId(ApplicationId id) { + checkArgument(id != null); + this.applicationId = id; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withPurgeOnUninstall() { + purgeOnUninstall = true; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withMeteringDisabled() { + metering = false; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withSerializer(Serializer serializer) { + checkArgument(serializer != null); + this.serializer = serializer; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withPartitionsDisabled() { + partitionsEnabled = false; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withUpdatesDisabled() { + readOnly = true; + return this; + } + + @Override + public ConsistentMapBuilder<K, V> withRelaxedReadConsistency() { + relaxedReadConsistency = true; + return this; + } + + private void validateInputs() { + checkState(name != null, "name must be specified"); + checkState(serializer != null, "serializer must be specified"); + if (purgeOnUninstall) { + checkState(applicationId != null, "ApplicationId must be specified when purgeOnUninstall is enabled"); + } + } + + @Override + public ConsistentMap<K, V> build() { + return new DefaultConsistentMap<>(buildAndRegisterMap()); + } + + @Override + public AsyncConsistentMap<K, V> buildAsyncMap() { + return buildAndRegisterMap(); + } + + private DefaultAsyncConsistentMap<K, V> buildAndRegisterMap() { + validateInputs(); + Database database = partitionsEnabled ? manager.partitionedDatabase : manager.inMemoryDatabase; + if (relaxedReadConsistency) { + return manager.registerMap( + new AsyncCachingConsistentMap<>(name, + applicationId, + database, + serializer, + readOnly, + purgeOnUninstall, + metering)); + } else { + return manager.registerMap( + new DefaultAsyncConsistentMap<>(name, + applicationId, + database, + serializer, + readOnly, + purgeOnUninstall, + metering)); + } + } +}
\ No newline at end of file |