blob: 6f3fadd2babfac506d3dc6f7314655562707b7df [file] [log] [blame]
Madan Jampani619453b2015-07-22 23:47:09 -07001/*
2 * Copyright 2015 Open Networking Laboratory
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
Madan Jampanif4c88502016-01-21 12:35:36 -080016package org.onosproject.store.primitives.impl;
Madan Jampanif1b8e172015-03-23 11:42:02 -070017
Madan Jampanie8af1cc2015-06-23 14:23:31 -070018import org.onosproject.core.ApplicationId;
Madan Jampanif1b8e172015-03-23 11:42:02 -070019import org.onosproject.store.service.AsyncConsistentMap;
20import org.onosproject.store.service.ConsistentMap;
21import org.onosproject.store.service.ConsistentMapBuilder;
22import org.onosproject.store.service.Serializer;
23
Flavio Castro41b1f3a2015-07-31 13:51:32 -070024import static com.google.common.base.Preconditions.checkArgument;
25import static com.google.common.base.Preconditions.checkState;
26
Madan Jampanif1b8e172015-03-23 11:42:02 -070027/**
28 * Default Consistent Map builder.
29 *
30 * @param <K> type for map key
31 * @param <V> type for map value
32 */
33public class DefaultConsistentMapBuilder<K, V> implements ConsistentMapBuilder<K, V> {
34
35 private Serializer serializer;
36 private String name;
Madan Jampanie8af1cc2015-06-23 14:23:31 -070037 private ApplicationId applicationId;
38 private boolean purgeOnUninstall = false;
Madan Jampanif1b8e172015-03-23 11:42:02 -070039 private boolean partitionsEnabled = true;
Madan Jampani02b7fb82015-05-01 13:01:20 -070040 private boolean readOnly = false;
Flavio Castro41b1f3a2015-07-31 13:51:32 -070041 private boolean metering = true;
Madan Jampani3d6a2f62015-08-12 07:19:07 -070042 private boolean relaxedReadConsistency = false;
Madan Jampani50589ac2015-06-08 11:38:46 -070043 private final DatabaseManager manager;
Madan Jampani28b2cd62016-02-02 10:49:52 -080044 private static final long DEFAULT_OPERATION_TIMEOUT_MILLIS = 5000L;
Madan Jampanif1b8e172015-03-23 11:42:02 -070045
Madan Jampani50589ac2015-06-08 11:38:46 -070046 public DefaultConsistentMapBuilder(DatabaseManager manager) {
47 this.manager = manager;
Madan Jampanif1b8e172015-03-23 11:42:02 -070048 }
49
50 @Override
51 public ConsistentMapBuilder<K, V> withName(String name) {
52 checkArgument(name != null && !name.isEmpty());
53 this.name = name;
54 return this;
55 }
56
57 @Override
Madan Jampanie8af1cc2015-06-23 14:23:31 -070058 public ConsistentMapBuilder<K, V> withApplicationId(ApplicationId id) {
59 checkArgument(id != null);
60 this.applicationId = id;
61 return this;
62 }
63
64 @Override
65 public ConsistentMapBuilder<K, V> withPurgeOnUninstall() {
66 purgeOnUninstall = true;
67 return this;
68 }
69
70 @Override
Flavio Castro41b1f3a2015-07-31 13:51:32 -070071 public ConsistentMapBuilder<K, V> withMeteringDisabled() {
72 metering = false;
73 return this;
74 }
75
76 @Override
Madan Jampanif1b8e172015-03-23 11:42:02 -070077 public ConsistentMapBuilder<K, V> withSerializer(Serializer serializer) {
78 checkArgument(serializer != null);
79 this.serializer = serializer;
80 return this;
81 }
82
83 @Override
84 public ConsistentMapBuilder<K, V> withPartitionsDisabled() {
85 partitionsEnabled = false;
86 return this;
87 }
88
Madan Jampani02b7fb82015-05-01 13:01:20 -070089 @Override
90 public ConsistentMapBuilder<K, V> withUpdatesDisabled() {
91 readOnly = true;
92 return this;
93 }
94
Madan Jampani3d6a2f62015-08-12 07:19:07 -070095 @Override
96 public ConsistentMapBuilder<K, V> withRelaxedReadConsistency() {
97 relaxedReadConsistency = true;
98 return this;
99 }
100
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700101 private void validateInputs() {
102 checkState(name != null, "name must be specified");
103 checkState(serializer != null, "serializer must be specified");
104 if (purgeOnUninstall) {
105 checkState(applicationId != null, "ApplicationId must be specified when purgeOnUninstall is enabled");
106 }
Madan Jampanif1b8e172015-03-23 11:42:02 -0700107 }
108
109 @Override
110 public ConsistentMap<K, V> build() {
Madan Jampani28b2cd62016-02-02 10:49:52 -0800111 return buildAndRegisterMap().asConsistentMap(DEFAULT_OPERATION_TIMEOUT_MILLIS);
Madan Jampanif1b8e172015-03-23 11:42:02 -0700112 }
113
114 @Override
115 public AsyncConsistentMap<K, V> buildAsyncMap() {
Madan Jampani50589ac2015-06-08 11:38:46 -0700116 return buildAndRegisterMap();
117 }
118
119 private DefaultAsyncConsistentMap<K, V> buildAndRegisterMap() {
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700120 validateInputs();
Madan Jampani3d6a2f62015-08-12 07:19:07 -0700121 Database database = partitionsEnabled ? manager.partitionedDatabase : manager.inMemoryDatabase;
122 if (relaxedReadConsistency) {
123 return manager.registerMap(
124 new AsyncCachingConsistentMap<>(name,
125 applicationId,
126 database,
127 serializer,
128 readOnly,
129 purgeOnUninstall,
130 metering));
131 } else {
132 return manager.registerMap(
133 new DefaultAsyncConsistentMap<>(name,
134 applicationId,
135 database,
136 serializer,
137 readOnly,
138 purgeOnUninstall,
139 metering));
140 }
Madan Jampanif1b8e172015-03-23 11:42:02 -0700141 }
142}