blob: c7cb4afba06fe9cf85f9cb9f8f86da9ff5a80a1c [file] [log] [blame]
Thomas Vachuska6d697f12015-03-08 20:59:50 -07001/*
Brian O'Connora09fe5b2017-08-03 21:12:30 -07002 * Copyright 2015-present Open Networking Foundation
Thomas Vachuska6d697f12015-03-08 20:59:50 -07003 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16package org.onosproject.cfg;
17
Thomas Vachuskab809b382018-02-12 15:53:01 -080018import com.google.common.collect.ImmutableSet;
Thomas Vachuska6d697f12015-03-08 20:59:50 -070019import org.onosproject.store.Store;
20
Thomas Vachuskab809b382018-02-12 15:53:01 -080021import java.util.Set;
22
Thomas Vachuska6d697f12015-03-08 20:59:50 -070023/**
24 * Service for storing and distributing system-wide configurations for various
25 * software components.
26 */
27public interface ComponentConfigStore
28 extends Store<ComponentConfigEvent, ComponentConfigStoreDelegate> {
29
30 /**
31 * Sets the value of the specified configuration property.
32 *
33 * @param componentName component name
34 * @param name property name
35 * @param value new property value
36 */
37 void setProperty(String componentName, String name, String value);
38
39 /**
40 * Clears the value of the specified configuration property thus making
41 * the property take on its default value.
42 *
43 * @param componentName component name
44 * @param name property name
45 */
46 void unsetProperty(String componentName, String name);
47
Thomas Vachuskab809b382018-02-12 15:53:01 -080048
49 /**
Thomas Vachuskaecf5cf82018-02-27 11:30:09 -080050 * Returns set of component configuration property names. This includes
51 * only the names of properties whose values depart from their default.
Thomas Vachuskab809b382018-02-12 15:53:01 -080052 *
53 * @param component component name
Thomas Vachuskaecf5cf82018-02-27 11:30:09 -080054 * @return set of property names whose values are set to non-default values
Thomas Vachuskab809b382018-02-12 15:53:01 -080055 */
56 default Set<String> getProperties(String component) {
57 return ImmutableSet.of();
58 }
59
60 /**
61 * Returns the string value of the given component configuration property.
Thomas Vachuskaecf5cf82018-02-27 11:30:09 -080062 * For properties whose values are set to their default this may return null.
Thomas Vachuskab809b382018-02-12 15:53:01 -080063 *
64 * @param component component name
Thomas Vachuskaecf5cf82018-02-27 11:30:09 -080065 * @param name property name; null if no property found or if value
66 * is default
Thomas Vachuskab809b382018-02-12 15:53:01 -080067 * @return set of property names
68 */
69 default String getProperty(String component, String name) {
70 return null;
71 }
72
Thomas Vachuska6d697f12015-03-08 20:59:50 -070073}