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

org.onosproject.net.behaviour.protection.ProtectionConfig 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.behaviour.protection;

import static com.google.common.base.Preconditions.checkNotNull;
import static org.onosproject.net.behaviour.protection.ProtectedTransportEndpointDescription.buildDescription;

import java.util.List;

import org.onosproject.net.DeviceId;
import org.onosproject.net.config.BaseConfig;
import com.fasterxml.jackson.databind.ObjectMapper;

// FIXME Move this to Protection handling Intent related package?
/**
 * Config object for protection end-point.
 * 

* Contains equivalent of {@link ProtectedTransportEndpointDescription}. */ public class ProtectionConfig extends BaseConfig { /** * {@value #CONFIG_KEY} : a netcfg ConfigKey for {@link ProtectionConfig}. */ public static final String CONFIG_KEY = "protection"; /** * JSON key for paths. *

* Value is list of {@link TransportEndpointDescription} in JSON. */ private static final String PATHS = "paths"; /** * JSON key for Peer {@link DeviceId}. */ private static final String PEER = "peer"; private static final String FINGERPRINT = "fingerprint"; @Override public boolean isValid() { return isString(PEER, FieldPresence.MANDATORY) && isString(FINGERPRINT, FieldPresence.MANDATORY) && hasField(PATHS); } /** * Returns List of underlying transport entity endpoints in priority order. * * @return the transport entity endpoint descriptions */ public List paths() { return getList(PATHS, jsonStr -> decode(jsonStr, TransportEndpointDescription.class)); } /** * Sets the List of underlying transport entity endpoints in priority order. * * @param paths the transport entity endpoint descriptions * @return self */ public ProtectionConfig paths(List paths) { setList(PATHS, elm -> encode(elm, TransportEndpointDescription.class).toString(), paths); return this; } /** * Returns DeviceId of remote peer of this endpoint. * * @return the peer */ public DeviceId peer() { return DeviceId.deviceId(get(PEER, "")); } /** * Sets the DeviceId of remote peer of this endpoint. * * @param peer DeviceId * @return self */ public ProtectionConfig peer(DeviceId peer) { setOrClear(PEER, peer.toString()); return this; } /** * Returns fingerprint to identify this protected transport entity. * * @return the fingerprint */ public String fingerprint() { return get(FINGERPRINT, ""); } /** * Sets the fingerprint to identify this protected transport entity. * * @param fingerprint the fingerprint * @return self */ public ProtectionConfig fingerprint(String fingerprint) { setOrClear(FINGERPRINT, checkNotNull(fingerprint)); return this; } /** * Returns equivalent of this Config as {@link ProtectedTransportEndpointDescription}. * * @return {@link ProtectedTransportEndpointDescription} */ public ProtectedTransportEndpointDescription asDescription() { return buildDescription(paths(), peer(), fingerprint()); } @Override public String toString() { return object.toString(); } /** * Create a {@link ProtectionConfig}. *

* Note: created instance needs to be initialized by #init(..) before using. */ public ProtectionConfig() { super(); } /** * Create a {@link ProtectionConfig} for specified Device. *

* Note: created instance is not bound to NetworkConfigService, * cannot use {@link #apply()}. Must be passed to the service * using NetworkConfigService#applyConfig * * @param did DeviceId */ public ProtectionConfig(DeviceId did) { ObjectMapper mapper = new ObjectMapper(); init(did, CONFIG_KEY, mapper.createObjectNode(), mapper, null); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy