blob: 9058189e4ecd329bae235e420b70b9d53fdf2cf6 [file] [log] [blame]
Madan Jampani762246d2015-07-21 15:40:59 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2016-present Open Networking Foundation
Madan Jampani762246d2015-07-21 15:40:59 -07003 *
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 Jampani762246d2015-07-21 15:40:59 -070017
Madan Jampani1beb60c2016-02-03 12:14:57 -080018import java.util.function.Supplier;
19
Jordan Halterman400bbe52018-04-05 23:07:47 -070020import org.onosproject.store.serializers.KryoNamespaces;
Madan Jampanidfde6ba2016-01-13 21:36:09 -080021import org.onosproject.store.service.AsyncAtomicValue;
Madan Jampani762246d2015-07-21 15:40:59 -070022import org.onosproject.store.service.AtomicValueBuilder;
23import org.onosproject.store.service.ConsistentMapBuilder;
Jordan Halterman400bbe52018-04-05 23:07:47 -070024import org.onosproject.store.service.Serializer;
Madan Jampanie17d3282016-02-03 15:30:57 -080025
26import static com.google.common.base.Preconditions.checkNotNull;
Madan Jampani762246d2015-07-21 15:40:59 -070027
28/**
29 * Default implementation of AtomicValueBuilder.
30 *
31 * @param <V> value type
32 */
Madan Jampanie17d3282016-02-03 15:30:57 -080033public class DefaultAtomicValueBuilder<V> extends AtomicValueBuilder<V> {
Madan Jampani762246d2015-07-21 15:40:59 -070034
Madan Jampani533ef982016-02-01 00:16:35 -080035 private ConsistentMapBuilder<String, byte[]> mapBuilder;
Madan Jampani762246d2015-07-21 15:40:59 -070036
Madan Jampani1beb60c2016-02-03 12:14:57 -080037 public DefaultAtomicValueBuilder(Supplier<ConsistentMapBuilder<String, byte[]>> mapBuilderSupplier) {
38 mapBuilder = mapBuilderSupplier.get();
Madan Jampani762246d2015-07-21 15:40:59 -070039 }
40
41 @Override
Madan Jampanie17d3282016-02-03 15:30:57 -080042 public AsyncAtomicValue<V> build() {
Jordan Halterman400bbe52018-04-05 23:07:47 -070043 if (compatibilityFunction != null) {
44 Serializer serializer = Serializer.using(KryoNamespaces.API, CompatibleValue.class);
45
46 AsyncAtomicValue<CompatibleValue<byte[]>> rawValue = new DefaultAsyncAtomicValue<>(
47 checkNotNull(name()), serializer, mapBuilder.buildAsyncMap());
48
49 AsyncAtomicValue<CompatibleValue<V>> compatibleValue =
50 DistributedPrimitives.newTranscodingAtomicValue(
51 rawValue,
52 value -> value == null ? null :
53 new CompatibleValue<byte[]>(serializer().encode(value.value()), value.version()),
54 value -> value == null ? null :
55 new CompatibleValue<V>(serializer().decode(value.value()), value.version()));
56 return DistributedPrimitives.newCompatibleAtomicValue(compatibleValue, compatibilityFunction, version());
57 }
58 return new DefaultAsyncAtomicValue<>(
59 checkNotNull(name()),
60 checkNotNull(serializer()),
61 mapBuilder.buildAsyncMap());
Madan Jampani762246d2015-07-21 15:40:59 -070062 }
Madan Jampanie17d3282016-02-03 15:30:57 -080063}