Mercurial > 510Connectbot
changeset 10:e773d0952613 tn5250
adding tn5250 files
author | Carl Byington <carl@five-ten-sg.com> |
---|---|
date | Thu, 22 May 2014 16:11:14 -0700 (2014-05-22) |
parents | 731e70088af0 |
children | f3b3bbd227b8 |
files | src/org/tn5250j/framework/tn5250/Screen5250.java src/org/tn5250j/framework/tn5250/tnvt.java src/org/tn5250j/framework/transport/SSL/X509CertificateTrustManager.java src/org/tn5250j/framework/transport/SocketConnector.java |
diffstat | 4 files changed, 39 insertions(+), 26 deletions(-) [+] |
line wrap: on
line diff
--- a/src/org/tn5250j/framework/tn5250/Screen5250.java Thu May 22 15:42:48 2014 -0700 +++ b/src/org/tn5250j/framework/tn5250/Screen5250.java Thu May 22 16:11:14 2014 -0700 @@ -498,8 +498,7 @@ while (planes.getWhichGUI(pos++) != BUTTON_RIGHT_EB) { eb.append(planes.getChar(pos)); } - org.tn5250j.tools.system.OperatingSystem.displayURL(eb - .toString()); + sessionVT.showURL(eb.toString()); // take out the log statement when we are sure it is // working log.info("Send to external Browser: " + eb.toString());
--- a/src/org/tn5250j/framework/tn5250/tnvt.java Thu May 22 15:42:48 2014 -0700 +++ b/src/org/tn5250j/framework/tn5250/tnvt.java Thu May 22 16:11:14 2014 -0700 @@ -83,7 +83,6 @@ import com.five_ten_sg.connectbot.service.TerminalBridge; import com.five_ten_sg.connectbot.service.TerminalManager; -import org.tn5250j.Session5250; import org.tn5250j.TN5250jConstants; import org.tn5250j.encoding.CharMappings; import org.tn5250j.encoding.ICodePage; @@ -133,7 +132,7 @@ private int readType; private boolean enhanced = true; private boolean cursorOn = false; - private String session = ""; + private String hostname = ""; private int port = 23; private boolean connected = false; private boolean support132 = true; @@ -166,10 +165,11 @@ private final TN5250jLogger log = TN5250jLogFactory.getLogger(this.getClass()); /** - * @param session * @param screen52 - * @param type + * @param enhanced * @param support132 + * @param bridge + * @param manager */ public tnvt(Screen5250 screen52, boolean enhanced, boolean support132, TerminalBridge bridge, TerminalManager manager) { if (log.isInfoEnabled()) { @@ -203,9 +203,15 @@ baosrsp = new ByteArrayOutputStream(); } + public void showURL(String url) { + if (url.indexOf("://") < 0) url = "http://" + url; + Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); + manager.startActivity(intent); + } + public String getHostName() { - return session; + return hostname; } @@ -257,12 +263,12 @@ public final boolean connect() { - return connect(session, port); + return connect(hostname, port); } - public final boolean connect(String s, int port) { + public final boolean connect(String hostname, int port) { // We will now see if there are any bypass signon parameters to be // processed. The system properties override these parameters so @@ -283,8 +289,8 @@ try { - session = s; - this.port = port; + this.hostname = hostname; + this.port = port; try { screen52.getOIA().setInputInhibited(ScreenOIA.INPUTINHIBITED_SYSTEM_WAIT, @@ -297,7 +303,7 @@ //smk - For SSL compability SocketConnector sc = new SocketConnector(); if (sslType != null) sc.setSSLType(sslType); - sock = sc.createSocket(s, port, bridge, manager); + sock = sc.createSocket(hostname, port, bridge, manager); if (sock == null) { log.warn("I did not get a socket");
--- a/src/org/tn5250j/framework/transport/SSL/X509CertificateTrustManager.java Thu May 22 15:42:48 2014 -0700 +++ b/src/org/tn5250j/framework/transport/SSL/X509CertificateTrustManager.java Thu May 22 16:11:14 2014 -0700 @@ -29,14 +29,16 @@ import java.util.ArrayList; import java.util.Arrays; -import javax.swing.JOptionPane; +import com.five_ten_sg.connectbot.service.TerminalBridge; +import com.five_ten_sg.connectbot.service.TerminalManager; + /** * This class is used to trust certificates exchanged during an SSL socket * handshake. It allows the user to accept the certificate so that connections * can be made without requiring the server to have a certificate signed by a * CA (Verisign, Thawte, etc.). - * + * * @author Stephen M. Kennedy <skennedy@tenthpowertech.com> * @deprecated. no longer used. * @@ -45,9 +47,12 @@ KeyStore ks = null; TrustManager[] trustManagers; - //X509TrustManager trustManager = null; + TerminalBridge bridge = null; + TerminalManager manager = null; - public X509CertificateTrustManager(TrustManager[] managers, KeyStore keyStore) { + public X509CertificateTrustManager(TrustManager[] managers, KeyStore keyStore, TerminalBridge bridge, TerminalManager manager) { + this.bridge = bridge; + this.manager = manager; trustManagers = managers; ks = keyStore; } @@ -55,14 +60,14 @@ public void checkClientTrusted(X509Certificate[] chain, String type) throws CertificateException { throw new SecurityException("checkClientTrusted unsupported"); } - - + + /** * Checks the server certificate. If it isn't trusted by the trust manager * passed to the constructor, then the user will be prompted to accept the * certificate. */ - public void checkServerTrusted(X509Certificate[] chain, String type) + public void checkServerTrusted(X509Certificate[] chain, String type) throws CertificateException { try { for (int i=0; i<trustManagers.length; i++) { @@ -80,10 +85,10 @@ certInfo = certInfo.concat("Valid To: " + cert.getNotAfter()+"\n"); certInfo = certInfo.concat("Subject DN: " + cert.getSubjectDN().getName()+"\n"); certInfo = certInfo.concat("Public Key: " + cert.getPublicKey().getFormat()+"\n"); - - int accept = JOptionPane.showConfirmDialog(null,certInfo, - "Accept Certificate",javax.swing.JOptionPane.YES_NO_OPTION); - if (accept != JOptionPane.YES_OPTION) { + + bridge.outputLine(manager.res.getString(R.string.host_certificate, certInfo)); + Boolean result = bridge.promptHelper.requestBooleanPrompt(null, manager.res.getString(R.string.prompt_accept_certificate)); + if ((result == null) || (!result.booleanValue())) { throw new java.security.cert.CertificateException("Certificate Not Accepted"); } }
--- a/src/org/tn5250j/framework/transport/SocketConnector.java Thu May 22 15:42:48 2014 -0700 +++ b/src/org/tn5250j/framework/transport/SocketConnector.java Thu May 22 16:11:14 2014 -0700 @@ -25,6 +25,9 @@ import java.net.Socket; +import com.five_ten_sg.connectbot.service.TerminalBridge; +import com.five_ten_sg.connectbot.service.TerminalManager; + import org.tn5250j.framework.transport.SSL.SSLImplementation; import org.tn5250j.TN5250jConstants; import org.tn5250j.tools.logging.TN5250jLogFactory; @@ -62,7 +65,7 @@ * @param port * @return a new client socket, or null if */ - public Socket createSocket(String destination, int port) { + public Socket createSocket(String destination, int port, TerminalBridge bridge, TerminalManager manager) { Socket socket = null; Exception ex = null; @@ -83,7 +86,7 @@ SSLInterface sslIf = null; try { - sslIf = (SSLInterface) new SSLImplementation(); + sslIf = (SSLInterface) new SSLImplementation(bridge, manager); } catch (Exception e) { ex = new Exception("Failed to create SSLInterface Instance. " + "Message is ["+e.getMessage()+"]"); @@ -91,7 +94,7 @@ if (sslIf != null) { sslIf.init(sslType); - socket = sslIf.createSSLSocket(destination,port); + socket = sslIf.createSSLSocket(destination, port); } }