blob: 9116267e0d4068d8f6386be7cd9bb07d34aa90e3 [file] [log] [blame]
/*
* Copyright 2017-present Open Networking Laboratory
*
* 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.mapping;
import org.onosproject.mapping.addresses.MappingAddress;
import org.onosproject.mapping.instructions.MappingInstruction;
import org.onosproject.net.DeviceId;
import org.onosproject.net.flow.instructions.ExtensionTreatment;
import java.util.List;
/**
* Abstraction of mapping treatment.
*/
public interface MappingTreatment {
/**
* Obtains a mapping address.
*
* @return a mapping address
*/
MappingAddress address();
/**
* Obtains a collection of mapping instructions.
*
* @return a collection of mapping instructions
*/
List<MappingInstruction> instructions();
interface Builder {
/**
* Specifies a mapping address.
*
* @param address mapping address
* @return a mapping treatment builder
*/
Builder withAddress(MappingAddress address);
/**
* Specifies a collection of mapping instructions.
*
* @param instruction a mapping instruction
* @return a mapping treatment builder
*/
Builder add(MappingInstruction instruction);
/**
* Adds an unicast weight instruction.
*
* @param weight unicast weight value
* @return a mapping treatment builder
*/
Builder setUnicastWeight(int weight);
/**
* Adds an unicast priority instruction.
*
* @param priority unicast priority value
* @return a mapping treatment builder
*/
Builder setUnicastPriority(int priority);
/**
* Adds a multicast weight instruction.
*
* @param weight multicast weight value
* @return a mapping treatment builder
*/
Builder setMulticastWeight(int weight);
/**
* Adds a multicast priority instruction.
*
* @param priority multicast priority value
* @return a mapping treatment builder
*/
Builder setMulticastPriority(int priority);
/**
* uses an extension treatment.
*
* @param extension extension treatment
* @param deviceId device identifier
* @return a treatment builder
*/
Builder extension(ExtensionTreatment extension, DeviceId deviceId);
/**
* Builds an immutable mapping treatment.
*
* @return a mapping treatment
*/
MappingTreatment build();
}
}