f2629522814157a3f6cdc84d07d12131cee34e81
[controller.git] / opendaylight / config / config-persister-directory-autodetect-adapter / src / main / java / org / opendaylight / controller / config / persist / storage / directory / autodetect / AutodetectDirectoryPersister.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 package org.opendaylight.controller.config.persist.storage.directory.autodetect;
9
10 import org.opendaylight.controller.config.persist.api.ConfigSnapshotHolder;
11 import org.opendaylight.controller.config.persist.api.Persister;
12 import org.opendaylight.controller.config.persist.storage.directory.DirectoryPersister;
13 import org.opendaylight.controller.config.persist.storage.directory.xml.XmlDirectoryPersister;
14 import org.slf4j.Logger;
15 import org.slf4j.LoggerFactory;
16
17 import javax.xml.bind.JAXBException;
18 import java.io.File;
19 import java.io.IOException;
20 import java.util.ArrayList;
21 import java.util.Arrays;
22 import java.util.Collections;
23 import java.util.List;
24
25 import static com.google.common.base.Preconditions.checkArgument;
26
27 public class AutodetectDirectoryPersister implements Persister {
28     private static final Logger logger = LoggerFactory.getLogger(AutodetectDirectoryPersister.class);
29
30     private final File storage;
31
32     public AutodetectDirectoryPersister(File storage) {
33         checkArgument(storage.exists() && storage.isDirectory(), "Storage directory does not exist: " + storage);
34         this.storage = storage;
35     }
36
37     @Override
38     public void persistConfig(ConfigSnapshotHolder holder) throws IOException {
39         throw new UnsupportedOperationException("This adapter is read only. Please set readonly=true on " + getClass());
40     }
41
42     @Override
43     public List<ConfigSnapshotHolder> loadLastConfigs() throws IOException {
44         File[] filesArray = storage.listFiles();
45         if (filesArray == null || filesArray.length == 0) {
46             return Collections.emptyList();
47         }
48         List<File> sortedFiles = new ArrayList<>(Arrays.asList(filesArray));
49         Collections.sort(sortedFiles);
50
51         // combine all found files
52         logger.debug("Reading files in following order: {}", sortedFiles);
53
54         List<ConfigSnapshotHolder> result = new ArrayList<>();
55         for (File file : sortedFiles) {
56             logger.trace("Adding file '{}' to combined result", file);
57
58             FileType fileType = FileType.getFileType(file);
59             logger.trace("File '{}' detected as {} storage", file, fileType);
60
61             ConfigSnapshotHolder snapshot = loadLastConfig(file, fileType);
62             result.add(snapshot);
63         }
64         return result;
65     }
66
67     private ConfigSnapshotHolder loadLastConfig(File file, FileType fileType) throws IOException {
68         switch (fileType) {
69         case plaintext:
70             return DirectoryPersister.loadLastConfig(file);
71         case xml:
72             try {
73                 return XmlDirectoryPersister.loadLastConfig(file);
74             } catch (JAXBException e) {
75                 logger.warn("Unable to restore configuration snapshot from {}", file, e);
76                 throw new IllegalStateException("Unable to restore configuration snapshot from " + file, e);
77             }
78         default:
79             throw new IllegalStateException("Unknown storage type " + fileType);
80         }
81     }
82
83     @Override
84     public void close() {
85
86     }
87
88     @Override
89     public String toString() {
90         final StringBuffer sb = new StringBuffer("AutodetectDirectoryPersister{");
91         sb.append("storage=").append(storage);
92         sb.append('}');
93         return sb.toString();
94     }
95 }