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

org.onosproject.net.config.NetworkConfigEvent Maven / Gradle / Ivy

/*
 * Copyright 2015-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.config;

import org.onlab.util.Tools;
import org.onosproject.event.AbstractEvent;

import java.util.Optional;

import static com.google.common.base.MoreObjects.toStringHelper;

/**
 * Describes network configuration event.
 */
public class NetworkConfigEvent extends AbstractEvent {

    private final Class configClass;
    private final Config config;
    private final Config prevConfig;

    /**
     * Type of network configuration events.
     */
    public enum Type {
        /**
         * Signifies that a network configuration was registered.
         */
        CONFIG_REGISTERED,

        /**
         * Signifies that a network configuration was unregistered.
         */
        CONFIG_UNREGISTERED,

        /**
         * Signifies that network configuration was added.
         */
        CONFIG_ADDED,

        /**
         * Signifies that network configuration was updated.
         */
        CONFIG_UPDATED,

        /**
         * Signifies that network configuration was removed.
         */
        CONFIG_REMOVED
    }

    /**
     * Creates an event of a given type and for the specified subject and the
     * current time.
     *
     * @param type        event type
     * @param subject     event subject
     * @param configClass configuration class
     */
    public NetworkConfigEvent(Type type, Object subject, Class configClass) {
        super(type, subject);
        this.configClass = configClass;
        this.config = null;
        this.prevConfig = null;
    }

    /**
     * Creates an event of a given type and for the specified subject and time.
     *
     * @param type        device event type
     * @param subject     event subject
     * @param configClass configuration class
     * @param time        occurrence time
     */
    public NetworkConfigEvent(Type type, Object subject, Class configClass, long time) {
        super(type, subject, time);
        this.configClass = configClass;
        this.config = null;
        this.prevConfig = null;
    }

    /**
     * Creates an event of a given type and for the specified subject,
     * previous config and time.
     *
     * @param type        device event type
     * @param subject     event subject
     * @param configClass configuration class
     * @param config      current config
     * @param prevConfig  previous config
     */
    public NetworkConfigEvent(Type type, Object subject, Config config,
            Config prevConfig, Class configClass) {
        super(type, subject);
        this.configClass = configClass;
        this.config = config;
        this.prevConfig = prevConfig;
    }

    /**
     * Returns the class of configuration that has been changed.
     *
     * @return configuration class
     */
    public Class configClass() {
        return configClass;
    }

    /**
     * Returns current config.
     *
     * @return current config; value presents only when the type is
     *         CONFIG_ADDED or CONFIG_UPDATED
     */
    public Optional config() {
        return (config != null) ? Optional.of(config) : Optional.empty();
    }

    /**
     * Returns previous config.
     *
     * @return previous config; value presents only when the type is
     *         CONFIG_UPDATED or CONFIG_REMOVED
     */
    public Optional prevConfig() {
        return (prevConfig != null) ? Optional.of(prevConfig) : Optional.empty();
    }

    @Override
    public String toString() {
        return toStringHelper(this)
                .add("time", Tools.defaultOffsetDataTime(time()))
                .add("type", type())
                .add("config", config())
                .add("prevConfig", prevConfig())
                .add("configClass", configClass())
                .toString();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy