/*************************************************** * * cismet GmbH, Saarbruecken, Germany * * ... and it just works. * ****************************************************/ /* * Copyright (C) 2010 mscholl * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ /* * ConnectionTester.java * * Created on Jul 5, 2010, 4:38:47 PM */ package Sirius.navigator; import org.apache.log4j.Logger; import org.apache.log4j.PropertyConfigurator; import org.openide.util.Lookup; import java.awt.EventQueue; import java.io.BufferedOutputStream; import java.io.FileOutputStream; import java.io.IOException; import java.util.Properties; import javax.swing.JFileChooser; import javax.swing.JTextArea; import de.cismet.cids.server.ws.SSLConfigProvider; import de.cismet.cids.server.ws.rest.RESTfulSerialInterfaceConnector; import de.cismet.netutil.Proxy; import de.cismet.tools.gui.TextAreaAppender; /** * DOCUMENT ME! * * @author mscholl * @version $Revision$, $Date$ */ public class ConnectionTester extends javax.swing.JFrame { //~ Static fields/initializers --------------------------------------------- private static final transient Logger LOG = Logger.getLogger(ConnectionTester.class); //~ Instance fields -------------------------------------------------------- private final String connectionUrl; // Variables declaration - do not modify//GEN-BEGIN:variables private javax.swing.JButton btnStore; private javax.swing.JButton btnTest; private javax.swing.JEditorPane jEditorPane1; private javax.swing.JPanel jPanel1; private javax.swing.JPanel jPanel3; private javax.swing.JScrollPane jScrollPane1; private javax.swing.JScrollPane jScrollPane2; private javax.swing.JScrollPane jScrollPane3; private javax.swing.JScrollPane jScrollPane4; private javax.swing.JTabbedPane jTabbedPane1; private javax.swing.JTextPane jTextPane1; private de.cismet.lookupoptions.options.ProxyOptionsPanel proxyOptionsPanel1; private javax.swing.JTextArea txaLog; private javax.swing.JTextArea txaOut; // End of variables declaration//GEN-END:variables //~ Constructors ----------------------------------------------------------- /** * Creates new form ConnectionTester. * * @param connectionUrl DOCUMENT ME! */ public ConnectionTester(final String connectionUrl) { this.connectionUrl = connectionUrl; initComponents(); initLog(); setTitle(getTitle() + ": " + connectionUrl); proxyOptionsPanel1.update(); } //~ Methods ---------------------------------------------------------------- /** * DOCUMENT ME! */ private void initLog() { TextAreaAppender.setTextArea(txaLog, new JTextArea()); final Properties logProperties = new Properties(); logProperties.put("log4j.rootLogger", "DEBUG, CONSOLE, TEXTAREA"); logProperties.put("log4j.appender.CONSOLE", "org.apache.log4j.ConsoleAppender"); // A standard console // appender logProperties.put("log4j.appender.CONSOLE.layout", "org.apache.log4j.PatternLayout"); // See: // http://logging.apache.org/log4j/docs/api/org/apache/log4j/PatternLayout.html logProperties.put("log4j.appender.CONSOLE.layout.ConversionPattern", "%d{HH:mm:ss} [%12.12t] %5.5p %c: %m%n"); logProperties.put("log4j.appender.TEXTAREA", "de.cismet.tools.gui.TextAreaAppender"); // Our custom appender logProperties.put("log4j.appender.TEXTAREA.layout", "org.apache.log4j.PatternLayout"); // See: // http://logging.apache.org/log4j/docs/api/org/apache/log4j/PatternLayout.html logProperties.put("log4j.appender.TEXTAREA.layout.ConversionPattern", "%d{HH:mm:ss} [%12.12t] %5.5p %c: %m%n"); PropertyConfigurator.configure(logProperties); } /** * This method is called from within the constructor to initialize the form. WARNING: Do NOT modify this code. The * content of this method is always regenerated by the Form Editor. */ @SuppressWarnings("unchecked") // <editor-fold defaultstate="collapsed" desc="Generated Code">//GEN-BEGIN:initComponents private void initComponents() { java.awt.GridBagConstraints gridBagConstraints; jScrollPane2 = new javax.swing.JScrollPane(); jEditorPane1 = new javax.swing.JEditorPane(); jScrollPane3 = new javax.swing.JScrollPane(); jTextPane1 = new javax.swing.JTextPane(); btnTest = new javax.swing.JButton(); jTabbedPane1 = new javax.swing.JTabbedPane(); jScrollPane1 = new javax.swing.JScrollPane(); txaOut = new javax.swing.JTextArea(); jPanel1 = new javax.swing.JPanel(); jScrollPane4 = new javax.swing.JScrollPane(); txaLog = new javax.swing.JTextArea(); btnStore = new javax.swing.JButton(); jPanel3 = new javax.swing.JPanel(); proxyOptionsPanel1 = new de.cismet.lookupoptions.options.ProxyOptionsPanel(); jScrollPane2.setViewportView(jEditorPane1); jScrollPane3.setViewportView(jTextPane1); setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE); setTitle(org.openide.util.NbBundle.getMessage(ConnectionTester.class, "ConnectionTester.title")); // NOI18N getContentPane().setLayout(new java.awt.GridBagLayout()); btnTest.setText("Test"); // NOI18N btnTest.addActionListener(new java.awt.event.ActionListener() { @Override public void actionPerformed(final java.awt.event.ActionEvent evt) { btnTestActionPerformed(evt); } }); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 0; gridBagConstraints.gridy = 1; gridBagConstraints.anchor = java.awt.GridBagConstraints.EAST; gridBagConstraints.insets = new java.awt.Insets(5, 5, 5, 5); getContentPane().add(btnTest, gridBagConstraints); txaOut.setColumns(20); txaOut.setRows(5); jScrollPane1.setViewportView(txaOut); jTabbedPane1.addTab("Out", jScrollPane1); jPanel1.setLayout(new java.awt.GridBagLayout()); txaLog.setColumns(20); txaLog.setRows(5); txaLog.setAutoscrolls(false); jScrollPane4.setViewportView(txaLog); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 0; gridBagConstraints.gridy = 0; gridBagConstraints.gridwidth = 2; gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; gridBagConstraints.ipadx = 744; gridBagConstraints.ipady = 345; gridBagConstraints.anchor = java.awt.GridBagConstraints.NORTHWEST; gridBagConstraints.weightx = 1.0; gridBagConstraints.weighty = 1.0; jPanel1.add(jScrollPane4, gridBagConstraints); btnStore.setText("save"); // NOI18N btnStore.addActionListener(new java.awt.event.ActionListener() { @Override public void actionPerformed(final java.awt.event.ActionEvent evt) { btnStoreActionPerformed(evt); } }); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 1; gridBagConstraints.gridy = 1; gridBagConstraints.insets = new java.awt.Insets(5, 5, 5, 5); jPanel1.add(btnStore, gridBagConstraints); final org.jdesktop.layout.GroupLayout jPanel3Layout = new org.jdesktop.layout.GroupLayout(jPanel3); jPanel3.setLayout(jPanel3Layout); jPanel3Layout.setHorizontalGroup( jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING).add(0, 0, Short.MAX_VALUE)); jPanel3Layout.setVerticalGroup( jPanel3Layout.createParallelGroup(org.jdesktop.layout.GroupLayout.LEADING).add(0, 0, Short.MAX_VALUE)); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 0; gridBagConstraints.gridy = 1; gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; gridBagConstraints.weightx = 1.0; gridBagConstraints.insets = new java.awt.Insets(5, 5, 5, 5); jPanel1.add(jPanel3, gridBagConstraints); jTabbedPane1.addTab("Log", jPanel1); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.gridx = 0; gridBagConstraints.gridy = 2; gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; gridBagConstraints.anchor = java.awt.GridBagConstraints.NORTHWEST; gridBagConstraints.weightx = 1.0; gridBagConstraints.weighty = 1.0; gridBagConstraints.insets = new java.awt.Insets(5, 5, 5, 5); getContentPane().add(jTabbedPane1, gridBagConstraints); gridBagConstraints = new java.awt.GridBagConstraints(); gridBagConstraints.fill = java.awt.GridBagConstraints.BOTH; getContentPane().add(proxyOptionsPanel1, gridBagConstraints); pack(); } // </editor-fold>//GEN-END:initComponents /** * DOCUMENT ME! * * @param evt DOCUMENT ME! */ private void btnTestActionPerformed(final java.awt.event.ActionEvent evt) //GEN-FIRST:event_btnTestActionPerformed { //GEN-HEADEREND:event_btnTestActionPerformed try { txaOut.setText(""); proxyOptionsPanel1.applyChanges(); final Proxy proxy = proxyOptionsPanel1.getProxy(); txaOut.setText("Connection test running...\n\n"); final RESTfulSerialInterfaceConnector connector = new RESTfulSerialInterfaceConnector( connectionUrl, proxy, Lookup.getDefault().lookup(SSLConfigProvider.class).getSSLConfig()); final Thread establisher = new Thread(new Runnable() { @Override public void run() { try { final String ret = connector.getDomains().length + " domain(s) retrieved\n\nSUCCESS"; EventQueue.invokeLater(new Runnable() { @Override public void run() { txaOut.append(ret); } }); } catch (final Exception ex) { appendException(ex); } } }); establisher.start(); } catch (final Exception ex) { appendException(ex); } } //GEN-LAST:event_btnTestActionPerformed /** * DOCUMENT ME! * * @param ex DOCUMENT ME! */ private void appendException(final Exception ex) { EventQueue.invokeLater(new Runnable() { @Override public void run() { txaOut.append(ex.getMessage() + "\n"); txaOut.append("STACKTRACE: \n"); for (final StackTraceElement ste : ex.getStackTrace()) { txaOut.append(ste.toString() + "\n"); } Throwable cause = ex.getCause(); while (cause != null) { txaOut.append("\n\n"); txaOut.append("CAUSE: "); txaOut.append(cause.getMessage()); txaOut.append("\n"); txaOut.append("STACKTRACE: \n"); for (final StackTraceElement ste : cause.getStackTrace()) { txaOut.append(ste.toString() + "\n"); } cause = cause.getCause(); } txaOut.append("\nFAILURE"); } }); } /** * DOCUMENT ME! * * @param evt DOCUMENT ME! */ private void btnStoreActionPerformed(final java.awt.event.ActionEvent evt) //GEN-FIRST:event_btnStoreActionPerformed { //GEN-HEADEREND:event_btnStoreActionPerformed BufferedOutputStream bos = null; try { final JFileChooser chooser = new JFileChooser(); final int answer = chooser.showSaveDialog(this); if (answer == JFileChooser.APPROVE_OPTION) { bos = new BufferedOutputStream(new FileOutputStream(chooser.getSelectedFile())); bos.write(txaLog.getText().getBytes()); } } catch (final Exception e) { LOG.error("cannot save log", e); if (bos != null) { try { bos.close(); } catch (final IOException ex) { LOG.error("cannot close stream", ex); } } } } //GEN-LAST:event_btnStoreActionPerformed /** * DOCUMENT ME! * * @param args the command line arguments * * @throws Exception DOCUMENT ME! */ public static void main(final String[] args) throws Exception { if ((args.length <= 0) || !(args[0] instanceof String)) { System.out.println("missing connectionUrl argument"); System.exit(1); } java.awt.EventQueue.invokeLater(new Runnable() { @Override public void run() { new ConnectionTester((String)args[0]).setVisible(true); } }); } }