| 1 | /******************************************************************************* | |
| 2 |  * Copyhacked (H) 2012-2025. | |
| 3 |  * This program and the accompanying materials | |
| 4 |  * are made available under no term at all, use it like | |
| 5 |  * you want, but share and discuss it | |
| 6 |  * every time possible with every body. | |
| 7 |  *  | |
| 8 |  * Contributors: | |
| 9 |  *      ron190 at ymail dot com - initial implementation | |
| 10 |  ******************************************************************************/ | |
| 11 | package com.jsql.view.swing.terminal; | |
| 12 | ||
| 13 | import com.jsql.util.LogLevelUtil; | |
| 14 | import org.apache.logging.log4j.LogManager; | |
| 15 | import org.apache.logging.log4j.Logger; | |
| 16 | ||
| 17 | import java.io.IOException; | |
| 18 | import java.net.URISyntaxException; | |
| 19 | import java.util.UUID; | |
| 20 | ||
| 21 | /** | |
| 22 |  * A terminal for web shell injection. | |
| 23 |  */ | |
| 24 | public class ExploitReverseShell extends AbstractExploit { | |
| 25 | ||
| 26 |     private static final Logger LOGGER = LogManager.getRootLogger(); | |
| 27 | ||
| 28 |     private final transient ServerInput serverInput; | |
| 29 | ||
| 30 |     /** | |
| 31 |      * Build a webshell instance. | |
| 32 |      * | |
| 33 |      * @param terminalID Unique identifier to discriminate beyond multiple opened terminals | |
| 34 |      * @param port | |
| 35 |      */ | |
| 36 |     public ExploitReverseShell(UUID terminalID, String port) throws IOException, URISyntaxException { | |
| 37 |         super(terminalID, null, "reverse", false); | |
| 38 | ||
| 39 |         this.serverInput = new ServerInput(this, Integer.parseInt(port)); | |
| 40 |         new Thread(() -> { | |
| 41 |             try { | |
| 42 | 1
1. lambda$new$0 : removed call to com/jsql/view/swing/terminal/ServerInput::startServer → NO_COVERAGE |                 this.serverInput.startServer(); | 
| 43 |             } catch (IOException e) { | |
| 44 |                 try { | |
| 45 |                     LOGGER.log(LogLevelUtil.CONSOLE_ERROR, "Socket connection failure: {}", e.getMessage()); | |
| 46 | 1
1. lambda$new$0 : removed call to com/jsql/view/swing/terminal/ServerInput::close → NO_COVERAGE |                     this.serverInput.close(); | 
| 47 |                 } catch (IOException ex) { | |
| 48 |                     LOGGER.log(LogLevelUtil.CONSOLE_ERROR, "Socket closing failure: {}", ex.getMessage()); | |
| 49 |                 } | |
| 50 |             } | |
| 51 | 1
1. <init> : removed call to java/lang/Thread::start → NO_COVERAGE |         }).start(); | 
| 52 |     } | |
| 53 | ||
| 54 |     @Override | |
| 55 |     public void action(String command, UUID terminalID, String urlShell, String... arg) { | |
| 56 | 1
1. action : removed call to com/jsql/view/swing/terminal/ServerInputConnection::setCommand → NO_COVERAGE |         this.serverInput.getServerInputConnection().setCommand(command); | 
| 57 |     } | |
| 58 | } | |
| Mutations | ||
| 42 | 1.1 | |
| 46 | 1.1 | |
| 51 | 1.1 | |
| 56 | 1.1 |