/* * Zed Attack Proxy (ZAP) and its related class files. * * ZAP is an HTTP/HTTPS proxy for assessing web application security. * * 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.httppanel.view.paramtable; import java.util.Iterator; import java.util.TreeSet; import javax.swing.JComboBox; import org.parosproxy.paros.Constant; import org.parosproxy.paros.extension.ExtensionAdaptor; import org.parosproxy.paros.extension.ExtensionHook; import org.parosproxy.paros.network.HtmlParameter; import org.zaproxy.zap.extension.httppanel.component.split.request.RequestSplitComponent; import org.zaproxy.zap.extension.httppanel.view.DefaultHttpPanelViewModel; import org.zaproxy.zap.extension.httppanel.view.HttpPanelView; import org.zaproxy.zap.extension.httppanel.view.HttpPanelViewModel; import org.zaproxy.zap.view.HttpPanelManager; import org.zaproxy.zap.view.HttpPanelManager.HttpPanelViewFactory; public class ExtensionHttpPanelRequestQueryCookieTableView extends ExtensionAdaptor { public static final String NAME = "ExtensionHttpPanelRequestQueryCookieTableView"; public ExtensionHttpPanelRequestQueryCookieTableView() { super(NAME); } @Override public void hook(ExtensionHook extensionHook) { super.hook(extensionHook); if (getView() != null) { HttpPanelManager.getInstance().addRequestViewFactory(RequestSplitComponent.NAME, new HttpPanelQueryCookieParamTableViewFactory()); } } @Override public boolean canUnload() { // Do not allow the unload until moved to an add-on. return false; } @Override public void unload() { if (getView() != null) { HttpPanelManager panelManager = HttpPanelManager.getInstance(); panelManager.removeRequestViewFactory(RequestSplitComponent.NAME, HttpPanelQueryCookieParamTableViewFactory.NAME); panelManager.removeRequestViews(RequestSplitComponent.NAME, HttpPanelQueryCookieParamTableView.NAME, RequestSplitComponent.ViewComponent.HEADER); } } private static final class HttpPanelQueryCookieParamTableViewFactory implements HttpPanelViewFactory { public static final String NAME = "HttpPanelQueryCookieParamTableViewFactory"; @Override public String getName() { return NAME; } @Override public HttpPanelView getNewView() { return new HttpPanelQueryCookieParamTableView(new DefaultHttpPanelViewModel(), new HttpPanelQueryCookieParamTableModel()); } @Override public Object getOptions() { return RequestSplitComponent.ViewComponent.HEADER; } } private static class HttpPanelQueryCookieParamTableView extends HttpPanelParamTableView { public HttpPanelQueryCookieParamTableView(HttpPanelViewModel model, HttpPanelParamTableModel tableModel) { super(model, tableModel); } @Override public String getTargetViewName() { return ""; } @Override public JComboBox<HtmlParameter.Type> getComboBoxTypes() { JComboBox<HtmlParameter.Type> comboBoxTypes = new JComboBox<>(); comboBoxTypes.addItem(HtmlParameter.Type.url); comboBoxTypes.addItem(HtmlParameter.Type.cookie); return comboBoxTypes; } } private static class HttpPanelQueryCookieParamTableModel extends HttpPanelParamTableModel { private static final long serialVersionUID = 869819957109403800L; @Override protected void loadAllParams() { allParams.addAll(httpMessage.getUrlParams()); allParams.addAll(httpMessage.getRequestHeader().getCookieParams()); } @Override public void saveAllParams() { TreeSet<HtmlParameter> get = new TreeSet<>(); TreeSet<HtmlParameter> cookies = new TreeSet<>(); Iterator<HtmlParameter> it = allParams.iterator(); while (it.hasNext()) { HtmlParameter htmlParameter = it.next(); if(!htmlParameter.getName().isEmpty()) { switch (htmlParameter.getType()) { case url: get.add(htmlParameter); break; case cookie: cookies.add(htmlParameter); break; case form: break; default: break; } } } httpMessage.setGetParams(get); httpMessage.setCookieParams(cookies); } @Override protected HtmlParameter getDefaultHtmlParameter() { return new HtmlParameter(HtmlParameter.Type.url, "", ""); } } @Override public String getAuthor() { return Constant.ZAP_TEAM; } /** * No database tables used, so all supported */ @Override public boolean supportsDb(String type) { return true; } }