org.opencms.workplace.CmsFrameset Maven / Gradle / Ivy
/*
* 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;
import org.opencms.configuration.CmsDefaultUserSettings;
import org.opencms.db.CmsUserSettings;
import org.opencms.file.CmsProject;
import org.opencms.file.CmsResourceFilter;
import org.opencms.i18n.CmsEncoder;
import org.opencms.jsp.CmsJspActionElement;
import org.opencms.main.CmsException;
import org.opencms.main.CmsLog;
import org.opencms.main.OpenCms;
import org.opencms.security.CmsOrganizationalUnit;
import org.opencms.site.CmsSite;
import org.opencms.synchronize.CmsSynchronizeSettings;
import org.opencms.util.CmsFileUtil;
import org.opencms.util.CmsRequestUtil;
import org.opencms.util.CmsStringUtil;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.Map.Entry;
import java.util.Set;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;
import org.apache.commons.logging.Log;
/**
* Provides methods for building the main framesets of the OpenCms Workplace.
*
* The following files use this class:
*
* - /views/top.html
*
- /views/top_foot.html
*
- /views/top_head.html
*
*
*
* @since 6.0.0
*/
public class CmsFrameset extends CmsWorkplace {
/** Path to the JSP workplace frame loader file. */
public static final String JSP_WORKPLACE_URI = CmsWorkplace.JSP_WORKPLACE_URI;
/** The request parameter for the selection of the frame. */
public static final String PARAM_WP_FRAME = "wpFrame";
/** The request parameter for the workplace start selection. */
public static final String PARAM_WP_START = "wpStart";
/** The request parameter for the workplace view selection. */
public static final String PARAM_WP_VIEW = "wpView";
/** The names of the supported frames. */
private static final String[] FRAMES = {"top", "head", "body", "foot"};
/** The names of the supported frames in a list. */
public static final List FRAMES_LIST = Collections.unmodifiableList(Arrays.asList(FRAMES));
/** The log object for this class. */
private static final Log LOG = CmsLog.getLog(CmsFrameset.class);
/** Indicates if a reload of the main body frame is required. */
private boolean m_reloadRequired;
/**
* Public constructor.
*
* @param jsp an initialized JSP action element
*/
public CmsFrameset(CmsJspActionElement jsp) {
super(jsp);
}
/**
* Performs additional filtering on the list of projects for the project selector.
*
* @param projects the original project list
*
* @return the filtered project list
*/
public List filterProjectsForSelector(List projects) {
List result = new ArrayList();
for (CmsProject project : projects) {
if (!project.isHiddenFromSelector()) {
result.add(project);
}
}
return result;
}
/**
* Returns the javascript code for the broadcast message alert in the foot of the workplace.
*
* @return javascript code showing an alert box when the foot load
*/
public String getBroadcastMessage() {
StringBuffer result = new StringBuffer(512);
String message = getBroadcastMessageString();
if (CmsStringUtil.isNotEmpty(message)) {
// create a javascript alert for the message
result.append("\n");
}
return result.toString();
}
/**
* Returns the remote ip address of the current user.
*
* @return the remote ip address of the current user
*/
public String getLoginAddress() {
return getCms().getRequestContext().getRemoteAddress();
}
/**
* Returns the last login time of the current user in localized format.
*
* @return the last login time of the current user in localized format
*/
public String getLoginTime() {
return getMessages().getDateTime(getSettings().getUser().getLastlogin());
}
/**
* Returns the html for the "preferences" button depending on the current users permissions and
* the default workplace settings.
*
* @return the html for the "preferences" button
*/
public String getPreferencesButton() {
int buttonStyle = getSettings().getUserSettings().getWorkplaceButtonStyle();
if (!getCms().getRequestContext().getCurrentUser().isManaged()) {
return button(
"../commons/preferences.jsp",
"body",
"preferences.png",
Messages.GUI_BUTTON_PREFERENCES_0,
buttonStyle);
} else {
return button(null, null, "preferences_in.png", Messages.GUI_BUTTON_PREFERENCES_0, buttonStyle);
}
}
/**
* Returns a html select box filled with the current users accessible projects.
*
* @param htmlAttributes attributes that will be inserted into the generated html
* @param htmlWidth additional style attributes containing width information
* @return a html select box filled with the current users accessible projects
*/
public String getProjectSelect(String htmlAttributes, String htmlWidth) {
// get all project information
List allProjects;
try {
String ouFqn = "";
CmsUserSettings settings = new CmsUserSettings(getCms());
if (!settings.getListAllProjects()) {
ouFqn = getCms().getRequestContext().getCurrentUser().getOuFqn();
}
allProjects = OpenCms.getOrgUnitManager().getAllAccessibleProjects(
getCms(),
ouFqn,
settings.getListAllProjects());
} catch (CmsException e) {
// should usually never happen
if (LOG.isErrorEnabled()) {
LOG.error(e.getLocalizedMessage(), e);
}
allProjects = Collections.emptyList();
}
allProjects = filterProjectsForSelector(allProjects);
boolean singleOu = true;
String ouFqn = null;
Iterator itProjects = allProjects.iterator();
while (itProjects.hasNext()) {
CmsProject prj = itProjects.next();
if (prj.isOnlineProject()) {
// skip the online project
continue;
}
if (ouFqn == null) {
// set the first ou
ouFqn = prj.getOuFqn();
}
if (!ouFqn.equals(prj.getOuFqn())) {
// break if one different ou is found
singleOu = false;
break;
}
}
List options = new ArrayList();
List values = new ArrayList();
int selectedIndex = -1;
int ouDefaultProjIndex = -1;
CmsOrganizationalUnit ou = null;
try {
ou = OpenCms.getOrgUnitManager().readOrganizationalUnit(getCms(), getCms().getRequestContext().getOuFqn());
} catch (CmsException e) {
// should never happen, ignore
}
// now loop through all projects and fill the result vectors
for (int i = 0, n = allProjects.size(); i < n; i++) {
CmsProject project = allProjects.get(i);
String projectId = project.getUuid().toString();
String projectName = project.getSimpleName();
if (!singleOu && !project.isOnlineProject()) {
try {
projectName = projectName
+ " - "
+ OpenCms.getOrgUnitManager().readOrganizationalUnit(
getCms(),
project.getOuFqn()).getDisplayName(getLocale());
} catch (CmsException e) {
projectName = projectName + " - " + project.getOuFqn();
}
}
values.add(projectId);
options.add(projectName);
if (project.getUuid().equals(getSettings().getProject())) {
// this is the user's current project
selectedIndex = i;
}
if ((ou != null) && project.getUuid().equals(ou.getProjectId())) {
ouDefaultProjIndex = i;
}
}
if (selectedIndex == -1) {
if (ouDefaultProjIndex == -1) {
selectedIndex = 0;
} else {
selectedIndex = ouDefaultProjIndex;
}
}
if (CmsStringUtil.isNotEmpty(htmlWidth)) {
StringBuffer buf = new StringBuffer(htmlAttributes.length() + htmlWidth.length() + 2);
buf.append(htmlAttributes);
buf.append(" ");
buf.append(htmlWidth);
htmlAttributes = buf.toString();
}
return buildSelect(htmlAttributes, options, values, selectedIndex);
}
/**
* Returns the html for the "publish project" button depending on the current users permissions and the default
* workplace settings.
*
* @return the html for the "publish project" button
*/
public String getPublishButton() {
String publishButton = OpenCms.getWorkplaceManager().getDefaultUserSettings().getPublishButtonAppearance();
if (CmsDefaultUserSettings.PUBLISHBUTTON_SHOW_NEVER.equals(publishButton)) {
return "";
}
int buttonStyle = getSettings().getUserSettings().getWorkplaceButtonStyle();
if (CmsDefaultUserSettings.PUBLISHBUTTON_SHOW_AUTO.equals(publishButton)) {
if (getCms().isManagerOfProject()) {
return button(
"../../workplace/commons/publish_project.jsp",
"body",
"publish.png",
Messages.GUI_BUTTON_PUBLISH_0,
buttonStyle);
} else {
return "";
}
}
if (getCms().isManagerOfProject()) {
return (button(
"../../workplace/commons/publish_project.jsp",
"body",
"publish.png",
Messages.GUI_BUTTON_PUBLISH_0,
buttonStyle));
} else {
return (button(null, null, "publish_in.png", Messages.GUI_BUTTON_PUBLISH_0, buttonStyle));
}
}
/**
* Returns the html for the "publish queue" button.
*
* @return the html for the "publish queue" button
*/
public String getPublishQueueButton() {
int buttonStyle = getSettings().getUserSettings().getWorkplaceButtonStyle();
StringBuffer js = new StringBuffer(128);
js.append("javascript:if (parent.body.admin_content && parent.body.admin_menu) {");
js.append("parent.body.location.href = '");
js.append(getJsp().link("/system/workplace/views/admin/admin-fs.jsp?root=admin&path=/publishqueue"));
js.append("';");
js.append("} else {");
js.append("parent.body.explorer_body.explorer_files.location.href = '");
js.append(getJsp().link("/system/workplace/views/admin/admin-fs.jsp?root=explorer&path=/publishqueue&menu=no"));
js.append("';");
js.append("};");
return button(js.toString(), null, "publish_queue.png", Messages.GUI_BUTTON_PUBLISHQUEUE_0, buttonStyle);
}
/**
* Returns a html select box filled with the current users accessible sites.
*
* @param htmlAttributes attributes that will be inserted into the generated html
* @return a html select box filled with the current users accessible sites
*/
public String getSiteSelect(String htmlAttributes) {
List options = new ArrayList();
List values = new ArrayList();
int selectedIndex = 0;
List sites = OpenCms.getSiteManager().getAvailableSites(getCms(), true);
Iterator i = sites.iterator();
int pos = 0;
while (i.hasNext()) {
CmsSite site = i.next();
values.add(site.getSiteRoot());
options.add(substituteSiteTitle(site.getTitle()));
String siteRoot = CmsFileUtil.addTrailingSeparator(site.getSiteRoot());
String settingsSiteRoot = getSettings().getSite();
if (settingsSiteRoot != null) {
settingsSiteRoot = CmsFileUtil.addTrailingSeparator(settingsSiteRoot);
}
if (siteRoot.equals(settingsSiteRoot)) {
// this is the user's current site
selectedIndex = pos;
}
pos++;
}
return buildSelect(htmlAttributes, options, values, selectedIndex);
}
/**
* Returns the startup URI for display in the main body frame, this can
* either be the user default view, or (if set) a specific startup resource.
*
* @return the startup URI for display in the main body frame
*/
public String getStartupUri() {
String result = getSettings().getViewStartup();
if (result == null) {
// no specific startup URI is set, use view from user settings
result = getSettings().getViewUri();
} else {
// reset the startup URI, so that it is not displayed again on reload of the frameset
getSettings().setViewStartup(null);
}
// add eventual request parameters to startup uri
if (getJsp().getRequest().getParameterMap().size() > 0) {
@SuppressWarnings("unchecked")
Set> params = getJsp().getRequest().getParameterMap().entrySet();
Iterator> i = params.iterator();
while (i.hasNext()) {
Entry, ?> entry = i.next();
result = CmsRequestUtil.appendParameter(
result,
(String)entry.getKey(),
((String[])entry.getValue())[0]);
}
}
// append the frame name to the startup uri
return CmsRequestUtil.appendParameter(result, CmsFrameset.PARAM_WP_FRAME, FRAMES[2]);
}
/**
* Returns a html select box filled with the views accessible by the current user.
*
* @param htmlAttributes attributes that will be inserted into the generated html
* @return a html select box filled with the views accessible by the current user
*/
public String getViewSelect(String htmlAttributes) {
List options = new ArrayList();
List values = new ArrayList();
int selectedIndex = 0;
// loop through the vectors and fill the result vectors
Iterator i = OpenCms.getWorkplaceManager().getViews().iterator();
int count = -1;
String currentView = getSettings().getViewUri();
if (CmsStringUtil.isNotEmpty(currentView)) {
// remove possible parameters from current view
int pos = currentView.indexOf('?');
if (pos >= 0) {
currentView = currentView.substring(0, pos);
}
}
while (i.hasNext()) {
CmsWorkplaceView view = i.next();
if (getCms().existsResource(view.getUri(), CmsResourceFilter.ONLY_VISIBLE_NO_DELETED)) {
count++;
// ensure the current user has +v+r permissions on the view
String loopLink = getJsp().link(view.getUri());
String localizedKey = resolveMacros(view.getKey());
options.add(localizedKey);
values.add(loopLink);
if (loopLink.equals(currentView)) {
selectedIndex = count;
}
}
}
return buildSelect(htmlAttributes, options, values, selectedIndex);
}
/**
* Returns the reload URI for the OpenCms workplace.
*
* @return the reload URI for the OpenCms workplace
*/
public String getWorkplaceReloadUri() {
return getJsp().link(CmsFrameset.JSP_WORKPLACE_URI);
}
/**
* Returns true
if a reload of the main body frame is required.
*
* This value is modified with the select options (project, site or view) in the head frame of
* the Workplace. If a user changes one of these select values, the head frame is posted
* "against itself". The posted values will be processed by this class, causing
* the internal Workplace settings to change. After these settings have been changed,
* a reload of the main body frame is required in order to update it with the new values.
* A JavaScript in the Workplace head frame will be executed in this case.
*
* @return true
if a reload of the main body frame is required
*/
public boolean isReloadRequired() {
return m_reloadRequired;
}
/**
* Returns true if the user has enabled synchronization.
*
* @return true if the user has enabled synchronization
*/
public boolean isSyncEnabled() {
CmsSynchronizeSettings syncSettings = getSettings().getUserSettings().getSynchronizeSettings();
return (syncSettings != null) && syncSettings.isSyncEnabled();
}
/**
* Indicates if the site selector should be shown in the top frame depending on the count of accessible sites.
*
* @return true if site selector should be shown, otherwise false
*/
public boolean showSiteSelector() {
if (getSettings().getUserSettings().getRestrictExplorerView()) {
// restricted explorer view to site and folder, do not show site selector
return false;
}
// count available sites
int siteCount = OpenCms.getSiteManager().getAvailableSites(getCms(), true).size();
return (siteCount > 1);
}
/**
* @see org.opencms.workplace.CmsWorkplace#initTimeWarp(org.opencms.db.CmsUserSettings, javax.servlet.http.HttpSession)
*/
@Override
protected void initTimeWarp(CmsUserSettings settings, HttpSession session) {
// overriden to avoid deletion of the configured time warp:
// this is triggered by editors and in auto time warping a direct edit
// must not delete a potential auto warped request time
}
/**
* @see org.opencms.workplace.CmsWorkplace#initWorkplaceRequestValues(org.opencms.workplace.CmsWorkplaceSettings, javax.servlet.http.HttpServletRequest)
*/
@Override
protected void initWorkplaceRequestValues(CmsWorkplaceSettings settings, HttpServletRequest request) {
// check if a startup page has been set
String frame = CmsRequestUtil.getNotEmptyDecodedParameter(request, CmsFrameset.PARAM_WP_FRAME);
if ((frame == null) || (FRAMES_LIST.indexOf(frame) < 0)) {
// illegal or no frame selected, assume the "top" frame
frame = FRAMES[0];
}
if (FRAMES[0].equals(frame)) {
// top frame requested - execute special reload actions
topFrameReload(settings);
}
// check if a startup page has been set
String startup = CmsRequestUtil.getNotEmptyDecodedParameter(request, CmsFrameset.PARAM_WP_START);
if (startup != null) {
m_reloadRequired = true;
settings.setViewStartup(startup);
}
// check if the user requested a view change
String view = request.getParameter(CmsFrameset.PARAM_WP_VIEW);
if (view != null) {
m_reloadRequired = true;
settings.setViewUri(view);
settings.getFrameUris().put("body", view);
}
m_reloadRequired = initSettings(settings, request) || m_reloadRequired;
}
/**
* Performs certain clear cache actions if the top frame is reloaded.
*
* @param settings the current users workplace settings
*/
protected void topFrameReload(CmsWorkplaceSettings settings) {
// ensure to read the settings from the database
initUserSettings(getCms(), settings, true);
// reset the HTML list in order to force a full reload
settings.setListObject(null);
}
}