All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.onosproject.net.PipelineTraceableInput Maven / Gradle / Ivy

There is a newer version: 2.7.0
Show newest version
/*
 * Copyright 2020-present Open Networking Foundation
 *
 * 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 org.onosproject.net;

import com.google.common.collect.Lists;
import com.google.common.collect.Maps;
import org.onosproject.core.GroupId;
import org.onosproject.net.flow.FlowEntry;
import org.onosproject.net.group.Group;

import java.util.List;
import java.util.Map;

/**
 * Represents the input of the pipeline traceable processing.
 */
public final class PipelineTraceableInput {

    // Input state for the traceable behavior
    private PipelineTraceablePacket ingressPacket;
    private ConnectPoint ingressPort;
    // List here all possible device state using
    // possibly an optimized reference
    private List flows = Lists.newArrayList();
    private Map groups = Maps.newHashMap();
    private List deviceState;

    /**
     * Builds a pipeline traceable input.
     *
     * @param ingressPacket the input packet
     * @param ingressPort the input port
     * @param deviceState the device state
     */
    public PipelineTraceableInput(PipelineTraceablePacket ingressPacket, ConnectPoint ingressPort,
                                  List deviceState) {
        this.ingressPacket = ingressPacket;
        this.ingressPort = ingressPort;
        this.deviceState = deviceState;
        processDeviceState(deviceState);
    }

    // Init internal device state (flows, groups, etc)
    private void processDeviceState(List deviceState) {
        deviceState.forEach(entity -> {
            if (entity.getType() == DataPlaneEntity.Type.FLOWRULE) {
                flows.add(entity.getFlowEntry());
            } else if (entity.getType() == DataPlaneEntity.Type.GROUP) {
                groups.put(entity.getGroupEntry().id(), entity.getGroupEntry());
            }
        });
    }

    /**
     * Getter for the ingress packet.
     *
     * @return the ingress packet
     */
    public PipelineTraceablePacket ingressPacket() {
        return ingressPacket;
    }

    /**
     * Getter for the ingress port.
     *
     * @return the ingress port
     */
    public ConnectPoint ingressPort() {
        return ingressPort;
    }

    /**
     * Getter for the device state.
     *
     * @return the device state
     */
    public List deviceState() {
        return deviceState;
    }

    /**
     * Getter for the flows.
     *
     * @return the flows
     */
    public List flows() {
        return flows;
    }

    /**
     * Getter for the groups.
     *
     * @return the groups
     */
    public Map groups() {
        return groups;
    }

    /**
     * Returns the group associated with the given group id.
     *
     * @param groupId the group id
     * @return the group, otherwise null.
     */
    public Group groupById(GroupId groupId) {
        return groups.get(groupId);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy