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 |