/* * Copyright (c) 2016 Cisco and/or its affiliates. * * 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 io.fd.honeycomb.translate.spi.read; import com.google.common.annotations.Beta; import io.fd.honeycomb.translate.read.ReadContext; import io.fd.honeycomb.translate.read.ReadFailedException; import javax.annotation.Nonnull; import org.opendaylight.yangtools.concepts.Builder; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; /** * CompositeChildReader SPI to customize its behavior. * * @param Specific DataObject derived type (Identifiable), that is handled by this customizer * @param Specific Builder for handled type (C) */ @Beta public interface ReaderCustomizer> { /** * Creates new builder that will be used to build read value. */ @Nonnull B getBuilder(@Nonnull final InstanceIdentifier id); /** * Adds current data (identified by id) to the provided builder. * * @param id id of current data object * @param builder builder for creating read value * @param ctx context for current read * @throws ReadFailedException if read was unsuccessful */ void readCurrentAttributes(@Nonnull final InstanceIdentifier id, @Nonnull final B builder, @Nonnull final ReadContext ctx) throws ReadFailedException; /** * Merge read data into provided parent builder. */ void merge(@Nonnull final Builder parentBuilder, @Nonnull final O readValue); /** * Check whether the resulting value should be added to the results or ignored. * Invoked after {@link #readCurrentAttributes(InstanceIdentifier, Builder, ReadContext)} * * @param id Keyed instance identifier of read data * @param built Read data as returned from builder * after {@link #readCurrentAttributes(InstanceIdentifier, Builder, ReadContext)} invocation * @param ctx Read context * * @return true if value is present (even if empty) */ default boolean isPresent(final InstanceIdentifier id, final O built, final ReadContext ctx) throws ReadFailedException { // Default impl = check whether read value is empty return !built.equals(getBuilder(id).build()); } }