blob: 2b07140567f60113337eac4cb245292254f616e8 [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
18import static com.google.common.base.Preconditions.checkArgument;
19import static com.google.common.base.Preconditions.checkState;
20
Madan Jampanie8af1cc2015-06-23 14:23:31 -070021import org.onosproject.core.ApplicationId;
Madan Jampanif1b8e172015-03-23 11:42:02 -070022import org.onosproject.store.service.AsyncConsistentMap;
23import org.onosproject.store.service.ConsistentMap;
24import org.onosproject.store.service.ConsistentMapBuilder;
Madan Jampani50589ac2015-06-08 11:38:46 -070025import org.onosproject.store.service.MapEvent;
Madan Jampanif1b8e172015-03-23 11:42:02 -070026import org.onosproject.store.service.Serializer;
27
28/**
29 * Default Consistent Map builder.
30 *
31 * @param <K> type for map key
32 * @param <V> type for map value
33 */
34public class DefaultConsistentMapBuilder<K, V> implements ConsistentMapBuilder<K, V> {
35
36 private Serializer serializer;
37 private String name;
Madan Jampanie8af1cc2015-06-23 14:23:31 -070038 private ApplicationId applicationId;
39 private boolean purgeOnUninstall = false;
Madan Jampanif1b8e172015-03-23 11:42:02 -070040 private boolean partitionsEnabled = true;
Madan Jampani02b7fb82015-05-01 13:01:20 -070041 private boolean readOnly = false;
Madan Jampani50589ac2015-06-08 11:38:46 -070042 private final DatabaseManager manager;
Madan Jampanif1b8e172015-03-23 11:42:02 -070043
Madan Jampani50589ac2015-06-08 11:38:46 -070044 public DefaultConsistentMapBuilder(DatabaseManager manager) {
45 this.manager = manager;
Madan Jampanif1b8e172015-03-23 11:42:02 -070046 }
47
48 @Override
49 public ConsistentMapBuilder<K, V> withName(String name) {
50 checkArgument(name != null && !name.isEmpty());
51 this.name = name;
52 return this;
53 }
54
55 @Override
Madan Jampanie8af1cc2015-06-23 14:23:31 -070056 public ConsistentMapBuilder<K, V> withApplicationId(ApplicationId id) {
57 checkArgument(id != null);
58 this.applicationId = id;
59 return this;
60 }
61
62 @Override
63 public ConsistentMapBuilder<K, V> withPurgeOnUninstall() {
64 purgeOnUninstall = true;
65 return this;
66 }
67
68 @Override
Madan Jampanif1b8e172015-03-23 11:42:02 -070069 public ConsistentMapBuilder<K, V> withSerializer(Serializer serializer) {
70 checkArgument(serializer != null);
71 this.serializer = serializer;
72 return this;
73 }
74
75 @Override
76 public ConsistentMapBuilder<K, V> withPartitionsDisabled() {
77 partitionsEnabled = false;
78 return this;
79 }
80
Madan Jampani02b7fb82015-05-01 13:01:20 -070081 @Override
82 public ConsistentMapBuilder<K, V> withUpdatesDisabled() {
83 readOnly = true;
84 return this;
85 }
86
Madan Jampanie8af1cc2015-06-23 14:23:31 -070087 private void validateInputs() {
88 checkState(name != null, "name must be specified");
89 checkState(serializer != null, "serializer must be specified");
90 if (purgeOnUninstall) {
91 checkState(applicationId != null, "ApplicationId must be specified when purgeOnUninstall is enabled");
92 }
Madan Jampanif1b8e172015-03-23 11:42:02 -070093 }
94
95 @Override
96 public ConsistentMap<K, V> build() {
Madan Jampani50589ac2015-06-08 11:38:46 -070097 return new DefaultConsistentMap<>(buildAndRegisterMap());
Madan Jampanif1b8e172015-03-23 11:42:02 -070098 }
99
100 @Override
101 public AsyncConsistentMap<K, V> buildAsyncMap() {
Madan Jampani50589ac2015-06-08 11:38:46 -0700102 return buildAndRegisterMap();
103 }
104
105 private DefaultAsyncConsistentMap<K, V> buildAndRegisterMap() {
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700106 validateInputs();
Madan Jampani50589ac2015-06-08 11:38:46 -0700107 DefaultAsyncConsistentMap<K, V> asyncMap = new DefaultAsyncConsistentMap<>(
Madan Jampanif1b8e172015-03-23 11:42:02 -0700108 name,
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700109 applicationId,
Madan Jampani50589ac2015-06-08 11:38:46 -0700110 partitionsEnabled ? manager.partitionedDatabase : manager.inMemoryDatabase,
Madan Jampani02b7fb82015-05-01 13:01:20 -0700111 serializer,
Madan Jampani50589ac2015-06-08 11:38:46 -0700112 readOnly,
Madan Jampanie8af1cc2015-06-23 14:23:31 -0700113 purgeOnUninstall,
Madan Jampani50589ac2015-06-08 11:38:46 -0700114 event -> manager.clusterCommunicator.<MapEvent<K, V>>broadcast(event,
115 DatabaseManager.mapUpdatesSubject(name),
116 serializer::encode));
Brian O'Connor24cf6562015-06-11 18:42:30 -0700117 return manager.registerMap(asyncMap);
Madan Jampanif1b8e172015-03-23 11:42:02 -0700118 }
119}