org.zaproxy.zap.extension.invoke.InvokeAppWorker.java Source code

Java tutorial

Introduction

Here is the source code for org.zaproxy.zap.extension.invoke.InvokeAppWorker.java

Source

/*
 * Zed Attack Proxy (ZAP) and its related class files.
 *
 * ZAP is an HTTP/HTTPS proxy for assessing web application security.
 *
 * Copyright 2010 The ZAP Development Team
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.zaproxy.zap.extension.invoke;

import java.io.BufferedReader;
import java.io.File;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
import java.util.Vector;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import javax.swing.SwingWorker;
import org.apache.commons.httpclient.URI;
import org.apache.log4j.Logger;
import org.parosproxy.paros.Constant;
import org.parosproxy.paros.model.HistoryReference;
import org.parosproxy.paros.network.HttpHeader;
import org.parosproxy.paros.network.HttpMessage;
import org.parosproxy.paros.view.View;

public class InvokeAppWorker extends SwingWorker<Void, Void> {

    private String command = null;
    private File workingDir = null;
    private String parameters = null;
    private boolean captureOutput = true;
    private boolean outputNote = false;
    private HttpMessage msg = null;

    private Logger logger = Logger.getLogger(InvokeAppWorker.class);

    public InvokeAppWorker(String command, File workingDir, String parameters, boolean captureOutput,
            boolean outputNote, HttpMessage msg) {
        this.command = command;
        this.workingDir = workingDir;
        this.parameters = parameters;
        this.captureOutput = captureOutput;
        this.outputNote = outputNote;
        this.msg = msg;
    }

    @Override
    protected Void doInBackground() throws Exception {

        String url = ""; // Full URL
        String host = ""; // Just the server name, e.g. localhost
        String port = ""; // the port
        String site = ""; // e.g. http://localhost:8080/
        String postdata = ""; // only present in POST ops
        String cookie = ""; // from the request header
        HistoryReference historyRef = msg.getHistoryRef();
        int msgid = -1;

        if (historyRef != null) {
            msgid = historyRef.getHistoryId();
        }

        URI uri = msg.getRequestHeader().getURI();
        url = uri.toString();
        host = uri.getHost();
        site = uri.getScheme() + "://" + uri.getHost();
        if (uri.getPort() > 0) {
            port = String.valueOf(uri.getPort());
            site = site + ":" + port + "/";
        } else {
            if (uri.getScheme().equalsIgnoreCase("http")) {
                port = "80";
            } else if (uri.getScheme().equalsIgnoreCase("https")) {
                port = "443";
            }
            site = site + "/";
        }
        if (msg.getRequestBody() != null) {
            postdata = msg.getRequestBody().toString();
            postdata = postdata.replaceAll("\n", "\\n");
        }
        Vector<String> cookies = msg.getRequestHeader().getHeaders(HttpHeader.COOKIE);
        if (cookies != null && cookies.size() > 0) {
            cookie = cookies.get(0);
        }

        List<String> cmd = new ArrayList<>();
        cmd.add(command);
        if (parameters != null) {
            for (String parameter : parameters.split(" ")) {
                // Replace all of the tags
                String finalParameter = parameter.replace("%url%", url).replace("%host%", host)
                        .replace("%port%", port).replace("%site%", site).replace("%cookie%", cookie)
                        .replace("%postdata%", postdata).replace("%msgid%", String.valueOf(msgid));

                // Replace header tags
                Matcher headers = Pattern.compile("%header-([A-z0-9_-]+)%").matcher(finalParameter);
                while (headers.find()) {
                    String headerValue = msg.getRequestHeader().getHeader(headers.group(1));
                    if (headerValue == null) {
                        headerValue = "";
                    }
                    finalParameter = finalParameter.replace(headers.group(0), headerValue);
                }

                cmd.add(finalParameter);
            }
        }

        logger.debug("Invoking: " + cmd.toString());
        View.getSingleton().getOutputPanel().append("\n" + cmd.toString() + "\n");
        ProcessBuilder pb = new ProcessBuilder(cmd);
        if (workingDir != null) {
            pb.directory(workingDir);
        }
        pb.redirectErrorStream(true);
        Process proc;
        try {
            proc = pb.start();
        } catch (final Exception e) {
            View.getSingleton().getOutputPanel()
                    .append(Constant.messages.getString("invoke.error") + e.getLocalizedMessage() + "\n");
            logger.warn("Failed to start the process: " + e.getMessage(), e);
            return null;
        }

        if (captureOutput) {
            try (BufferedReader brOut = new BufferedReader(new InputStreamReader(proc.getInputStream()))) {
                String line;
                boolean isOutput = false;
                StringBuilder sb = new StringBuilder();
                if (msg.getNote() != null) {
                    sb.append(msg.getNote());
                    sb.append('\n');
                }

                // Show any stdout/error messages
                while ((line = brOut.readLine()) != null) {
                    View.getSingleton().getOutputPanel().append(line + "\n");
                    sb.append(line);
                    sb.append('\n');
                    isOutput = true;
                }
                if (isOutput) {
                    // Somethings been written, switch to the Output tab
                    View.getSingleton().getOutputPanel().setTabFocus();
                }

                if (outputNote) {
                    HistoryReference hr = msg.getHistoryRef();
                    if (hr != null) {
                        hr.setNote(sb.toString());
                    }
                }
            }
        }

        return null;
    }
}