org.onosproject.net.optical.config.OpticalPortConfig Maven / Gradle / Ivy
/*
* Copyright 2016-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.optical.config;
import java.util.Optional;
import org.onosproject.net.config.Config;
import org.onosproject.net.ConnectPoint;
import org.onosproject.net.Port;
import com.fasterxml.jackson.databind.JsonNode;
import static org.onosproject.net.config.Config.FieldPresence.OPTIONAL;
/**
* Configurations for an optical port on a device.
*
*
* Example:
*
* "ports": {
* "(device Id)/(port number)": {
* {@value #CONFIG_KEY}: {
* {@value #TYPE}: "OCH",
* {@value #SPEED}: 0,
* {@value #PORT}: 10
* ...
* }
* }
* }
*
*/
public final class OpticalPortConfig extends Config {
/**
* Configuration key for {@link OpticalPortConfig}.
*/
public static final String CONFIG_KEY = "optical";
// optical type {OMS, OCH, ODUClt, fiber}
public static final String TYPE = "type";
// port name. "name" is the alphanumeric name of the port, but "port" refers
// to the port number used as a name string (i.e., for ports without
// alphanumeric names).
public static final String NAME = "name";
public static final String PORT = "port";
public static final String STATIC_PORT = "staticPort";
public static final String STATIC_LAMBDA = "staticLambda";
// **Linc-OE : remove if it's not needed after all.**
public static final String SPEED = "speed";
@Override
public boolean isValid() {
return hasOnlyFields(TYPE, NAME, PORT, STATIC_PORT, STATIC_LAMBDA, SPEED) &&
isNumber(STATIC_LAMBDA, OPTIONAL) && isNumber(SPEED, OPTIONAL);
}
/**
* Returns the Enum value representing the type of port.
*
* @return the port type, or null if invalid or unset
*/
public Port.Type type() {
JsonNode type = object.path(TYPE);
if (type.isMissingNode()) {
return null;
}
return Port.Type.valueOf(type.asText());
}
/**
* Returns the port name associated with this port configuration. The Name
* is an alphanumeric string.
*
* @return the name of this port, else, an empty string
*/
public String name() {
return getStringValue(NAME);
}
/**
* Returns a stringified representation of the port number, configured in
* some port types without an alphanumeric name as the port name.
*
* @return A string representation of the port number
*/
public String numberName() {
return getStringValue(PORT);
}
/**
* Returns the string-representation of name of the output port. This is
* usually an OMS port for an OCH input ports, or an OCH port for ODU input
* ports.
*
* @return the name of this port, else, an empty string
*/
public String staticPort() {
return getStringValue(STATIC_PORT);
}
private String getStringValue(String field) {
JsonNode name = object.path(field);
return name.isMissingNode() ? "" : name.asText();
}
/**
* Returns the output lambda configured for this port. The lambda value is
* expressed as a frequency value. If the port type doesn't have a notion of
* lambdas, this returns an empty Optional.
*
* @return an Optional that may contain a frequency value.
*/
public Optional staticLambda() {
JsonNode sl = object.path(STATIC_LAMBDA);
if (sl.isMissingNode()) {
return Optional.empty();
}
return Optional.of(sl.asLong());
}
/**
* Returns the port speed configured for this port. If the port doesn't have
* a notion of speed, this returns an empty Optional.
*
* @return a port speed value whose default is 0.
*/
public Optional speed() {
JsonNode s = object.path(SPEED);
if (s.isMissingNode()) {
return Optional.empty();
}
return Optional.of(s.asInt());
}
/**
* Sets the port type, or updates it if it's already set. A null argument removes
* this field.
*
* @param type the port type
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig portType(Port.Type type) {
// if unspecified, ideally fall back on FIBER or PACKET.
String pt = (type == null) ? null : type.toString();
return (OpticalPortConfig) setOrClear(TYPE, pt);
}
/**
* Sets the port name, or updates it if already set. A null argument removes
* this field.
*
* @param name the port's name
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig portName(String name) {
return (OpticalPortConfig) setOrClear(NAME, name);
}
/**
* Sets the port name from port number, or updates it if already set. A null
* argument removes this field.
*
* @param name the port number, to be used as name
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig portNumberName(Long name) {
return (OpticalPortConfig) setOrClear(PORT, name);
}
/**
* Sets the output port name, or updates it if already set. A null argument
* removes this field.
*
* @param name the output port's name
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig staticPort(String name) {
return (OpticalPortConfig) setOrClear(STATIC_PORT, name);
}
/**
* Sets the output lambda center frequency, or updates it if already set.
* A null argument removes this field.
*
* @param index the output lambda
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig staticLambda(Long index) {
return (OpticalPortConfig) setOrClear(STATIC_LAMBDA, index);
}
/**
* Sets the port speed, or updates it if already set. A null argument
* removes this field.
*
* @param bw the port bandwidth
* @return this OpticalPortConfig instance
*/
public OpticalPortConfig speed(Integer bw) {
return (OpticalPortConfig) setOrClear(SPEED, bw);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy