Revision 5033
Added by daigle over 15 years ago
src/edu/ucsb/nceas/metacat/properties/SimpleProperties.java | ||
---|---|---|
1 |
/** |
|
2 |
* '$RCSfile$' |
|
3 |
* Purpose: A Class that implements properties methods for metacat |
|
4 |
* Copyright: 2008 Regents of the University of California and the |
|
5 |
* National Center for Ecological Analysis and Synthesis |
|
6 |
* Authors: Michael Daigle |
|
7 |
* |
|
8 |
* '$Author: daigle $' |
|
9 |
* '$Date: 2009-08-14 17:38:05 -0700 (Fri, 14 Aug 2009) $' |
|
10 |
* '$Revision: 5028 $' |
|
11 |
* |
|
12 |
* This program is free software; you can redistribute it and/or modify |
|
13 |
* it under the terms of the GNU General Public License as published by |
|
14 |
* the Free Software Foundation; either version 2 of the License, or |
|
15 |
* (at your option) any later version. |
|
16 |
* |
|
17 |
* This program is distributed in the hope that it will be useful, |
|
18 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
19 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
20 |
* GNU General Public License for more details. |
|
21 |
* |
|
22 |
* You should have received a copy of the GNU General Public License |
|
23 |
* along with this program; if not, write to the Free Software |
|
24 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
25 |
*/ |
|
26 |
|
|
27 |
package edu.ucsb.nceas.metacat.properties; |
|
28 |
|
|
29 |
import java.io.IOException; |
|
30 |
import java.util.Map; |
|
31 |
import java.util.Vector; |
|
32 |
|
|
33 |
import javax.servlet.ServletContext; |
|
34 |
import javax.servlet.http.HttpServletRequest; |
|
35 |
|
|
36 |
import org.apache.log4j.Logger; |
|
37 |
|
|
38 |
import edu.ucsb.nceas.metacat.shared.BaseService; |
|
39 |
import edu.ucsb.nceas.metacat.shared.ServiceException; |
|
40 |
import edu.ucsb.nceas.utilities.GeneralPropertyException; |
|
41 |
import edu.ucsb.nceas.utilities.PropertiesMetaData; |
|
42 |
import edu.ucsb.nceas.utilities.PropertyNotFoundException; |
|
43 |
import edu.ucsb.nceas.utilities.SortedProperties; |
|
44 |
|
|
45 |
/** |
|
46 |
* A suite of utility classes for the metadata configuration utility |
|
47 |
*/ |
|
48 |
public class SimpleProperties extends BaseService implements PropertiesInterface { |
|
49 |
|
|
50 |
private static SortedProperties sortedProperties = null; |
|
51 |
|
|
52 |
private static Logger logMetacat = Logger.getLogger(SimpleProperties.class); |
|
53 |
|
|
54 |
/** |
|
55 |
* private constructor since this is a singleton |
|
56 |
* |
|
57 |
* @param servletContext the context we will use to get relative paths |
|
58 |
*/ |
|
59 |
protected SimpleProperties() throws ServiceException { |
|
60 |
_serviceName = "SimpleProperties"; |
|
61 |
|
|
62 |
initialize(); |
|
63 |
} |
|
64 |
|
|
65 |
public boolean refreshable() { |
|
66 |
return true; |
|
67 |
} |
|
68 |
|
|
69 |
public void doRefresh() throws ServiceException { |
|
70 |
initialize(); |
|
71 |
} |
|
72 |
|
|
73 |
public void stop() throws ServiceException { |
|
74 |
return; |
|
75 |
} |
|
76 |
|
|
77 |
/** |
|
78 |
* Initialize the singleton. |
|
79 |
* |
|
80 |
* @param servletContext the context we will use to get relative paths |
|
81 |
*/ |
|
82 |
private void initialize() throws ServiceException { |
|
83 |
|
|
84 |
logMetacat.debug("Initializing SimpleProperties"); |
|
85 |
|
|
86 |
String mainConfigFilePath = |
|
87 |
PropertyService.CONFIG_FILE_PATH; |
|
88 |
sortedProperties = new SortedProperties(mainConfigFilePath); |
|
89 |
|
|
90 |
try { |
|
91 |
sortedProperties.load(); |
|
92 |
} catch (IOException ioe) { |
|
93 |
throw new ServiceException("I/O problem while loading properties: " |
|
94 |
+ ioe.getMessage()); |
|
95 |
} |
|
96 |
} |
|
97 |
|
|
98 |
/** |
|
99 |
* Utility method to get a property value from the properties file |
|
100 |
* |
|
101 |
* @param propertyName |
|
102 |
* the name of the property requested |
|
103 |
* @return the String value for the property |
|
104 |
*/ |
|
105 |
public String getProperty(String propertyName) |
|
106 |
throws PropertyNotFoundException { |
|
107 |
return sortedProperties.getProperty(propertyName); |
|
108 |
} |
|
109 |
|
|
110 |
/** |
|
111 |
* Get a set of all property names. |
|
112 |
* |
|
113 |
* @return Set of property names |
|
114 |
*/ |
|
115 |
public Vector<String> getPropertyNames() { |
|
116 |
return sortedProperties.getPropertyNames(); |
|
117 |
} |
|
118 |
|
|
119 |
|
|
120 |
/** |
|
121 |
* Get a Set of all property names that start with the groupName prefix. |
|
122 |
* |
|
123 |
* @param groupName |
|
124 |
* the prefix of the keys to search for. |
|
125 |
* @return enumeration of property names |
|
126 |
*/ |
|
127 |
public Vector<String> getPropertyNamesByGroup(String groupName) { |
|
128 |
return sortedProperties.getPropertyNamesByGroup(groupName); |
|
129 |
} |
|
130 |
|
|
131 |
/** |
|
132 |
* Get a Map of all properties that start with the groupName prefix. |
|
133 |
* |
|
134 |
* @param groupName |
|
135 |
* the prefix of the keys to search for. |
|
136 |
* @return Map of property names |
|
137 |
*/ |
|
138 |
public Map<String, String> getPropertiesByGroup(String groupName) throws PropertyNotFoundException { |
|
139 |
return sortedProperties.getPropertiesByGroup(groupName); |
|
140 |
} |
|
141 |
|
|
142 |
/** |
|
143 |
* Utility method to set a property value both in memory and to the |
|
144 |
* properties file |
|
145 |
* |
|
146 |
* @param propertyName |
|
147 |
* the name of the property requested |
|
148 |
* @param newValue |
|
149 |
* the new value for the property |
|
150 |
*/ |
|
151 |
public void setProperty(String propertyName, String newValue) throws GeneralPropertyException { |
|
152 |
sortedProperties.setProperty(propertyName, newValue); |
|
153 |
sortedProperties.store(); |
|
154 |
} |
|
155 |
|
|
156 |
/** |
|
157 |
* Utility method to set a property value in memory. This will NOT cause the |
|
158 |
* property to be written to disk. Use this method to set multiple |
|
159 |
* properties in a row without causing excessive I/O. You must call |
|
160 |
* persistProperties() once you're done setting properties to have them |
|
161 |
* written to disk. |
|
162 |
* |
|
163 |
* @param propertyName |
|
164 |
* the name of the property requested |
|
165 |
* @param newValue |
|
166 |
* the new value for the property |
|
167 |
*/ |
|
168 |
public void setPropertyNoPersist(String propertyName, String newValue) throws GeneralPropertyException { |
|
169 |
sortedProperties.setPropertyNoPersist(propertyName, newValue); |
|
170 |
} |
|
171 |
|
|
172 |
/** |
|
173 |
* Save the properties to a properties file. Note, the |
|
174 |
* order and comments will be preserved. |
|
175 |
*/ |
|
176 |
public void persistProperties() throws GeneralPropertyException { |
|
177 |
sortedProperties.store(); |
|
178 |
} |
|
179 |
|
|
180 |
/** |
|
181 |
* Take input from the user in an HTTP request about an property to be changed |
|
182 |
* and update the metacat property file with that new value if it has |
|
183 |
* changed from the value that was originally set. |
|
184 |
* |
|
185 |
* @param request |
|
186 |
* that was generated by the user |
|
187 |
* @param response |
|
188 |
* to send output back to the user |
|
189 |
* @param propertyName |
|
190 |
* the name of the property to be checked and set |
|
191 |
*/ |
|
192 |
public void checkAndSetProperty(HttpServletRequest request, String propertyName) |
|
193 |
throws GeneralPropertyException { |
|
194 |
String value = getProperty(propertyName); |
|
195 |
String newValue = request.getParameter(propertyName); |
|
196 |
if (newValue != null && !newValue.trim().equals(value)) { |
|
197 |
setPropertyNoPersist(propertyName, newValue.trim()); |
|
198 |
} |
|
199 |
} |
|
200 |
|
|
201 |
public SortedProperties getMainBackupProperties() { |
|
202 |
return sortedProperties; |
|
203 |
} |
|
204 |
|
|
205 |
public SortedProperties getAuthBackupProperties() throws GeneralPropertyException { |
|
206 |
throw new GeneralPropertyException("SimpleProperties.getAuthBackupProperties - " + |
|
207 |
"SimpleProperties does not support backup properties"); |
|
208 |
} |
|
209 |
|
|
210 |
public PropertiesMetaData getMainMetaData() throws GeneralPropertyException { |
|
211 |
throw new GeneralPropertyException("SimpleProperties.getMainMetaData - " + |
|
212 |
"SimpleProperties does not support metadata"); |
|
213 |
} |
|
214 |
|
|
215 |
public PropertiesMetaData getAuthMetaData() throws GeneralPropertyException { |
|
216 |
throw new GeneralPropertyException("SimpleProperties.getAuthMetaData - " + |
|
217 |
"SimpleProperties does not support auth metadata"); |
|
218 |
} |
|
219 |
|
|
220 |
public void persistMainBackupProperties() throws GeneralPropertyException { |
|
221 |
throw new GeneralPropertyException("SimpleProperties.persistMainBackupProperties - " + |
|
222 |
"SimpleProperties does not support backup properties"); |
|
223 |
} |
|
224 |
|
|
225 |
public void persistAuthBackupProperties(ServletContext servletContext) throws GeneralPropertyException { |
|
226 |
throw new GeneralPropertyException("SimpleProperties.persistAuthBackupProperties - " + |
|
227 |
"SimpleProperties does not support backup properties"); |
|
228 |
} |
|
229 |
|
|
230 |
public boolean arePropertiesConfigured() throws GeneralPropertyException { |
|
231 |
return true; |
|
232 |
} |
|
233 |
|
|
234 |
public boolean doBypass() throws GeneralPropertyException { |
|
235 |
throw new GeneralPropertyException("SimpleProperties.doBypass - " + |
|
236 |
"SimpleProperties does not support doBypass method."); |
|
237 |
} |
|
238 |
|
|
239 |
public void bypassConfiguration() throws GeneralPropertyException { |
|
240 |
throw new GeneralPropertyException("SimpleProperties.doBypass - " + |
|
241 |
"SimpleProperties does not support bypassConfiguration method."); |
|
242 |
} |
|
243 |
|
|
244 |
} |
|
0 | 245 |
src/edu/ucsb/nceas/metacat/properties/SkinPropertyService.java | ||
---|---|---|
1 |
/** |
|
2 |
* '$RCSfile$' |
|
3 |
* Purpose: A Class that implements properties methods for metacat |
|
4 |
* skins |
|
5 |
* Copyright: 2008 Regents of the University of California and the |
|
6 |
* National Center for Ecological Analysis and Synthesis |
|
7 |
* Authors: Michael Daigle |
|
8 |
* |
|
9 |
* '$Author$' |
|
10 |
* '$Date$' |
|
11 |
* '$Revision$' |
|
12 |
* |
|
13 |
* This program is free software; you can redistribute it and/or modify |
|
14 |
* it under the terms of the GNU General Public License as published by |
|
15 |
* the Free Software Foundation; either version 2 of the License, or |
|
16 |
* (at your option) any later version. |
|
17 |
* |
|
18 |
* This program is distributed in the hope that it will be useful, |
|
19 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
20 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
21 |
* GNU General Public License for more details. |
|
22 |
* |
|
23 |
* You should have received a copy of the GNU General Public License |
|
24 |
* along with this program; if not, write to the Free Software |
|
25 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
26 |
*/ |
|
27 |
|
|
28 |
package edu.ucsb.nceas.metacat.properties; |
|
29 |
|
|
30 |
import java.io.IOException; |
|
31 |
import java.util.HashMap; |
|
32 |
import java.util.Map; |
|
33 |
import java.util.Set; |
|
34 |
import java.util.Vector; |
|
35 |
|
|
36 |
|
|
37 |
import javax.servlet.http.HttpServletRequest; |
|
38 |
import javax.xml.transform.TransformerException; |
|
39 |
|
|
40 |
import org.apache.log4j.Logger; |
|
41 |
|
|
42 |
import edu.ucsb.nceas.metacat.service.ServiceService; |
|
43 |
import edu.ucsb.nceas.metacat.shared.BaseService; |
|
44 |
import edu.ucsb.nceas.metacat.shared.MetacatUtilException; |
|
45 |
import edu.ucsb.nceas.metacat.shared.ServiceException; |
|
46 |
import edu.ucsb.nceas.metacat.util.SkinUtil; |
|
47 |
import edu.ucsb.nceas.utilities.FileUtil; |
|
48 |
import edu.ucsb.nceas.utilities.GeneralPropertyException; |
|
49 |
import edu.ucsb.nceas.utilities.MetaDataProperty; |
|
50 |
import edu.ucsb.nceas.utilities.PropertiesMetaData; |
|
51 |
import edu.ucsb.nceas.utilities.PropertyNotFoundException; |
|
52 |
import edu.ucsb.nceas.utilities.SortedProperties; |
|
53 |
|
|
54 |
/** |
|
55 |
* A suite of utility classes for the skin configuration utility |
|
56 |
*/ |
|
57 |
public class SkinPropertyService extends BaseService { |
|
58 |
|
|
59 |
private static SkinPropertyService skinService = null; |
|
60 |
|
|
61 |
private static boolean bypassAlreadyChecked = false; |
|
62 |
|
|
63 |
private static String BACKUP_DIR = null; |
|
64 |
|
|
65 |
private static Vector<String> skinNames = null; |
|
66 |
|
|
67 |
private static HashMap<String, SortedProperties> skinPropertiesMap = null; |
|
68 |
private static HashMap<String, SortedProperties> skinBackupPropertiesMap = null; |
|
69 |
private static HashMap<String, PropertiesMetaData> skinMetaDataMap = null; |
|
70 |
|
|
71 |
private static Logger logMetacat = Logger.getLogger(SkinPropertyService.class); |
|
72 |
|
|
73 |
/** |
|
74 |
* private constructor since this is a singleton |
|
75 |
* |
|
76 |
* @param servletContext |
|
77 |
* the context we will use to get relative paths |
|
78 |
*/ |
|
79 |
private SkinPropertyService() throws ServiceException { |
|
80 |
try { |
|
81 |
_serviceName = "SkinPropertyService"; |
|
82 |
|
|
83 |
initialize(); |
|
84 |
} catch (GeneralPropertyException gpe) { |
|
85 |
throw new ServiceException( |
|
86 |
"Properties problem while initializing SkinPropertyService: " |
|
87 |
+ gpe.getMessage()); |
|
88 |
} catch (IOException ioe) { |
|
89 |
throw new ServiceException("I/O Problem while initializing SkinPropertyService: " |
|
90 |
+ ioe.getMessage()); |
|
91 |
} |
|
92 |
} |
|
93 |
|
|
94 |
/** |
|
95 |
* Get the single instance of SkinPropertyService. |
|
96 |
* |
|
97 |
* @param servletContext |
|
98 |
* the context we will use to get relative paths |
|
99 |
* @return the single instance of SkinPropertyService |
|
100 |
*/ |
|
101 |
public static SkinPropertyService getInstance() throws ServiceException { |
|
102 |
if (skinService == null) { |
|
103 |
skinService = new SkinPropertyService(); |
|
104 |
} |
|
105 |
return skinService; |
|
106 |
} |
|
107 |
|
|
108 |
public boolean refreshable() { |
|
109 |
return true; |
|
110 |
} |
|
111 |
|
|
112 |
public void doRefresh() throws ServiceException { |
|
113 |
try { |
|
114 |
initialize(); |
|
115 |
} catch (IOException ioe) { |
|
116 |
throw new ServiceException("Could not refresh SkinPropertyService due to" |
|
117 |
+ " I/O error: " + ioe.getMessage()); |
|
118 |
} catch (GeneralPropertyException gpe) { |
|
119 |
throw new ServiceException("Could not refresh SkinPropertyService due to" |
|
120 |
+ " property error: " + gpe.getMessage()); |
|
121 |
} |
|
122 |
} |
|
123 |
|
|
124 |
public void stop() throws ServiceException { |
|
125 |
return; |
|
126 |
} |
|
127 |
|
|
128 |
/** |
|
129 |
* Initialize the singleton. |
|
130 |
* |
|
131 |
* @param servletContext |
|
132 |
* the context we will use to get relative paths |
|
133 |
*/ |
|
134 |
private void initialize() throws IOException, GeneralPropertyException, |
|
135 |
ServiceException { |
|
136 |
|
|
137 |
logMetacat.debug("Initializing SkinService"); |
|
138 |
|
|
139 |
BACKUP_DIR = PropertyService.getProperty("application.backupDir"); |
|
140 |
|
|
141 |
skinNames = SkinUtil.getSkinNames(); |
|
142 |
|
|
143 |
skinPropertiesMap = new HashMap<String, SortedProperties>(); |
|
144 |
skinBackupPropertiesMap = new HashMap<String, SortedProperties>(); |
|
145 |
skinMetaDataMap = new HashMap<String, PropertiesMetaData>(); |
|
146 |
|
|
147 |
try { |
|
148 |
for (String skinName : skinNames) { |
|
149 |
String propertyFilePath = ServiceService.getRealSkinDir() |
|
150 |
+ FileUtil.getFS() + skinName + FileUtil.getFS() + skinName |
|
151 |
+ ".properties"; |
|
152 |
|
|
153 |
if (FileUtil.getFileStatus(propertyFilePath) < FileUtil.EXISTS_READ_WRITABLE) { |
|
154 |
logMetacat.error("Skin property file: " + propertyFilePath |
|
155 |
+ " does not exist read/writable. This skin will not be available."); |
|
156 |
continue; |
|
157 |
} |
|
158 |
|
|
159 |
SortedProperties skinProperties = new SortedProperties(propertyFilePath); |
|
160 |
skinProperties.load(); |
|
161 |
skinPropertiesMap.put(skinName, skinProperties); |
|
162 |
|
|
163 |
String metaDataFilePath = ServiceService.getRealSkinDir() |
|
164 |
+ FileUtil.getFS() + skinName + FileUtil.getFS() + skinName |
|
165 |
+ ".properties.metadata.xml"; |
|
166 |
if (FileUtil.getFileStatus(metaDataFilePath) > FileUtil.DOES_NOT_EXIST) { |
|
167 |
PropertiesMetaData skinMetaData = new PropertiesMetaData(metaDataFilePath); |
|
168 |
skinMetaDataMap.put(skinName, skinMetaData); |
|
169 |
} else { |
|
170 |
skinPropertiesMap.remove(skinName); |
|
171 |
logMetacat.error("Could not find skin property metadata file for skin: " |
|
172 |
+ skinName + " at: " + metaDataFilePath |
|
173 |
+ ". This skin will not be available."); |
|
174 |
continue; |
|
175 |
} |
|
176 |
|
|
177 |
String backupPropertyFilePath = BACKUP_DIR + FileUtil.getFS() + skinName |
|
178 |
+ ".properties.backup"; |
|
179 |
if (FileUtil.getFileStatus(backupPropertyFilePath) > FileUtil.DOES_NOT_EXIST) { |
|
180 |
SortedProperties skinBackupProperties = new SortedProperties( |
|
181 |
backupPropertyFilePath); |
|
182 |
skinBackupProperties.load(); |
|
183 |
skinBackupPropertiesMap.put(skinName, skinBackupProperties); |
|
184 |
} else { |
|
185 |
logMetacat.warn("Could not find backup properties for skin: " |
|
186 |
+ skinName + " at: " + backupPropertyFilePath); |
|
187 |
} |
|
188 |
} |
|
189 |
} catch (TransformerException te) { |
|
190 |
throw new GeneralPropertyException(te.getMessage()); |
|
191 |
} |
|
192 |
} |
|
193 |
|
|
194 |
/** |
|
195 |
* Utility method to get a property value from the properties file for a |
|
196 |
* specific skin. |
|
197 |
* |
|
198 |
* @param skinName |
|
199 |
* the skin for which we want to retrieve the property |
|
200 |
* @param propertyName |
|
201 |
* the name of the property requested |
|
202 |
* @return the String value for the property |
|
203 |
*/ |
|
204 |
public static String getProperty(String skinName, String propertyName) |
|
205 |
throws PropertyNotFoundException { |
|
206 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
207 |
if (skinProperties == null) { |
|
208 |
throw new PropertyNotFoundException("There is not property map for " |
|
209 |
+ skinName); |
|
210 |
} |
|
211 |
return skinProperties.getProperty(propertyName); |
|
212 |
} |
|
213 |
|
|
214 |
/** |
|
215 |
* Get a set of all property names for a given skin. |
|
216 |
* |
|
217 |
* @param skinName |
|
218 |
* the skin for which we want to retrieve the property names |
|
219 |
* @return Set of property names |
|
220 |
*/ |
|
221 |
public static Vector<String> getPropertyNames(String skinName) |
|
222 |
throws PropertyNotFoundException { |
|
223 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
224 |
if (skinProperties == null) { |
|
225 |
throw new PropertyNotFoundException("There is not property map for " |
|
226 |
+ skinName); |
|
227 |
} |
|
228 |
return skinProperties.getPropertyNames(); |
|
229 |
} |
|
230 |
|
|
231 |
/** |
|
232 |
* Get a Set of all property names that start with the groupName prefix. |
|
233 |
* |
|
234 |
* @param groupName |
|
235 |
* the prefix of the keys to search for. |
|
236 |
* @return Vector of property names |
|
237 |
*/ |
|
238 |
public static Vector<String> getPropertyNamesByGroup(String skinName, String groupName) |
|
239 |
throws PropertyNotFoundException { |
|
240 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
241 |
if (skinProperties == null) { |
|
242 |
throw new PropertyNotFoundException("There is not property map for " |
|
243 |
+ skinName); |
|
244 |
} |
|
245 |
return skinProperties.getPropertyNamesByGroup(groupName); |
|
246 |
} |
|
247 |
|
|
248 |
/** |
|
249 |
* Get the main backup properties file. These are configurable properties |
|
250 |
* that are stored outside the metacat install directories so the user does |
|
251 |
* not need to re-enter all the configuration information every time they do |
|
252 |
* an upgrade. |
|
253 |
* |
|
254 |
* @return a SortedProperties object with the backup properties |
|
255 |
*/ |
|
256 |
public static HashMap<String, SortedProperties> getProperties() { |
|
257 |
return skinPropertiesMap; |
|
258 |
} |
|
259 |
|
|
260 |
/** |
|
261 |
* Get the main backup properties file. These are configurable properties |
|
262 |
* that are stored outside the metacat install directories so the user does |
|
263 |
* not need to re-enter all the configuration information every time they do |
|
264 |
* an upgrade. |
|
265 |
* |
|
266 |
* @return a SortedProperties object with the backup properties |
|
267 |
*/ |
|
268 |
public static SortedProperties getProperties(String skinName) { |
|
269 |
return skinPropertiesMap.get(skinName); |
|
270 |
} |
|
271 |
|
|
272 |
/** |
|
273 |
* Get the main backup properties file. These are configurable properties |
|
274 |
* that are stored outside the metacat install directories so the user does |
|
275 |
* not need to re-enter all the configuration information every time they do |
|
276 |
* an upgrade. |
|
277 |
* |
|
278 |
* @return a SortedProperties object with the backup properties |
|
279 |
*/ |
|
280 |
public static HashMap<String, SortedProperties> getBackupProperties() { |
|
281 |
return skinBackupPropertiesMap; |
|
282 |
} |
|
283 |
|
|
284 |
/** |
|
285 |
* Get the main backup properties file. These are configurable properties |
|
286 |
* that are stored outside the metacat install directories so the user does |
|
287 |
* not need to re-enter all the configuration information every time they do |
|
288 |
* an upgrade. |
|
289 |
* |
|
290 |
* @return a SortedProperties object with the backup properties |
|
291 |
*/ |
|
292 |
public static SortedProperties getBackupProperties(String skinName) { |
|
293 |
return skinBackupPropertiesMap.get(skinName); |
|
294 |
} |
|
295 |
|
|
296 |
/** |
|
297 |
* Get the main properties metadata. This is retrieved from an xml file that |
|
298 |
* describes the attributes of configurable properties. |
|
299 |
* |
|
300 |
* @return a PropertiesMetaData object with the main properties metadata |
|
301 |
*/ |
|
302 |
public static HashMap<String, PropertiesMetaData> getMetaData() { |
|
303 |
return skinMetaDataMap; |
|
304 |
} |
|
305 |
|
|
306 |
/** |
|
307 |
* Get the main properties metadata. This is retrieved from an xml file that |
|
308 |
* describes the attributes of configurable properties. |
|
309 |
* |
|
310 |
* @return a PropertiesMetaData object with the main properties metadata |
|
311 |
*/ |
|
312 |
public static PropertiesMetaData getMetaData(String skinName) { |
|
313 |
return skinMetaDataMap.get(skinName); |
|
314 |
} |
|
315 |
|
|
316 |
/** |
|
317 |
* Utility method to set a property value both in memory and to the |
|
318 |
* properties file |
|
319 |
* |
|
320 |
* @param propertyName |
|
321 |
* the name of the property requested |
|
322 |
* @param newValue |
|
323 |
* the new value for the property |
|
324 |
*/ |
|
325 |
public static void setProperty(String skinName, String propertyName, String newValue) |
|
326 |
throws IOException, GeneralPropertyException { |
|
327 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
328 |
if (skinProperties == null) { |
|
329 |
throw new GeneralPropertyException("There is not property map for " |
|
330 |
+ skinName); |
|
331 |
} |
|
332 |
skinProperties.setProperty(propertyName, newValue); |
|
333 |
skinProperties.store(); |
|
334 |
|
|
335 |
} |
|
336 |
|
|
337 |
/** |
|
338 |
* Utility method to set a property value in memory. This will NOT cause the |
|
339 |
* property to be written to disk. Use this method to set multiple |
|
340 |
* properties in a row without causing excessive I/O. You must call |
|
341 |
* persistProperties() once you're done setting properties to have them |
|
342 |
* written to disk. |
|
343 |
* |
|
344 |
* @param propertyName |
|
345 |
* the name of the property requested |
|
346 |
* @param newValue |
|
347 |
* the new value for the property |
|
348 |
*/ |
|
349 |
public static void setPropertyNoPersist(String skinName, String propertyName, |
|
350 |
String newValue) throws GeneralPropertyException { |
|
351 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
352 |
if (skinProperties == null) { |
|
353 |
throw new GeneralPropertyException("There is not property map for " |
|
354 |
+ skinName); |
|
355 |
} |
|
356 |
skinProperties.setPropertyNoPersist(propertyName, newValue); |
|
357 |
} |
|
358 |
|
|
359 |
/** |
|
360 |
* Save the properties to a properties file. Note, the order and comments |
|
361 |
* will be preserved. |
|
362 |
*/ |
|
363 |
public static void persistProperties(String skinName) throws IOException, |
|
364 |
GeneralPropertyException { |
|
365 |
SortedProperties skinProperties = skinPropertiesMap.get(skinName); |
|
366 |
if (skinProperties == null) { |
|
367 |
throw new GeneralPropertyException("There is not property map for " |
|
368 |
+ skinName); |
|
369 |
} |
|
370 |
skinProperties.store(); |
|
371 |
} |
|
372 |
|
|
373 |
/** |
|
374 |
* Save the properties to a properties file. Note, the order and comments |
|
375 |
* will be preserved. |
|
376 |
*/ |
|
377 |
public static void persistAllProperties() throws IOException, |
|
378 |
GeneralPropertyException { |
|
379 |
for (String skinName : skinNames) { |
|
380 |
persistProperties(skinName); |
|
381 |
} |
|
382 |
} |
|
383 |
|
|
384 |
/** |
|
385 |
* Writes out backup configurable properties to a file. |
|
386 |
*/ |
|
387 |
public static void persistBackupProperties(String skinName) |
|
388 |
throws GeneralPropertyException { |
|
389 |
try { |
|
390 |
String metaDataFilePath = ServiceService.getRealSkinDir() + FileUtil.getFS() |
|
391 |
+ skinName + FileUtil.getFS() + skinName + ".properties.metadata.xml"; |
|
392 |
|
|
393 |
String backupPropertyFilePath = BACKUP_DIR + FileUtil.getFS() + skinName |
|
394 |
+ ".properties.backup"; |
|
395 |
|
|
396 |
// Use the metadata to extract configurable properties from the |
|
397 |
// overall properties list, and store those properties. |
|
398 |
SortedProperties backupProperties = new SortedProperties( |
|
399 |
backupPropertyFilePath); |
|
400 |
|
|
401 |
// Populate the backup properties for main metacat properties using |
|
402 |
// the associated metadata file |
|
403 |
PropertiesMetaData skinMetadata = new PropertiesMetaData(metaDataFilePath); |
|
404 |
|
|
405 |
Map<String, MetaDataProperty> skinKeyMap = skinMetadata.getProperties(); |
|
406 |
Set<String> skinKeySet = skinKeyMap.keySet(); |
|
407 |
for (String propertyKey : skinKeySet) { |
|
408 |
// don't backup passwords |
|
409 |
MetaDataProperty metaData = skinKeyMap.get(propertyKey); |
|
410 |
if (!metaData.getFieldType().equals(MetaDataProperty.PASSWORD_TYPE)) { |
|
411 |
backupProperties.addProperty(propertyKey, getProperty(skinName, propertyKey)); |
|
412 |
} |
|
413 |
} |
|
414 |
|
|
415 |
// store the properties to file |
|
416 |
backupProperties.store(); |
|
417 |
|
|
418 |
} catch (TransformerException te) { |
|
419 |
throw new GeneralPropertyException( |
|
420 |
"Could not transform backup properties xml: " + te.getMessage()); |
|
421 |
} catch (IOException ioe) { |
|
422 |
throw new GeneralPropertyException( |
|
423 |
"Could not backup configurable properties: " + ioe.getMessage()); |
|
424 |
} catch (ServiceException se) { |
|
425 |
throw new GeneralPropertyException("Could not get skins property file: " |
|
426 |
+ se.getMessage()); |
|
427 |
} |
|
428 |
} |
|
429 |
|
|
430 |
/** |
|
431 |
* Reports whether properties are fully configured. |
|
432 |
* |
|
433 |
* @return a boolean that is true if properties are not unconfigured and |
|
434 |
* false otherwise |
|
435 |
*/ |
|
436 |
public static boolean areSkinsConfigured() throws MetacatUtilException { |
|
437 |
try { |
|
438 |
return !PropertyService.getProperty("configutil.skinsConfigured").equals( |
|
439 |
PropertyService.UNCONFIGURED); |
|
440 |
} catch (PropertyNotFoundException pnfe) { |
|
441 |
throw new MetacatUtilException("Could not determine if skins are configured: " |
|
442 |
+ pnfe.getMessage()); |
|
443 |
} |
|
444 |
} |
|
445 |
|
|
446 |
/** |
|
447 |
* Take input from the user in an HTTP request about an property to be |
|
448 |
* changed and update the metacat property file with that new value if it |
|
449 |
* has changed from the value that was originally set. |
|
450 |
* |
|
451 |
* @param request |
|
452 |
* that was generated by the user |
|
453 |
* @param response |
|
454 |
* to send output back to the user |
|
455 |
* @param propertyName |
|
456 |
* the name of the property to be checked and set |
|
457 |
*/ |
|
458 |
public static void checkAndSetProperty(HttpServletRequest request, String skinName, |
|
459 |
String propertyName) throws GeneralPropertyException { |
|
460 |
String newValue = request.getParameter(skinName + "." + propertyName); |
|
461 |
checkAndSetProperty(newValue, skinName, propertyName); |
|
462 |
} |
|
463 |
|
|
464 |
/** |
|
465 |
* Check user input against existing value and update the metacat property |
|
466 |
* file with that new value if it has changed from the value that was |
|
467 |
* originally set. |
|
468 |
* |
|
469 |
* @param newValue |
|
470 |
* the value that was returned by the form |
|
471 |
* @param skinname |
|
472 |
* the skin that we are checking |
|
473 |
* @param propertyName |
|
474 |
* the name of the property to be checked and set |
|
475 |
*/ |
|
476 |
public static void checkAndSetProperty(String newValue, String skinName, |
|
477 |
String propertyName) throws GeneralPropertyException { |
|
478 |
String oldValue = SkinPropertyService.getProperty(skinName, propertyName); |
|
479 |
if (newValue != null && !newValue.equals(oldValue)) { |
|
480 |
SkinPropertyService.setPropertyNoPersist(skinName, propertyName, newValue); |
|
481 |
} |
|
482 |
} |
|
483 |
|
|
484 |
/** |
|
485 |
* Reports whether the metacat configuration utility should be run. Returns |
|
486 |
* false if -- dev.runConfiguration=false and -- backup properties file |
|
487 |
* exists Note that dev.runConfiguration should only be set to false when |
|
488 |
* reinstalling the same version of the application in developement. |
|
489 |
* |
|
490 |
* @return a boolean that is false if dev.runConfiguration is false and the |
|
491 |
* backup properties file exists. |
|
492 |
*/ |
|
493 |
public static boolean bypassConfiguration() { |
|
494 |
boolean bypass = false; |
|
495 |
|
|
496 |
// We only want to go through the check once to see if we want to |
|
497 |
// bypass the configuration. We don't want to run through all of |
|
498 |
// this every time we hit metacat. |
|
499 |
if (bypassAlreadyChecked) { |
|
500 |
return bypass; |
|
501 |
} |
|
502 |
|
|
503 |
try { |
|
504 |
// check how dev.runConfiguration is set in metacat.properties |
|
505 |
String strRunConfiguration = PropertyService |
|
506 |
.getProperty("dev.runConfiguration"); |
|
507 |
bypass = !(Boolean.parseBoolean(strRunConfiguration)); |
|
508 |
|
|
509 |
// if the deb.runConfiguration is true, return false here. |
|
510 |
if (!bypass) { |
|
511 |
bypassAlreadyChecked = true; |
|
512 |
return false; |
|
513 |
} |
|
514 |
|
|
515 |
// the system is bypassing the configuration utility. We need to |
|
516 |
// get the backup properties and replace existing properties with |
|
517 |
// backup values. We do this for main and org properties. |
|
518 |
for (String skinName : skinNames) { |
|
519 |
SortedProperties backupProperties = getBackupProperties(skinName); |
|
520 |
Vector<String> backupPropertyNames = backupProperties.getPropertyNames(); |
|
521 |
for (String backupPropertyName : backupPropertyNames) { |
|
522 |
String value = backupProperties.getProperty(backupPropertyName); |
|
523 |
backupProperties.setPropertyNoPersist(backupPropertyName, value); |
|
524 |
} |
|
525 |
backupProperties.store(); |
|
526 |
} |
|
527 |
} catch (PropertyNotFoundException pnfe) { |
|
528 |
logMetacat.error("Could not find property: " + pnfe.getMessage()); |
|
529 |
} catch (GeneralPropertyException gpe) { |
|
530 |
logMetacat.error("General property error: " + gpe.getMessage()); |
|
531 |
} |
|
532 |
|
|
533 |
bypassAlreadyChecked = true; |
|
534 |
return bypass; |
|
535 |
} |
|
536 |
|
|
537 |
} |
|
0 | 538 |
src/edu/ucsb/nceas/metacat/properties/ConfigurableProperties.java | ||
---|---|---|
1 |
/** |
|
2 |
* '$RCSfile$' |
|
3 |
* Purpose: A Class that implements properties methods for metacat |
|
4 |
* Copyright: 2008 Regents of the University of California and the |
|
5 |
* National Center for Ecological Analysis and Synthesis |
|
6 |
* Authors: Michael Daigle |
|
7 |
* |
|
8 |
* '$Author: daigle $' |
|
9 |
* '$Date: 2009-08-14 17:38:05 -0700 (Fri, 14 Aug 2009) $' |
|
10 |
* '$Revision: 5028 $' |
|
11 |
* |
|
12 |
* This program is free software; you can redistribute it and/or modify |
|
13 |
* it under the terms of the GNU General Public License as published by |
|
14 |
* the Free Software Foundation; either version 2 of the License, or |
|
15 |
* (at your option) any later version. |
|
16 |
* |
|
17 |
* This program is distributed in the hope that it will be useful, |
|
18 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
19 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
20 |
* GNU General Public License for more details. |
|
21 |
* |
|
22 |
* You should have received a copy of the GNU General Public License |
|
23 |
* along with this program; if not, write to the Free Software |
|
24 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
25 |
*/ |
|
26 |
|
|
27 |
package edu.ucsb.nceas.metacat.properties; |
|
28 |
|
|
29 |
import java.io.IOException; |
|
30 |
import java.util.Map; |
|
31 |
import java.util.Set; |
|
32 |
import java.util.Vector; |
|
33 |
|
|
34 |
import javax.servlet.ServletContext; |
|
35 |
import javax.servlet.http.HttpServletRequest; |
|
36 |
import javax.xml.transform.TransformerException; |
|
37 |
|
|
38 |
import org.apache.log4j.Logger; |
|
39 |
|
|
40 |
import edu.ucsb.nceas.metacat.service.ServiceService; |
|
41 |
import edu.ucsb.nceas.metacat.shared.BaseService; |
|
42 |
import edu.ucsb.nceas.metacat.shared.MetacatUtilException; |
|
43 |
import edu.ucsb.nceas.metacat.shared.ServiceException; |
|
44 |
import edu.ucsb.nceas.metacat.util.SystemUtil; |
|
45 |
import edu.ucsb.nceas.utilities.FileUtil; |
|
46 |
import edu.ucsb.nceas.utilities.GeneralPropertyException; |
|
47 |
import edu.ucsb.nceas.utilities.MetaDataProperty; |
|
48 |
import edu.ucsb.nceas.utilities.PropertiesMetaData; |
|
49 |
import edu.ucsb.nceas.utilities.PropertyNotFoundException; |
|
50 |
import edu.ucsb.nceas.utilities.SortedProperties; |
|
51 |
|
|
52 |
/** |
|
53 |
* A suite of utility classes for the metadata configuration utility |
|
54 |
*/ |
|
55 |
public class ConfigurableProperties extends BaseService implements PropertiesInterface { |
|
56 |
|
|
57 |
private static final String MAIN_CONFIG_FILE_NAME = "metacat.properties"; |
|
58 |
private static String mainConfigFilePath = null; |
|
59 |
private static SortedProperties mainProperties = null; |
|
60 |
|
|
61 |
private static final String MAIN_METADATA_FILE_NAME = "metacat.properties.metadata.xml"; |
|
62 |
private static String mainMetadataFilePath = null; |
|
63 |
private static PropertiesMetaData mainMetaData = null; |
|
64 |
|
|
65 |
private static final String MAIN_BACKUP_FILE_NAME = "metacat.properties.backup"; |
|
66 |
private static String mainBackupFilePath = null; |
|
67 |
private static SortedProperties mainBackupProperties = null; |
|
68 |
|
|
69 |
private static final String AUTH_METADATA_FILE_NAME = "auth.properties.metadata.xml"; |
|
70 |
private static String authMetadataFilePath = null; |
|
71 |
private static PropertiesMetaData authMetaData = null; |
|
72 |
|
|
73 |
private static final String AUTH_BACKUP_FILE_NAME = "auth.properties.backup"; |
|
74 |
private static String authBackupFilePath = null; |
|
75 |
private static SortedProperties authBackupProperties = null; |
|
76 |
|
|
77 |
private static boolean bypassAlreadyChecked = false; |
|
78 |
|
|
79 |
private static Logger logMetacat = Logger.getLogger(ConfigurableProperties.class); |
|
80 |
|
|
81 |
/** |
|
82 |
* private constructor since this is a singleton |
|
83 |
* |
|
84 |
* @param servletContext the context we will use to get relative paths |
|
85 |
*/ |
|
86 |
protected ConfigurableProperties() throws ServiceException { |
|
87 |
_serviceName = "ConfigurableProperties"; |
|
88 |
|
|
89 |
initialize(); |
|
90 |
} |
|
91 |
|
|
92 |
public boolean refreshable() { |
|
93 |
return true; |
|
94 |
} |
|
95 |
|
|
96 |
public void doRefresh() throws ServiceException { |
|
97 |
initialize(); |
|
98 |
} |
|
99 |
|
|
100 |
public void stop() throws ServiceException { |
|
101 |
return; |
|
102 |
} |
|
103 |
|
|
104 |
/** |
|
105 |
* Initialize the singleton. |
|
106 |
* |
|
107 |
* @param servletContext the context we will use to get relative paths |
|
108 |
*/ |
|
109 |
private void initialize() throws ServiceException { |
|
110 |
|
|
111 |
logMetacat.debug("Initializing ConfigurableProperties"); |
|
112 |
|
|
113 |
try { |
|
114 |
mainConfigFilePath = |
|
115 |
PropertyService.CONFIG_FILE_DIR + FileUtil.getFS() + MAIN_CONFIG_FILE_NAME; |
|
116 |
mainMetadataFilePath = |
|
117 |
PropertyService.CONFIG_FILE_DIR + FileUtil.getFS() + MAIN_METADATA_FILE_NAME; |
|
118 |
// mainBackupFilePath = |
|
119 |
// PropertyService.CONFIG_FILE_DIR + FileUtil.getFS() + MAIN_BACKUP_FILE_NAME; |
|
120 |
authMetadataFilePath = |
|
121 |
PropertyService.CONFIG_FILE_DIR + FileUtil.getFS() + AUTH_METADATA_FILE_NAME; |
|
122 |
// authBackupFilePath = |
|
123 |
// PropertyService.CONFIG_FILE_DIR + FileUtil.getFS() + AUTH_BACKUP_FILE_NAME; |
|
124 |
|
|
125 |
|
|
126 |
// mainProperties will hold the primary configuration values for |
|
127 |
// metacat. |
|
128 |
mainProperties = new SortedProperties(mainConfigFilePath); |
|
129 |
mainProperties.load(); |
|
130 |
|
|
131 |
// mainMetaData holds configuration information about main |
|
132 |
// properties. This is primarily used to display input fields on |
|
133 |
// the configuration page. The information is retrieved from an |
|
134 |
// xml metadata file |
|
135 |
mainMetaData = new PropertiesMetaData(mainMetadataFilePath); |
|
136 |
|
|
137 |
// authMetaData holds configuration information about organization |
|
138 |
// level |
|
139 |
// properties. This is primarily used to display input fields on |
|
140 |
// the auth configuration page. The information is retrieved |
|
141 |
// from an xml metadata file dedicated just to auth properties. |
|
142 |
authMetaData = new PropertiesMetaData(authMetadataFilePath); |
|
143 |
|
|
144 |
String recommendedExternalDir = SystemUtil.discoverExternalDir(); |
|
145 |
PropertyService.setRecommendedExternalDir(recommendedExternalDir); |
|
146 |
|
|
147 |
String backupPath = getProperty("application.backupDir"); |
|
148 |
if (backupPath == null || backupPath.equals("")) { |
|
149 |
backupPath = SystemUtil.getStoredBackupDir(); |
|
150 |
} |
|
151 |
if (backupPath == null || backupPath.equals("") && recommendedExternalDir != null) { |
|
152 |
backupPath = |
|
153 |
recommendedExternalDir + FileUtil.getFS() + "." + ServiceService.getRealApplicationContext(); |
|
154 |
} |
|
155 |
|
|
156 |
// if backupPath is still null, no reason to initialize the |
|
157 |
// backup properties. The system will need to prompt the user for |
|
158 |
// the backup properties and reinitialize ConfigurableProperties. |
|
159 |
if (backupPath != null && !backupPath.equals("")) { |
|
160 |
setProperty("application.backupDir", backupPath); |
|
161 |
SystemUtil.writeStoredBackupFile(backupPath); |
|
162 |
|
|
163 |
// The mainBackupProperties hold properties that were backed up |
|
164 |
// the last time the application was configured. On disk, the |
|
165 |
// file will look like a smaller version of metacat.properties. |
|
166 |
// It is stored in the data storage directory outside the |
|
167 |
// application directories. |
|
168 |
mainBackupFilePath = backupPath + FileUtil.getFS() + MAIN_BACKUP_FILE_NAME; |
|
169 |
mainBackupProperties = new SortedProperties(mainBackupFilePath); |
|
170 |
mainBackupProperties.load(); |
|
171 |
|
|
172 |
// The authBackupProperties hold properties that were backed up |
|
173 |
// the last time the auth was configured. On disk, the file |
|
174 |
// will look like a smaller version of metacat.properties. It |
|
175 |
// is stored in the data storage directory outside the |
|
176 |
// application directories. |
|
177 |
authBackupFilePath = backupPath + FileUtil.getFS() + AUTH_BACKUP_FILE_NAME; |
|
178 |
authBackupProperties = new SortedProperties(authBackupFilePath); |
|
179 |
authBackupProperties.load(); |
|
180 |
} |
|
181 |
} catch (TransformerException te) { |
|
182 |
throw new ServiceException("Transform problem while loading properties: " |
|
183 |
+ te.getMessage()); |
|
184 |
} catch (IOException ioe) { |
|
185 |
throw new ServiceException("I/O problem while loading properties: " |
|
186 |
+ ioe.getMessage()); |
|
187 |
} catch (GeneralPropertyException gpe) { |
|
188 |
throw new ServiceException("General properties problem while loading properties: " |
|
189 |
+ gpe.getMessage()); |
|
190 |
} catch (MetacatUtilException ue) { |
|
191 |
throw new ServiceException("Utilities problem while loading properties: " |
|
192 |
+ ue.getMessage()); |
|
193 |
} |
|
194 |
} |
|
195 |
|
|
196 |
/** |
|
197 |
* Utility method to get a property value from the properties file |
|
198 |
* |
|
199 |
* @param propertyName |
|
200 |
* the name of the property requested |
|
201 |
* @return the String value for the property |
|
202 |
*/ |
|
203 |
public String getProperty(String propertyName) throws PropertyNotFoundException { |
|
204 |
return mainProperties.getProperty(propertyName); |
|
205 |
} |
|
206 |
|
|
207 |
/** |
|
208 |
* Get a set of all property names. |
|
209 |
* |
|
210 |
* @return Set of property names |
|
211 |
*/ |
|
212 |
public Vector<String> getPropertyNames() { |
|
213 |
return mainProperties.getPropertyNames(); |
|
214 |
} |
|
215 |
|
|
216 |
|
|
217 |
/** |
|
218 |
* Get a Set of all property names that start with the groupName prefix. |
|
219 |
* |
|
220 |
* @param groupName |
|
221 |
* the prefix of the keys to search for. |
|
222 |
* @return enumeration of property names |
|
223 |
*/ |
|
224 |
public Vector<String> getPropertyNamesByGroup(String groupName) { |
|
225 |
return mainProperties.getPropertyNamesByGroup(groupName); |
|
226 |
} |
|
227 |
|
|
228 |
/** |
|
229 |
* Get a Map of all properties that start with the groupName prefix. |
|
230 |
* |
|
231 |
* @param groupName |
|
232 |
* the prefix of the keys to search for. |
|
233 |
* @return Map of property names |
|
234 |
*/ |
|
235 |
public Map<String, String> getPropertiesByGroup(String groupName) throws PropertyNotFoundException { |
|
236 |
return mainProperties.getPropertiesByGroup(groupName); |
|
237 |
} |
|
238 |
|
|
239 |
/** |
|
240 |
* Utility method to set a property value both in memory and to the |
|
241 |
* properties file |
|
242 |
* |
|
243 |
* @param propertyName |
|
244 |
* the name of the property requested |
|
245 |
* @param newValue |
|
246 |
* the new value for the property |
|
247 |
*/ |
|
248 |
public void setProperty(String propertyName, String newValue) throws GeneralPropertyException { |
|
249 |
mainProperties.setProperty(propertyName, newValue); |
|
250 |
mainProperties.store(); |
|
251 |
} |
|
252 |
|
|
253 |
/** |
|
254 |
* Utility method to set a property value in memory. This will NOT cause the |
|
255 |
* property to be written to disk. Use this method to set multiple |
|
256 |
* properties in a row without causing excessive I/O. You must call |
|
257 |
* persistProperties() once you're done setting properties to have them |
|
258 |
* written to disk. |
|
259 |
* |
|
260 |
* @param propertyName |
|
261 |
* the name of the property requested |
|
262 |
* @param newValue |
|
263 |
* the new value for the property |
|
264 |
*/ |
|
265 |
public void setPropertyNoPersist(String propertyName, String newValue) throws GeneralPropertyException { |
|
266 |
mainProperties.setPropertyNoPersist(propertyName, newValue); |
|
267 |
} |
|
268 |
|
|
269 |
/** |
|
270 |
* Save the properties to a properties file. Note, the |
|
271 |
* order and comments will be preserved. |
|
272 |
*/ |
|
273 |
public void persistProperties() throws GeneralPropertyException { |
|
274 |
mainProperties.store(); |
|
275 |
} |
|
276 |
|
|
277 |
/** |
|
278 |
* Get the main backup properties file. These are configurable properties that |
|
279 |
* are stored outside the metacat install directories so the user does not |
|
280 |
* need to re-enter all the configuration information every time they do an |
|
281 |
* upgrade. |
|
282 |
* |
|
283 |
* @return a SortedProperties object with the backup properties |
|
284 |
*/ |
|
285 |
public SortedProperties getMainBackupProperties() { |
|
286 |
return mainBackupProperties; |
|
287 |
} |
|
288 |
|
|
289 |
/** |
|
290 |
* Get the auth backup properties file. These are configurable |
|
291 |
* properties that are stored outside the metacat install directories so |
|
292 |
* the user does not need to re-enter all the configuration information |
|
293 |
* every time they do an upgrade. |
|
294 |
* |
|
295 |
* @return a SortedProperties object with the backup properties |
|
296 |
*/ |
|
297 |
public SortedProperties getAuthBackupProperties() { |
|
298 |
return authBackupProperties; |
|
299 |
} |
|
300 |
|
|
301 |
/** |
|
302 |
* Get the main properties metadata. This is retrieved from an xml file that |
|
303 |
* describes the attributes of configurable properties. |
|
304 |
* |
|
305 |
* @return a PropertiesMetaData object with the main properties metadata |
|
306 |
*/ |
|
307 |
public PropertiesMetaData getMainMetaData() { |
|
308 |
return mainMetaData; |
|
309 |
} |
|
310 |
|
|
311 |
/** |
|
312 |
* Get the auth properties metadata. This is retrieved from an xml |
|
313 |
* file that describes the attributes of configurable properties. |
|
314 |
* |
|
315 |
* @return a PropertiesMetaData object with the organization properties |
|
316 |
* metadata |
|
317 |
*/ |
|
318 |
public PropertiesMetaData getAuthMetaData() { |
|
319 |
return authMetaData; |
|
320 |
} |
|
321 |
|
|
322 |
/** |
|
323 |
* Writes out backup configurable properties to a file. |
|
324 |
*/ |
|
325 |
public void persistMainBackupProperties() |
|
326 |
throws GeneralPropertyException { |
|
327 |
|
|
328 |
// Use the metadata to extract configurable properties from the |
|
329 |
// overall properties list, and store those properties. |
|
330 |
try { |
|
331 |
SortedProperties backupProperties = new SortedProperties(mainBackupFilePath); |
|
332 |
|
|
333 |
// Populate the backup properties for main metacat properties using |
|
334 |
// the associated metadata file |
|
335 |
PropertiesMetaData mainMetadata = new PropertiesMetaData(mainMetadataFilePath); |
|
336 |
|
|
337 |
Map<String, MetaDataProperty> mainKeyMap = mainMetadata.getProperties(); |
|
338 |
Set<String> mainKeySet = mainKeyMap.keySet(); |
|
339 |
for (String propertyKey : mainKeySet) { |
|
340 |
// don't backup passwords |
|
341 |
MetaDataProperty metaData = mainKeyMap.get(propertyKey); |
|
342 |
if (!metaData.getFieldType().equals(MetaDataProperty.PASSWORD_TYPE)) { |
|
343 |
backupProperties.addProperty(propertyKey, getProperty(propertyKey)); |
|
344 |
} |
|
345 |
} |
|
346 |
|
|
347 |
// store the properties to file |
|
348 |
backupProperties.store(); |
|
349 |
mainBackupProperties = |
|
350 |
new SortedProperties(mainBackupFilePath); |
|
351 |
mainBackupProperties.load(); |
|
352 |
|
|
353 |
} catch (TransformerException te) { |
|
354 |
throw new GeneralPropertyException("Could not transform backup properties xml: " |
|
355 |
+ te.getMessage()); |
|
356 |
} catch (IOException ioe) { |
|
357 |
throw new GeneralPropertyException("Could not backup configurable properties: " |
|
358 |
+ ioe.getMessage()); |
|
359 |
} |
|
360 |
} |
|
361 |
|
|
362 |
/** |
|
363 |
* Writes out backup configurable properties to a file. |
|
364 |
*/ |
|
365 |
public void persistAuthBackupProperties(ServletContext servletContext) |
|
366 |
throws GeneralPropertyException { |
|
367 |
|
|
368 |
// Use the metadata to extract configurable properties from the |
|
369 |
// overall properties list, and store those properties. |
|
370 |
try { |
|
371 |
SortedProperties backupProperties = |
|
372 |
new SortedProperties(authBackupFilePath); |
|
373 |
|
|
374 |
// Populate the backup properties for auth properties using |
|
375 |
// the associated metadata file |
|
376 |
PropertiesMetaData authMetadata = new PropertiesMetaData(authMetadataFilePath); |
|
377 |
|
|
378 |
Map<String, MetaDataProperty> authKeyMap = authMetadata.getProperties(); |
|
379 |
Set<String> authKeySet = authKeyMap.keySet(); |
|
380 |
for (String propertyKey : authKeySet) { |
|
381 |
// don't backup passwords |
|
382 |
MetaDataProperty metaData = authKeyMap.get(propertyKey); |
|
383 |
if (!metaData.getFieldType().equals(MetaDataProperty.PASSWORD_TYPE)) { |
|
384 |
backupProperties.addProperty(propertyKey, getProperty(propertyKey)); |
|
385 |
} |
|
386 |
} |
|
387 |
|
|
388 |
// store the properties to file |
|
389 |
backupProperties.store(); |
|
390 |
authBackupProperties = |
|
391 |
new SortedProperties(authBackupFilePath); |
|
392 |
authBackupProperties.load(); |
|
393 |
|
|
394 |
} catch (TransformerException te) { |
|
395 |
throw new GeneralPropertyException("Could not transform backup properties xml: " |
|
396 |
+ te.getMessage()); |
|
397 |
} catch (IOException ioe) { |
|
398 |
throw new GeneralPropertyException("Could not backup configurable properties: " |
|
399 |
+ ioe.getMessage()); |
|
400 |
} |
|
401 |
} |
|
402 |
|
|
403 |
/** |
|
404 |
* Reports whether properties are fully configured. |
|
405 |
* |
|
406 |
* @return a boolean that is true if properties are not unconfigured and |
|
407 |
* false otherwise |
|
408 |
*/ |
|
409 |
public boolean arePropertiesConfigured() throws GeneralPropertyException { |
|
410 |
String propertiesConfigured = getProperty("configutil.propertiesConfigured"); |
|
411 |
if (propertiesConfigured != null && !propertiesConfigured.equals(UNCONFIGURED)) { |
|
412 |
return true; |
|
413 |
} |
|
414 |
return false; |
|
415 |
} |
|
416 |
|
|
417 |
/** |
|
418 |
* Determine if the system is configured to bypass configuration. If so, the |
|
419 |
* system will look for backup configuration files at startup time and use |
|
420 |
* those to configure metacat. The bypass options should only be set by |
|
421 |
* developers. Production code should never bypass confguration. |
|
422 |
* |
|
423 |
* @return true if dev.runConfiguration is set to true in metacat.properties |
|
424 |
* and we have not already checked for bypass, false otherwise. |
|
425 |
*/ |
|
426 |
public boolean doBypass() throws PropertyNotFoundException { |
|
427 |
// We only want to go through the check once to see if we want to |
|
428 |
// bypass the configuration. We don't want to run through all of |
|
429 |
// this every time we hit metacat. |
|
430 |
if (bypassAlreadyChecked) { |
|
431 |
logMetacat.debug("bypassConfiguration not performing full bypass check. Bypass set to false"); |
|
432 |
return false; |
|
433 |
} |
|
434 |
|
|
435 |
// check how dev.runConfiguration is set in metacat.properties |
|
436 |
String strRunConfiguration = getProperty("dev.runConfiguration"); |
|
437 |
boolean runConfiguration = Boolean.parseBoolean(strRunConfiguration); |
|
438 |
logMetacat.debug("bypassConfiguration: dev.runConfiguration property set to: " + strRunConfiguration); |
|
439 |
|
|
440 |
// if the dev.runConfiguration is true, return false here. |
|
441 |
if (runConfiguration) { |
|
442 |
bypassAlreadyChecked = true; |
|
443 |
return false; |
|
444 |
} |
|
445 |
|
|
446 |
return true; |
|
447 |
} |
|
448 |
|
|
449 |
/** |
|
450 |
* Reports whether the metacat configuration utility should be run. |
|
451 |
* Returns false if |
|
452 |
* -- dev.runConfiguration=false and |
|
453 |
* -- backup properties file exists |
|
454 |
* Note that dev.runConfiguration should only be set to false when |
|
455 |
* reinstalling the same version of the application in developement. |
|
456 |
* |
|
457 |
* @return a boolean that is false if dev.runConfiguration is false and |
|
458 |
* the backup properties file exists. |
|
459 |
*/ |
|
460 |
public void bypassConfiguration() throws GeneralPropertyException { |
|
461 |
try { |
|
462 |
boolean doBypass = doBypass(); |
|
463 |
|
|
464 |
if (!doBypass) { |
|
465 |
throw new GeneralPropertyException( |
|
466 |
"Attempting to do bypass when system is not configured for it."); |
|
467 |
} |
|
468 |
|
|
469 |
// The system is bypassing the configuration utility. We need to |
|
470 |
// get the backup properties and replace existing properties with |
|
471 |
// backup values. We do this for main and org properties. |
|
472 |
logMetacat.debug("bypassConfiguration: setting main backup properties."); |
|
473 |
SortedProperties mainBackupProperties = getMainBackupProperties(); |
|
474 |
Vector<String> backupPropertyNames = |
|
475 |
mainBackupProperties.getPropertyNames(); |
|
476 |
for (String backupPropertyName : backupPropertyNames) { |
|
477 |
String value = mainBackupProperties.getProperty(backupPropertyName); |
|
478 |
setPropertyNoPersist(backupPropertyName, value); |
|
479 |
} |
|
480 |
|
|
481 |
logMetacat.debug("bypassConfiguration: setting auth backup properties."); |
|
482 |
SortedProperties authBackupProperties = getAuthBackupProperties(); |
|
483 |
Vector<String> authBackupPropertyNames = |
|
484 |
authBackupProperties.getPropertyNames(); |
|
485 |
for (String authBackupPropertyName : authBackupPropertyNames) { |
|
486 |
String value = authBackupProperties.getProperty(authBackupPropertyName); |
|
487 |
setPropertyNoPersist(authBackupPropertyName, value); |
|
488 |
} |
|
489 |
|
|
490 |
logMetacat.debug("bypassConfiguration: setting configutil sections to true."); |
|
491 |
setPropertyNoPersist("configutil.propertiesConfigured", "true"); |
|
492 |
setPropertyNoPersist("configutil.authConfigured", "true"); |
|
493 |
setPropertyNoPersist("configutil.skinsConfigured", "true"); |
|
494 |
setPropertyNoPersist("configutil.databaseConfigured", "true"); |
|
495 |
setPropertyNoPersist("configutil.geoserverConfigured", "bypassed"); |
|
496 |
|
|
497 |
persistProperties(); |
|
498 |
|
|
499 |
} catch (PropertyNotFoundException pnfe) { |
|
500 |
logMetacat.error("bypassConfiguration: Could not find property: " + pnfe.getMessage()); |
|
501 |
} catch (GeneralPropertyException gpe) { |
|
502 |
logMetacat.error("bypassConfiguration: General property error: " + gpe.getMessage()); |
|
503 |
} |
|
504 |
|
|
505 |
bypassAlreadyChecked = true; |
|
506 |
} |
|
507 |
|
|
508 |
/** |
|
509 |
* Take input from the user in an HTTP request about an property to be changed |
|
510 |
* and update the metacat property file with that new value if it has |
|
511 |
* changed from the value that was originally set. |
|
512 |
* |
|
513 |
* @param request |
|
514 |
* that was generated by the user |
|
515 |
* @param response |
|
516 |
* to send output back to the user |
|
517 |
* @param propertyName |
|
518 |
* the name of the property to be checked and set |
|
519 |
*/ |
|
520 |
public void checkAndSetProperty(HttpServletRequest request, String propertyName) |
|
521 |
throws GeneralPropertyException { |
|
522 |
String value = getProperty(propertyName); |
|
523 |
String newValue = request.getParameter(propertyName); |
|
524 |
if (newValue != null && !newValue.trim().equals(value)) { |
|
525 |
setPropertyNoPersist(propertyName, newValue.trim()); |
|
526 |
} |
|
527 |
} |
|
528 |
|
|
529 |
} |
|
0 | 530 |
src/edu/ucsb/nceas/metacat/properties/PropertiesInterface.java | ||
---|---|---|
1 |
/** |
|
2 |
* '$RCSfile$' |
|
3 |
* Purpose: A Class that loads eml-access.xml file containing ACL |
|
4 |
* for a metadata document into relational DB |
|
5 |
* Copyright: 2000 Regents of the University of California and the |
|
6 |
* National Center for Ecological Analysis and Synthesis |
|
7 |
* Authors: Jivka Bojilova |
|
8 |
* |
|
9 |
* '$Author: daigle $' |
|
10 |
* '$Date: 2009-03-25 14:04:06 -0800 (Wed, 25 Mar 2009) $' |
|
11 |
* '$Revision: 4863 $' |
|
12 |
* |
|
13 |
* This program is free software; you can redistribute it and/or modify |
|
14 |
* it under the terms of the GNU General Public License as published by |
|
15 |
* the Free Software Foundation; either version 2 of the License, or |
|
16 |
* (at your option) any later version. |
|
17 |
* |
|
18 |
* This program is distributed in the hope that it will be useful, |
|
19 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
20 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
21 |
* GNU General Public License for more details. |
|
22 |
* |
|
23 |
* You should have received a copy of the GNU General Public License |
|
24 |
* along with this program; if not, write to the Free Software |
|
25 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
|
26 |
*/ |
|
27 |
|
|
28 |
package edu.ucsb.nceas.metacat.properties; |
|
29 |
|
|
30 |
import java.util.Map; |
|
31 |
import java.util.Vector; |
|
32 |
|
|
33 |
import javax.servlet.ServletContext; |
|
34 |
import javax.servlet.http.HttpServletRequest; |
|
35 |
|
|
36 |
import edu.ucsb.nceas.metacat.shared.MetacatUtilException; |
|
37 |
import edu.ucsb.nceas.metacat.shared.ServiceException; |
|
38 |
import edu.ucsb.nceas.utilities.GeneralPropertyException; |
|
39 |
import edu.ucsb.nceas.utilities.PropertiesMetaData; |
|
40 |
import edu.ucsb.nceas.utilities.PropertyNotFoundException; |
|
41 |
import edu.ucsb.nceas.utilities.SortedProperties; |
|
42 |
|
|
43 |
/** |
|
44 |
* This interface will handle properties access |
|
45 |
*/ |
|
46 |
public interface PropertiesInterface { |
|
47 |
|
|
48 |
// system is configured |
|
49 |
public static final String CONFIGURED = "true"; |
|
50 |
// system has never been configured |
|
51 |
public static final String UNCONFIGURED = "false"; |
|
52 |
public static final String BYPASSED = "bypassed"; |
|
53 |
|
|
54 |
// public PropertiesInterface getInstance() throws ServiceException; |
|
55 |
|
|
56 |
public String getProperty(String propertyName) throws PropertyNotFoundException; |
|
57 |
|
|
58 |
public Vector<String> getPropertyNames(); |
|
59 |
|
|
60 |
public Vector<String> getPropertyNamesByGroup(String groupName); |
|
61 |
|
|
62 |
public Map<String, String> getPropertiesByGroup(String groupName) throws PropertyNotFoundException; |
|
63 |
|
|
64 |
public void setProperty(String propertyName, String newValue) throws GeneralPropertyException; |
|
65 |
|
|
66 |
public void setPropertyNoPersist(String propertyName, String newValue) throws GeneralPropertyException; |
|
67 |
|
|
68 |
public void persistProperties() throws GeneralPropertyException; |
|
69 |
|
|
70 |
public void checkAndSetProperty(HttpServletRequest request, String propertyName) throws GeneralPropertyException; |
|
71 |
|
|
72 |
public SortedProperties getMainBackupProperties() throws GeneralPropertyException; |
|
73 |
|
|
74 |
public SortedProperties getAuthBackupProperties() throws GeneralPropertyException; |
|
75 |
|
|
76 |
public PropertiesMetaData getMainMetaData() throws GeneralPropertyException; |
|
77 |
|
|
78 |
public PropertiesMetaData getAuthMetaData() throws GeneralPropertyException; |
|
79 |
|
|
80 |
public void persistMainBackupProperties() throws GeneralPropertyException; |
|
81 |
|
|
82 |
public void persistAuthBackupProperties(ServletContext servletContext) throws GeneralPropertyException; |
|
83 |
|
|
84 |
public boolean arePropertiesConfigured() throws GeneralPropertyException; |
|
85 |
|
|
86 |
public boolean doBypass() throws GeneralPropertyException; |
|
87 |
|
|
88 |
public void bypassConfiguration() throws GeneralPropertyException; |
|
89 |
|
|
90 |
} |
|
0 | 91 |
Also available in: Unified diff
Make properties handlers implement an interface so you can use configurable or non-configurable properties.