Remove unused imports
[controller.git] / opendaylight / config / config-persister-directory-xml-adapter / src / main / java / org / opendaylight / controller / config / persist / storage / directory / xml / XmlDirectoryStorageAdapter.java
1 /*
2  * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.controller.config.persist.storage.directory.xml;
10
11 import com.google.common.base.Preconditions;
12 import com.google.common.base.Splitter;
13 import com.google.common.collect.Sets;
14 import org.opendaylight.controller.config.persist.api.Persister;
15 import org.opendaylight.controller.config.persist.api.PropertiesProvider;
16 import org.opendaylight.controller.config.persist.api.StorageAdapter;
17 import org.slf4j.Logger;
18 import org.slf4j.LoggerFactory;
19
20 import java.io.File;
21 import java.util.Set;
22
23 /**
24  * StorageAdapter that retrieves initial configuration from a directory. If multiple files are present, snapshot and
25  * required capabilities will be merged together. Writing to this persister is not supported.
26  */
27 public class XmlDirectoryStorageAdapter implements StorageAdapter {
28     private static final Logger logger = LoggerFactory.getLogger(XmlDirectoryStorageAdapter.class);
29
30     public static final String DIRECTORY_STORAGE_PROP = "directoryStorage";
31     public static final String INCLUDE_EXT_PROP = "includeExtensions";
32     private static final char EXTENSIONS_SEPARATOR = ',';
33
34
35     @Override
36     public Persister instantiate(PropertiesProvider propertiesProvider) {
37         String fileStorageProperty = propertiesProvider.getProperty(DIRECTORY_STORAGE_PROP);
38         Preconditions.checkNotNull(fileStorageProperty, "Unable to find " + propertiesProvider.getFullKeyForReporting(DIRECTORY_STORAGE_PROP));
39         File storage  = new File(fileStorageProperty);
40         String fileExtensions = propertiesProvider.getProperty(INCLUDE_EXT_PROP);
41
42         logger.debug("Using storage: {}", storage);
43
44         if(fileExtensions != null) {
45             logger.debug("Using extensions: {}", fileExtensions);
46             return new XmlDirectoryPersister(storage, splitExtensions(fileExtensions));
47         } else {
48             return new XmlDirectoryPersister(storage);
49         }
50     }
51
52     private Set<String> splitExtensions(String fileExtensions) {
53         return Sets.newHashSet(Splitter.on(EXTENSIONS_SEPARATOR).trimResults().omitEmptyStrings()
54                 .split(fileExtensions));
55     }
56
57 }