blob: 00e8eab28ec9ec4056e103d216bc297242cc4f77 [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 /**
50 * Returns set of component configuration property names.
51 *
52 * @param component component name
53 * @return set of property names
54 */
55 default Set<String> getProperties(String component) {
56 return ImmutableSet.of();
57 }
58
59 /**
60 * Returns the string value of the given component configuration property.
61 *
62 * @param component component name
63 * @param name property name; null if no property found
64 * @return set of property names
65 */
66 default String getProperty(String component, String name) {
67 return null;
68 }
69
Thomas Vachuska6d697f12015-03-08 20:59:50 -070070}