blob: 0e11794e5b89f2d8f93fa7c21a93c10fed2771ce [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 Jampanif1b8e172015-03-23 11:42:02 -070016package org.onosproject.store.consistent.impl;
17
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 Jampanif1b8e172015-03-23 11:42:02 -070044
Madan Jampani50589ac2015-06-08 11:38:46 -070045 public DefaultConsistentMapBuilder(DatabaseManager manager) {
46 this.manager = manager;
Madan Jampanif1b8e172015-03-23 11:42:02 -070047 }
48
49 @Override
50 public ConsistentMapBuilder<K, V> withName(String name) {
51 checkArgument(name != null && !name.isEmpty());
52 this.name = name;
53 return this;
54 }
55
56 @Override
Madan Jampanie8af1cc2015-06-23 14:23:31 -070057 public ConsistentMapBuilder<K, V> withApplicationId(ApplicationId id) {
58 checkArgument(id != null);
59 this.applicationId = id;
60 return this;
61 }
62
63 @Override
64 public ConsistentMapBuilder<K, V> withPurgeOnUninstall() {
65 purgeOnUninstall = true;
66 return this;
67 }
68
69 @Override
Flavio Castro41b1f3a2015-07-31 13:51:32 -070070 public ConsistentMapBuilder<K, V> withMeteringDisabled() {
71 metering = false;
72 return this;
73 }
74
75 @Override
Madan Jampanif1b8e172015-03-23 11:42:02 -070076 public ConsistentMapBuilder<K, V> withSerializer(Serializer serializer) {
77 checkArgument(serializer != null);
78 this.serializer = serializer;
79 return this;
80 }
81
82 @Override
83 public ConsistentMapBuilder<K, V> withPartitionsDisabled() {
84 partitionsEnabled = false;
85 return this;
86 }
87
Madan Jampani02b7fb82015-05-01 13:01:20 -070088 @Override
89 public ConsistentMapBuilder<K, V> withUpdatesDisabled() {
90 readOnly = true;
91 return this;
92 }
93
Madan Jampani3d6a2f62015-08-12 07:19:07 -070094 @Override
95 public ConsistentMapBuilder<K, V> withRelaxedReadConsistency() {
96 relaxedReadConsistency = true;
97 return this;
98 }
99
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700100 private void validateInputs() {
101 checkState(name != null, "name must be specified");
102 checkState(serializer != null, "serializer must be specified");
103 if (purgeOnUninstall) {
104 checkState(applicationId != null, "ApplicationId must be specified when purgeOnUninstall is enabled");
105 }
Madan Jampanif1b8e172015-03-23 11:42:02 -0700106 }
107
108 @Override
109 public ConsistentMap<K, V> build() {
Madan Jampani50589ac2015-06-08 11:38:46 -0700110 return new DefaultConsistentMap<>(buildAndRegisterMap());
Madan Jampanif1b8e172015-03-23 11:42:02 -0700111 }
112
113 @Override
114 public AsyncConsistentMap<K, V> buildAsyncMap() {
Madan Jampani50589ac2015-06-08 11:38:46 -0700115 return buildAndRegisterMap();
116 }
117
118 private DefaultAsyncConsistentMap<K, V> buildAndRegisterMap() {
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700119 validateInputs();
Madan Jampani3d6a2f62015-08-12 07:19:07 -0700120 Database database = partitionsEnabled ? manager.partitionedDatabase : manager.inMemoryDatabase;
121 if (relaxedReadConsistency) {
122 return manager.registerMap(
123 new AsyncCachingConsistentMap<>(name,
124 applicationId,
125 database,
126 serializer,
127 readOnly,
128 purgeOnUninstall,
129 metering));
130 } else {
131 return manager.registerMap(
132 new DefaultAsyncConsistentMap<>(name,
133 applicationId,
134 database,
135 serializer,
136 readOnly,
137 purgeOnUninstall,
138 metering));
139 }
Madan Jampanif1b8e172015-03-23 11:42:02 -0700140 }
141}