3
|
1
|
|
2 /**
|
|
3 * @(#)SocketConnector.java
|
|
4 * @author Stephen M. Kennedy
|
|
5 *
|
|
6 * Copyright: Copyright (c) 2001
|
|
7 *
|
|
8 * This program is free software; you can redistribute it and/or modify
|
|
9 * it under the terms of the GNU General Public License as published by
|
|
10 * the Free Software Foundation; either version 2, or (at your option)
|
|
11 * any later version.
|
|
12 *
|
|
13 * This program is distributed in the hope that it will be useful,
|
|
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
16 * GNU General Public License for more details.
|
|
17 *
|
|
18 * You should have received a copy of the GNU General Public License
|
|
19 * along with this software; see the file COPYING. If not, write to
|
|
20 * the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
|
|
21 * Boston, MA 02111-1307 USA
|
|
22 *
|
|
23 */
|
|
24 package org.tn5250j.framework.transport;
|
|
25
|
|
26 import java.net.Socket;
|
|
27
|
8
|
28 import org.tn5250j.framework.transport.SSL.SSLImplementation;
|
3
|
29 import org.tn5250j.TN5250jConstants;
|
|
30 import org.tn5250j.tools.logging.TN5250jLogFactory;
|
|
31 import org.tn5250j.tools.logging.TN5250jLogger;
|
|
32
|
|
33 public class SocketConnector {
|
|
34
|
|
35 String sslType = null;
|
|
36
|
|
37 TN5250jLogger logger;
|
|
38
|
|
39 /**
|
|
40 * Creates a new instance that creates a plain socket by default.
|
|
41 */
|
|
42 public SocketConnector() {
|
|
43 logger = TN5250jLogFactory.getLogger(getClass());
|
|
44 }
|
|
45
|
|
46 /**
|
|
47 * Set the type of SSL connection to use. Specify null or an empty string
|
8
|
48 * to use a plain socket.
|
3
|
49 * @param type The SSL connection type
|
|
50 * @see org.tn5250j.framework.transport.SSLConstants
|
|
51 */
|
|
52 public void setSSLType(String type) {
|
|
53 sslType = type;
|
|
54 }
|
|
55
|
|
56 /**
|
|
57 * Create a new client Socket to the given destination and port. If an SSL
|
|
58 * socket type has not been specified <i>(by setSSLType(String))</i>, then
|
8
|
59 * a plain socket will be created. Otherwise, a new SSL socket of the
|
3
|
60 * specified type will be created.
|
|
61 * @param destination
|
|
62 * @param port
|
8
|
63 * @return a new client socket, or null if
|
3
|
64 */
|
|
65 public Socket createSocket(String destination, int port) {
|
|
66
|
|
67 Socket socket = null;
|
|
68 Exception ex = null;
|
8
|
69
|
|
70 if (sslType == null || sslType.trim().length() == 0 ||
|
3
|
71 sslType.toUpperCase().equals(TN5250jConstants.SSL_TYPE_NONE)) {
|
|
72 logger.info("Creating Plain Socket");
|
|
73 try {
|
|
74 // Use Socket Constructor!!! SocketFactory for jdk 1.4
|
|
75 socket = new Socket(destination,port);
|
|
76 } catch (Exception e) {
|
|
77 ex = e;
|
|
78 }
|
|
79 } else { //SSL SOCKET
|
|
80
|
8
|
81 logger.info("Creating SSL ["+sslType+"] Socket");
|
|
82
|
3
|
83 SSLInterface sslIf = null;
|
8
|
84
|
3
|
85 try {
|
8
|
86 sslIf = (SSLInterface) new SSLImplementation();
|
3
|
87 } catch (Exception e) {
|
|
88 ex = new Exception("Failed to create SSLInterface Instance. " +
|
|
89 "Message is ["+e.getMessage()+"]");
|
|
90 }
|
8
|
91
|
3
|
92 if (sslIf != null) {
|
|
93 sslIf.init(sslType);
|
|
94 socket = sslIf.createSSLSocket(destination,port);
|
|
95 }
|
|
96 }
|
|
97
|
|
98 if (ex != null) {
|
|
99 logger.error(ex);
|
|
100 }
|
|
101 if (socket == null) {
|
|
102 logger.warn("No socket was created");
|
|
103 }
|
|
104 return socket;
|
|
105 }
|
8
|
106
|
|
107
|
3
|
108 } |