org.opencms.workplace.help.CmsHelpSearchResultView Maven / Gradle / Ivy
Show all versions of opencms-test Show documentation
/*
* This library is part of OpenCms -
* the Open Source Content Management System
*
* Copyright (c) Alkacon Software GmbH & Co. KG (http://www.alkacon.com)
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* For further information about Alkacon Software GmbH & Co. KG, please see the
* company website: http://www.alkacon.com
*
* For further information about OpenCms, please see the
* project website: http://www.opencms.org
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
package org.opencms.workplace.help;
import org.opencms.file.CmsObject;
import org.opencms.file.CmsProject;
import org.opencms.i18n.CmsEncoder;
import org.opencms.i18n.CmsLocaleManager;
import org.opencms.i18n.CmsMessages;
import org.opencms.jsp.CmsJspActionElement;
import org.opencms.main.CmsException;
import org.opencms.search.CmsSearch;
import org.opencms.search.CmsSearchResult;
import org.opencms.search.fields.CmsSearchField;
import org.opencms.util.CmsStringUtil;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.SortedMap;
import java.util.StringTokenizer;
import java.util.TreeMap;
import javax.servlet.ServletRequest;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.jsp.PageContext;
/**
* Displays the result of a {@link org.opencms.search.CmsSearch}
.
*
* Requires the following request parameters (see constructor):
*
* -
* index:
the String identifying the required search index.
* -
* query:
the search query to run.
*
*
*
* @since 6.0.0
*/
public class CmsHelpSearchResultView {
/** The project that forces evaluation of all dynamic content. */
protected CmsProject m_offlineProject;
/** The project that allows static export. */
protected CmsProject m_onlineProject;
/** The flag that decides wethter links to search result point to their exported version or not. */
private boolean m_exportLinks;
/**
* A small cache for the forms generated by {@link #toPostParameters(String)}
during a request.
*
* Avoids duplicate forms.
*
*/
private SortedMap m_formCache;
/** The CmsJspActionElement to use. **/
private CmsJspActionElement m_jsp;
/** The url to a proprietary search url (different from m_jsp.getRequestContext().getUri). **/
private String m_searchRessourceUrl;
/**
* Constructor with the action element to use.
*
* @param action the action element to use
*/
public CmsHelpSearchResultView(CmsJspActionElement action) {
m_jsp = action;
m_formCache = new TreeMap();
try {
m_onlineProject = m_jsp.getCmsObject().readProject(CmsProject.ONLINE_PROJECT_ID);
m_offlineProject = m_jsp.getRequestContext().getCurrentProject();
} catch (CmsException e) {
// failed to get online project, at least avoid NPE
m_onlineProject = m_offlineProject;
}
}
/**
* Constructor with arguments for construction of a {@link CmsJspActionElement}
.
*
* @param pageContext the page context to use
* @param request the current request
* @param response the current response
*/
public CmsHelpSearchResultView(PageContext pageContext, HttpServletRequest request, HttpServletResponse response) {
this(new CmsJspActionElement(pageContext, request, response));
}
/**
* Returns the formatted search results.
*
* @param search the preconfigured search bean
* @return the formatted search results
*/
public String displaySearchResult(CmsSearch search) {
initSearch(search);
StringBuffer result = new StringBuffer(800);
CmsMessages messages = org.opencms.search.Messages.get().getBundle(m_jsp.getRequestContext().getLocale());
result.append("
\n");
result.append(messages.key(org.opencms.search.Messages.GUI_HELP_SEARCH_RESULT_TITLE_0));
result.append("\n
\n");
List searchResult;
if (CmsStringUtil.isEmptyOrWhitespaceOnly(search.getQuery())) {
search.setQuery("");
searchResult = new ArrayList();
} else {
searchResult = search.getSearchResult();
}
HttpServletRequest request = m_jsp.getRequest();
// get the action to perform from the request
String action = request.getParameter("action");
if ((action != null) && (searchResult == null)) {
result.append("\n");
if (search.getLastException() != null) {
result.append(messages.key(org.opencms.search.Messages.GUI_HELP_SEARCH_UNAVAILABLE_0));
result.append("\n\n");
} else {
result.append(
messages.key(
org.opencms.search.Messages.GUI_HELP_SEARCH_NOMATCH_1,
CmsEncoder.escapeXml(search.getQuery())));
result.append("\n");
}
result.append("
\n");
} else if ((action != null) && (searchResult.size() <= 0)) {
result.append("\n");
result.append(
messages.key(
org.opencms.search.Messages.GUI_HELP_SEARCH_NOMATCH_1,
CmsEncoder.escapeXml(search.getQuery())));
result.append("\n");
result.append("
\n");
} else if ((action != null) && (searchResult.size() > 0)) {
result.append("\n");
result.append(messages.key(org.opencms.search.Messages.GUI_HELP_SEARCH_RESULT_START_0));
result.append("\n");
result.append("
\n\n");
Iterator iterator = searchResult.iterator();
try {
if (m_exportLinks) {
m_jsp.getRequestContext().setCurrentProject(m_onlineProject);
}
while (iterator.hasNext()) {
CmsSearchResult entry = iterator.next();
result.append("\n\n");
result.append(entry.getField(CmsSearchField.FIELD_TITLE));
result.append("");
result.append(" (").append(entry.getScore()).append(" %)\n");
result.append("\n");
result.append(entry.getExcerpt()).append('\n');
result.append("\n");
result.append("\n");
}
} finally {
m_jsp.getRequestContext().setCurrentProject(m_offlineProject);
}
result.append("
\n");
// search page links below results
if ((search.getPreviousUrl() != null) || (search.getNextUrl() != null)) {
result.append("");
if (search.getPreviousUrl() != null) {
result.append("");
result.append(messages.key(org.opencms.search.Messages.GUI_HELP_BUTTON_BACK_0));
result.append(" << \n");
}
Map pageLinks = search.getPageLinks();
Iterator i = pageLinks.keySet().iterator();
while (i.hasNext()) {
int pageNumber = i.next().intValue();
result.append(" ");
if (pageNumber != search.getSearchPage()) {
result.append("").append(pageNumber).append("\n");
} else {
result.append(pageNumber);
}
}
if (search.getNextUrl() != null) {
result.append(" >>");
result.append(messages.key(org.opencms.search.Messages.GUI_HELP_BUTTON_NEXT_0));
result.append("\n");
}
result.append("
\n");
}
}
// include the post forms for the page links:
Iterator values = m_formCache.values().iterator();
while (values.hasNext()) {
result.append(values.next());
}
return result.toString();
}
/**
* Returns true if the links to search results shall point to exported content, false else.
* @return true if the links to search results shall point to exported content, false else
*/
public boolean isExportLinks() {
return m_exportLinks;
}
/**
* Set wether the links to search results point to exported content or not.
*
* @param exportLinks The value that decides Set wether the links to search results point to exported content or not.
*/
public void setExportLinks(boolean exportLinks) {
m_exportLinks = exportLinks;
}
/**
* Set a proprietary resource uri for the search page.
*
* This is optional but allows to override the standard search result links
* (for next or previous pages) that point to
* getJsp().getRequestContext().getUri()
whenever the search
* uri is element of some template and should not be linked directly.
*
* @param uri the proprietary resource uri for the search page
*/
public void setSearchRessourceUrl(String uri) {
m_searchRessourceUrl = uri;
}
/**
* Returns the resource uri to the search page with respect to the
* optionally configured value {@link #setSearchRessourceUrl(String)}
* with the request parameters of the given argument.
*
* This is a workaround for Tomcat bug 35775
* (http://issues.apache.org/bugzilla/show_bug.cgi?id=35775). After it has been
* fixed the version 1.1 should be restored (or at least this codepath should be switched back.
*
*
* @param link the suggestion of the search result bean ( a previous, next or page number url)
* @return the resource uri to the search page with respect to the
* optionally configured value {@link #setSearchRessourceUrl(String)}
* with the request parameters of the given argument
*/
private String getSearchPageLink(String link) {
if (m_searchRessourceUrl != null) {
// for the form to generate we need params.
String pageParams = "";
int paramIndex = link.indexOf('?');
if (paramIndex > 0) {
pageParams = link.substring(paramIndex);
}
String formurl = new StringBuffer(m_searchRessourceUrl).append(pageParams).toString();
toPostParameters(formurl);
link = new StringBuffer("javascript:document.forms['").append("form").append(m_formCache.size() - 1).append(
"'].submit()").toString();
}
return link;
}
/**
* Initialize the search for the help pages.
*
* @param search the search configuration (will be initialized)
*/
private void initSearch(CmsSearch search) {
// Collect the objects required to access the OpenCms VFS from the request
CmsObject cmsObject = m_jsp.getCmsObject();
ServletRequest request = m_jsp.getRequest();
search.init(cmsObject);
search.setField(
new String[] {
CmsSearchField.FIELD_TITLE,
CmsSearchField.FIELD_KEYWORDS,
CmsSearchField.FIELD_DESCRIPTION,
CmsSearchField.FIELD_CONTENT});
search.setMatchesPerPage(5);
search.setDisplayPages(7);
search.setSearchRoot(
new StringBuffer("/system/workplace/locales/").append(m_jsp.getRequestContext().getLocale()).append(
"/help/").toString());
String query = request.getParameter("query");
search.setQuery(query);
}
/**
* Generates a html form (named form<n>) with parameters found in
* the given GET request string (appended params with "?value=param&value2=param2).
* >n< is the number of forms that already have been generated.
* This is a content-expensive bugfix for http://issues.apache.org/bugzilla/show_bug.cgi?id=35775
* and should be replaced with the 1.1 revision as soon that bug is fixed.
*
* The forms action will point to the given uri's path info part: All links in the page
* that includes this generated html and that are related to the get request should
* have "src='#'" and "onclick=documents.forms['<getRequestUri>'].submit()".
*
* The generated form lands in the internal Map {@link #m_formCache}
as mapping
* from uris to Strings and has to be appended to the output at a valid position.
*
* Warning: Does not work with multiple values mapped to one parameter ("key = value1,value2..").
*
*
*
* @param getRequestUri a request uri with optional query, will be used as name of the form too.
*/
private void toPostParameters(String getRequestUri) {
StringBuffer result;
if (!m_formCache.containsKey(getRequestUri)) {
result = new StringBuffer();
int index = getRequestUri.indexOf('?');
String query = "";
String path = "";
if (index > 0) {
query = getRequestUri.substring(index + 1);
path = getRequestUri.substring(0, index);
result.append("\n
\n");
m_formCache.put(getRequestUri, result.toString());
}
}
}
}