001: /*
002: * Licensed to the Apache Software Foundation (ASF) under one or more
003: * contributor license agreements. See the NOTICE file distributed with
004: * this work for additional information regarding copyright ownership.
005: * The ASF licenses this file to You under the Apache License, Version 2.0
006: * (the "License"); you may not use this file except in compliance with
007: * the License. You may obtain a copy of the License at
008: *
009: * http://www.apache.org/licenses/LICENSE-2.0
010: *
011: * Unless required by applicable law or agreed to in writing, software
012: * distributed under the License is distributed on an "AS IS" BASIS,
013: * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
014: * See the License for the specific language governing permissions and
015: * limitations under the License.
016: */
017: package org.apache.servicemix.mail.utils;
018:
019: import javax.mail.Authenticator;
020: import javax.mail.PasswordAuthentication;
021:
022: /**
023: * a data holder class for the connection information
024: *
025: * @author lhein
026: */
027: public class MailConnectionConfiguration {
028: private String host;
029: private String password;
030: private String protocol;
031: private String username;
032: private String folderName = "INBOX";
033:
034: private int port = -1;
035:
036: /**
037: * @return the host
038: */
039: public String getHost() {
040: return this .host;
041: }
042:
043: /**
044: * @param host the host to set
045: */
046: public void setHost(String host) {
047: this .host = host;
048: }
049:
050: /**
051: * @return the password
052: */
053: public String getPassword() {
054: return this .password;
055: }
056:
057: /**
058: * @param password the password to set
059: */
060: public void setPassword(String password) {
061: this .password = password;
062: }
063:
064: /**
065: * @return the protocol
066: */
067: public String getProtocol() {
068: return this .protocol.toLowerCase();
069: }
070:
071: /**
072: * @param protocol the protocol to set
073: */
074: public void setProtocol(String protocol) {
075: this .protocol = protocol;
076: }
077:
078: /**
079: * @return the username
080: */
081: public String getUsername() {
082: return this .username;
083: }
084:
085: /**
086: * @param username the username to set
087: */
088: public void setUsername(String username) {
089: this .username = username;
090: }
091:
092: /**
093: * @return the folderName
094: */
095: public String getFolderName() {
096: return this .folderName;
097: }
098:
099: /**
100: * @param folderName the folderName to set
101: */
102: public void setFolderName(String folderName) {
103: this .folderName = folderName;
104: }
105:
106: /**
107: * @return the port
108: */
109: public int getPort() {
110: return this .port;
111: }
112:
113: /**
114: * @param port the port to set
115: */
116: public void setPort(int port) {
117: this .port = port;
118: }
119:
120: /**
121: * flags the used protocol to be secure or not
122: *
123: * @return true if secure otherwise false
124: */
125: public boolean isSecureProtocol() {
126: return this .protocol.equalsIgnoreCase("smtps")
127: || this .protocol.equalsIgnoreCase("pop3s")
128: || this .protocol.equalsIgnoreCase("imaps");
129: }
130:
131: /**
132: * returns an authenticator object for use in sessions
133: *
134: * @return the authenticator object
135: */
136: public Authenticator getAuthenticator() {
137: return new Authenticator() {
138: /*
139: * (non-Javadoc)
140: *
141: * @see javax.mail.Authenticator#getPasswordAuthentication()
142: */
143: @Override
144: protected PasswordAuthentication getPasswordAuthentication() {
145: PasswordAuthentication pa = new PasswordAuthentication(
146: getUsername(), getPassword());
147: return pa;
148: }
149: };
150: }
151: }
|