blob: d725203e2285d23d00cebdcc1ea422e5d6d79fc2 [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 Vachuska9f6bd522018-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 Vachuska9f6bd522018-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 /**
Charles Chan8b488de2019-04-10 17:12:20 -070040 * Sets the value of the specified configuration property.
41 *
42 * @param componentName component name
43 * @param name property name
44 * @param value new property value
45 * @param override true to override even if the property has been set to other value
46 */
47 void setProperty(String componentName, String name, String value, boolean override);
48
49 /**
Thomas Vachuska6d697f12015-03-08 20:59:50 -070050 * Clears the value of the specified configuration property thus making
51 * the property take on its default value.
52 *
53 * @param componentName component name
54 * @param name property name
55 */
56 void unsetProperty(String componentName, String name);
57
Thomas Vachuska9f6bd522018-02-12 15:53:01 -080058
59 /**
Thomas Vachuska611f4662018-02-27 11:30:09 -080060 * Returns set of component configuration property names. This includes
61 * only the names of properties whose values depart from their default.
Thomas Vachuska9f6bd522018-02-12 15:53:01 -080062 *
63 * @param component component name
Thomas Vachuska611f4662018-02-27 11:30:09 -080064 * @return set of property names whose values are set to non-default values
Thomas Vachuska9f6bd522018-02-12 15:53:01 -080065 */
66 default Set<String> getProperties(String component) {
67 return ImmutableSet.of();
68 }
69
70 /**
71 * Returns the string value of the given component configuration property.
Thomas Vachuska611f4662018-02-27 11:30:09 -080072 * For properties whose values are set to their default this may return null.
Thomas Vachuska9f6bd522018-02-12 15:53:01 -080073 *
74 * @param component component name
Thomas Vachuska611f4662018-02-27 11:30:09 -080075 * @param name property name; null if no property found or if value
76 * is default
Thomas Vachuska9f6bd522018-02-12 15:53:01 -080077 * @return set of property names
78 */
79 default String getProperty(String component, String name) {
80 return null;
81 }
82
Thomas Vachuska6d697f12015-03-08 20:59:50 -070083}