Some work on XDAEMON command.
3 * see AUTHORS for the list of contributors
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 package org.sonews.config;
22 * Configuration facade class.
23 * @author Christian Lins
26 public class Config extends AbstractConfig
29 public static final int LEVEL_CLI = 1;
30 public static final int LEVEL_FILE = 2;
31 public static final int LEVEL_BACKEND = 3;
32 public static final String CONFIGFILE = "sonews.configfile";
33 /** BackendConfig key constant. Value is the maximum article size in kilobytes. */
34 public static final String ARTICLE_MAXSIZE = "sonews.article.maxsize";
35 /** BackendConfig key constant. Value: Amount of news that are feeded per run. */
36 public static final String EVENTLOG = "sonews.eventlog";
37 public static final String FEED_NEWSPERRUN = "sonews.feed.newsperrun";
38 public static final String FEED_PULLINTERVAL = "sonews.feed.pullinterval";
39 public static final String HOSTNAME = "sonews.hostname";
40 public static final String PORT = "sonews.port";
41 public static final String TIMEOUT = "sonews.timeout";
42 public static final String LOGLEVEL = "sonews.loglevel";
43 public static final String MLPOLL_DELETEUNKNOWN = "sonews.mlpoll.deleteunknown";
44 public static final String MLPOLL_HOST = "sonews.mlpoll.host";
45 public static final String MLPOLL_PASSWORD = "sonews.mlpoll.password";
46 public static final String MLPOLL_USER = "sonews.mlpoll.user";
47 public static final String MLSEND_ADDRESS = "sonews.mlsend.address";
48 public static final String MLSEND_RW_FROM = "sonews.mlsend.rewrite.from";
49 public static final String MLSEND_RW_SENDER = "sonews.mlsend.rewrite.sender";
50 public static final String MLSEND_HOST = "sonews.mlsend.host";
51 public static final String MLSEND_PASSWORD = "sonews.mlsend.password";
52 public static final String MLSEND_PORT = "sonews.mlsend.port";
53 public static final String MLSEND_USER = "sonews.mlsend.user";
54 /** Key constant. If value is "true" every I/O is written to logfile
57 public static final String DEBUG = "sonews.debug";
58 /** Key constant. Value is classname of the JDBC driver */
59 public static final String STORAGE_DBMSDRIVER = "sonews.storage.dbmsdriver";
60 /** Key constant. Value is JDBC connect String to the database. */
61 public static final String STORAGE_DATABASE = "sonews.storage.database";
62 /** Key constant. Value is the username for the DBMS. */
63 public static final String STORAGE_USER = "sonews.storage.user";
64 /** Key constant. Value is the password for the DBMS. */
65 public static final String STORAGE_PASSWORD = "sonews.storage.password";
66 /** Key constant. Value is the name of the host which is allowed to use the
67 * XDAEMON command; default: "localhost" */
68 public static final String XDAEMON_HOST = "sonews.xdaemon.host";
69 /** The config key for the filename of the logfile */
70 public static final String LOGFILE = "sonews.log";
71 public static final String[] AVAILABLE_KEYS = {
92 private static Config instance = new Config();
94 public static Config inst()
104 public String get(String key, String def)
106 String val = CommandLineConfig.getInstance().get(key, null);
109 val = FileConfig.getInstance().get(key, null);
113 val = BackendConfig.getInstance().get(key, def);
119 public String get(int maxLevel, String key, String def)
121 String val = CommandLineConfig.getInstance().get(key, null);
123 if (val == null && maxLevel >= LEVEL_FILE) {
124 val = FileConfig.getInstance().get(key, null);
125 if (val == null && maxLevel >= LEVEL_BACKEND) {
126 val = BackendConfig.getInstance().get(key, def);
130 return val != null ? val : def;
134 public void set(String key, String val)
136 set(LEVEL_BACKEND, key, val);
139 public void set(int level, String key, String val)
143 CommandLineConfig.getInstance().set(key, val);
147 FileConfig.getInstance().set(key, val);
150 case LEVEL_BACKEND: {
151 BackendConfig.getInstance().set(key, val);