1 /**
2 *
3 * Copyright 2003-2006 The Apache Software Foundation
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18 package org.apache.geronimo.mail.util;
19
20 import java.security.Security;
21
22 import javax.mail.Session;
23
24 /**
25 * Simple utility class for managing session properties.
26 */
27 public class SessionUtil {
28
29 /**
30 * Get a property associated with this mail session. Returns
31 * the provided default if it doesn't exist.
32 *
33 * @param session The attached session.
34 * @param name The name of the property.
35 *
36 * @return The property value (returns null if the property has not been set).
37 */
38 static public String getProperty(Session session, String name) {
39
40
41 if (session == null) {
42 return null;
43 }
44
45 return session.getProperty(name);
46 }
47
48
49 /**
50 * Get a property associated with this mail session. Returns
51 * the provided default if it doesn't exist.
52 *
53 * @param session The attached session.
54 * @param name The name of the property.
55 * @param defaultValue
56 * The default value to return if the property doesn't exist.
57 *
58 * @return The property value (returns defaultValue if the property has not been set).
59 */
60 static public String getProperty(Session session, String name, String defaultValue) {
61 String result = getProperty(session, name);
62 if (result == null) {
63 return defaultValue;
64 }
65 return result;
66 }
67
68
69 /**
70 * Process a session property as a boolean value, returning
71 * either true or false.
72 *
73 * @param session The source session.
74 * @param name
75 *
76 * @return True if the property value is "true". Returns false for any
77 * other value (including null).
78 */
79 static public boolean isPropertyTrue(Session session, String name) {
80 String property = getProperty(session, name);
81 if (property != null) {
82 return property.equals("true");
83 }
84 return false;
85 }
86
87 /**
88 * Process a session property as a boolean value, returning
89 * either true or false.
90 *
91 * @param session The source session.
92 * @param name
93 *
94 * @return True if the property value is "false". Returns false for
95 * other value (including null).
96 */
97 static public boolean isPropertyFalse(Session session, String name) {
98 String property = getProperty(session, name);
99 if (property != null) {
100 return property.equals("false");
101 }
102 return false;
103 }
104
105 /**
106 * Get a property associated with this mail session as an integer value. Returns
107 * the default value if the property doesn't exist or it doesn't have a valid int value.
108 *
109 * @param session The source session.
110 * @param name The name of the property.
111 * @param defaultValue
112 * The default value to return if the property doesn't exist.
113 *
114 * @return The property value converted to an int.
115 */
116 static public int getIntProperty(Session session, String name, int defaultValue) {
117 String result = getProperty(session, name);
118 if (result != null) {
119 try {
120
121 return Integer.parseInt(result);
122 } catch (NumberFormatException e) {
123 }
124 }
125
126 return defaultValue;
127 }
128
129
130 /**
131 * Get a property associated with this mail session as a boolean value. Returns
132 * the default value if the property doesn't exist or it doesn't have a valid boolean value.
133 *
134 * @param session The source session.
135 * @param name The name of the property.
136 * @param defaultValue
137 * The default value to return if the property doesn't exist.
138 *
139 * @return The property value converted to a boolean.
140 */
141 static public boolean getBooleanProperty(Session session, String name, boolean defaultValue) {
142 String result = getProperty(session, name);
143 if (result != null) {
144 return Boolean.valueOf(result).booleanValue();
145 }
146
147 return defaultValue;
148 }
149
150
151 /**
152 * Get a system property associated with this mail session as a boolean value. Returns
153 * the default value if the property doesn't exist or it doesn't have a valid boolean value.
154 *
155 * @param name The name of the property.
156 * @param defaultValue
157 * The default value to return if the property doesn't exist.
158 *
159 * @return The property value converted to a boolean.
160 */
161 static public boolean getBooleanProperty(String name, boolean defaultValue) {
162 try {
163 String result = System.getProperty(name);
164 if (result != null) {
165 return Boolean.valueOf(result).booleanValue();
166 }
167 } catch (SecurityException e) {
168
169 }
170
171 return defaultValue;
172 }
173
174
175 /**
176 * Get a system property associated with this mail session as a boolean value. Returns
177 * the default value if the property doesn't exist.
178 *
179 * @param name The name of the property.
180 * @param defaultValue
181 * The default value to return if the property doesn't exist.
182 *
183 * @return The property value
184 */
185 static public String getProperty(String name, String defaultValue) {
186 try {
187 String result = System.getProperty(name);
188 if (result != null) {
189 return result;
190 }
191 } catch (SecurityException e) {
192
193 }
194
195 return defaultValue;
196 }
197
198
199 /**
200 * Get a system property associated with this mail session as a boolean value. Returns
201 * the default value if the property doesn't exist.
202 *
203 * @param name The name of the property.
204 *
205 * @return The property value
206 */
207 static public String getProperty(String name) {
208 try {
209 return System.getProperty(name);
210 } catch (SecurityException e) {
211
212 }
213
214 return null;
215 }
216 }