org.opencms.setup.xml.A_CmsXmlWorkplace Maven / Gradle / Ivy
/*
* This library is part of OpenCms -
* the Open Source Content Management System
*
* Copyright (c) Alkacon Software GmbH (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, 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.setup.xml;
import org.opencms.configuration.CmsConfigurationManager;
import org.opencms.configuration.CmsWorkplaceConfiguration;
import org.opencms.configuration.I_CmsXmlConfiguration;
import org.dom4j.Document;
/**
* Skeleton for handling opencms-workplace.xml.
*
* @since 6.1.8
*/
public abstract class A_CmsXmlWorkplace extends A_CmsSetupXmlUpdate {
/**
* @see org.opencms.setup.xml.I_CmsSetupXmlUpdate#getXmlFilename()
*/
public String getXmlFilename() {
return CmsWorkplaceConfiguration.DEFAULT_XML_FILE_NAME;
}
/**
* Creates a new 'explorertype/newresource' node.
*
* @param document the xml document to modify
* @param xpath the xpath to the existing explorer type (ie /opencms/workplace/explorertypes/explorertype[@name='${etype}']
)
* @param uri the uri attribute value
* @param order the order attribute value
* @param autoSetNav the autosetnavigation attribute value
* @param autoSetTitle the autosettitle attribute value
* @param info the info attribute value
* @param page the optional page attribute value
*/
protected void createEtNewResource(
Document document,
String xpath,
String uri,
int order,
boolean autoSetNav,
boolean autoSetTitle,
String info,
String page) {
String xp = xpath + "/" + CmsWorkplaceConfiguration.N_NEWRESOURCE;
if (page != null) {
CmsSetupXmlHelper.setValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_PAGE, page);
}
CmsSetupXmlHelper.setValue(document, xp + "/@" + I_CmsXmlConfiguration.A_URI, uri);
CmsSetupXmlHelper.setValue(document, xp + "/@" + I_CmsXmlConfiguration.A_ORDER, String.valueOf(order));
CmsSetupXmlHelper.setValue(
document,
xp + "/@" + CmsWorkplaceConfiguration.A_AUTOSETNAVIGATION,
String.valueOf(autoSetNav));
CmsSetupXmlHelper.setValue(
document,
xp + "/@" + CmsWorkplaceConfiguration.A_AUTOSETTITLE,
String.valueOf(autoSetTitle));
CmsSetupXmlHelper.setValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_INFO, info);
}
/**
* Creates a new 'explorertype' node.
*
* @param document the xml documento to modify
* @param xpath the xpath to the non-existing explorer type (ie /opencms/workplace/explorertypes/explorertype[@name='${etype}']
)
* @param name the name attribute value
* @param key the key attribute value
* @param icon the icon attribute value
* @param reference the reference attribute value
*/
protected void createExplorerType(
Document document,
String xpath,
String name,
String key,
String icon,
String reference) {
StringBuffer insertPoint = new StringBuffer(256);
insertPoint.append("/");
insertPoint.append(CmsConfigurationManager.N_ROOT);
insertPoint.append("/");
insertPoint.append(CmsWorkplaceConfiguration.N_WORKPLACE);
insertPoint.append("/");
insertPoint.append(CmsWorkplaceConfiguration.N_EXPLORERTYPES);
insertPoint.append("/");
insertPoint.append(CmsWorkplaceConfiguration.N_EXPLORERTYPE);
insertPoint.append("[last()]");
CmsSetupXmlHelper.setValue(document, insertPoint.toString(), null, xpath.substring(xpath.lastIndexOf('/') + 1));
CmsSetupXmlHelper.setValue(document, xpath + "/@" + I_CmsXmlConfiguration.A_KEY, key);
CmsSetupXmlHelper.setValue(document, xpath + "/@" + I_CmsXmlConfiguration.A_ICON, icon);
CmsSetupXmlHelper.setValue(document, xpath + "/@" + CmsWorkplaceConfiguration.A_REFERENCE, reference);
}
/**
* Creates a new access control entry node.
*
* @param document the xml document to change
* @param xpath the base xpath (ie /opencms/workplace/explorertypes/explorertype[@name='${etype}']/accesscontrol
)
* @param principal the principal
* @param permissions the permissions string
*
* @return if a modification has been needed
*/
protected boolean setAccessEntry(Document document, String xpath, String principal, String permissions) {
boolean ret = false;
String xp = xpath
+ "/"
+ CmsWorkplaceConfiguration.N_ACCESSENTRY
+ "[@"
+ CmsWorkplaceConfiguration.A_PRINCIPAL
+ "='"
+ principal
+ "']";
if (CmsSetupXmlHelper.getValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_PRINCIPAL) == null) {
ret = true;
}
CmsSetupXmlHelper.setValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_PRINCIPAL, principal);
if (!permissions.equals(CmsSetupXmlHelper.getValue(document, xp
+ "/@"
+ CmsWorkplaceConfiguration.A_PERMISSIONS))) {
CmsSetupXmlHelper.setValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_PERMISSIONS, permissions);
ret = true;
}
return ret;
}
/**
* Creates a new context menu entry node.
*
* @param document the xml document to change
* @param xpath the base xpath
* @param key the localization key name
* @param uri the entry uri
* @param rules the permissions rules
* @param order the relative order
*/
protected void setMenuEntry(Document document, String xpath, String key, String uri, String rules, String order) {
String xp = xpath
+ "/"
+ CmsWorkplaceConfiguration.N_ENTRY
+ "[@"
+ I_CmsXmlConfiguration.A_URI
+ "='"
+ uri
+ "']";
CmsSetupXmlHelper.setValue(document, xp + "/@" + I_CmsXmlConfiguration.A_URI, uri);
CmsSetupXmlHelper.setValue(document, xp + "/@" + I_CmsXmlConfiguration.A_KEY, key);
CmsSetupXmlHelper.setValue(document, xp + "/@" + CmsWorkplaceConfiguration.A_RULES, rules);
CmsSetupXmlHelper.setValue(document, xp + "/@" + I_CmsXmlConfiguration.A_ORDER, order);
}
}