org.opencms.setup.xml.v8.CmsXmlAddWidgets 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.v8;
import org.opencms.configuration.CmsConfigurationManager;
import org.opencms.configuration.CmsVfsConfiguration;
import org.opencms.configuration.I_CmsXmlConfiguration;
import org.opencms.setup.CmsSetupBean;
import org.opencms.setup.xml.A_CmsXmlVfs;
import org.opencms.setup.xml.CmsSetupXmlHelper;
import org.opencms.util.CmsStringUtil;
import java.util.ArrayList;
import java.util.List;
import org.dom4j.Document;
/**
* Updates the widget configuration.
*
*
* @since 8.0.0
*/
public class CmsXmlAddWidgets extends A_CmsXmlVfs {
/** List of xpaths to update. */
private List m_xpaths;
/**
* The new widget definition data.
*/
private String[][] m_widgets = {
{"org.opencms.widgets.CmsAdeDownloadGalleryWidget", "DownloadGalleryWidget"},
{"org.opencms.widgets.CmsAdeImageGalleryWidget", "ImageGalleryWidget"},
{"org.opencms.widgets.CmsDownloadGalleryWidget", "LegacyDownloadGalleryWidget"},
{"org.opencms.widgets.CmsImageGalleryWidget", "LegacyImageGalleryWidget"},
{"org.opencms.widgets.CmsSelectGroupWidget", "GroupSelectorWidget"}};
/**
* @see org.opencms.setup.xml.I_CmsSetupXmlUpdate#getName()
*/
public String getName() {
return "Add new widget definitions for ADE galleries";
}
/**
* @see org.opencms.setup.xml.I_CmsSetupXmlUpdate#validate(org.opencms.setup.CmsSetupBean)
*/
@Override
public boolean validate(CmsSetupBean setupBean) throws Exception {
return CmsStringUtil.isNotEmptyOrWhitespaceOnly(getCodeToChange(setupBean));
}
/**
* @see org.opencms.setup.xml.A_CmsSetupXmlUpdate#executeUpdate(org.dom4j.Document, java.lang.String, boolean)
*/
@Override
protected boolean executeUpdate(Document document, String xpath, boolean forReal) {
for (int i = 0; i < m_widgets.length; i++) {
if (xpath.equals(getXPathsToUpdate().get(i))) {
CmsSetupXmlHelper.setValue(document, xpathForWidgetClassAttribute(m_widgets[i][1]), m_widgets[i][0]);
return true;
}
}
return false;
}
/**
* @see org.opencms.setup.xml.A_CmsSetupXmlUpdate#getCommonPath()
*/
@Override
protected String getCommonPath() {
return xpathForWidgets();
}
/**
* @see org.opencms.setup.xml.A_CmsSetupXmlUpdate#getXPathsToUpdate()
*/
@Override
protected List getXPathsToUpdate() {
if (m_xpaths == null) {
m_xpaths = new ArrayList();
for (int i = 0; i < m_widgets.length; i++) {
m_xpaths.add(xpathForWidgetByAlias(m_widgets[i][1]));
}
}
return m_xpaths;
}
/**
* Returns the xpath for a widget with a given alias.
*
* @param alias the widget alias
*
* @return the xpath for the widget with the given alias
*/
protected String xpathForWidgetByAlias(String alias) {
return xpathForWidgets()
+ "/"
+ CmsVfsConfiguration.N_WIDGET
+ "[@"
+ I_CmsXmlConfiguration.A_ALIAS
+ "='"
+ alias
+ "']";
}
/**
* Returns the xpath of the class attribute for a widget with a given alias.
*
* @param alias the widget alias
*
* @return the xpath of the widget's class attribute
*/
protected String xpathForWidgetClassAttribute(String alias) {
return xpathForWidgetByAlias(alias) + "/@" + I_CmsXmlConfiguration.A_CLASS;
}
/**
* Returns the xpath for the widgets node.
*
* @return the xpath for the widgets node
*/
protected String xpathForWidgets() {
return "/"
+ CmsConfigurationManager.N_ROOT
+ "/"
+ CmsVfsConfiguration.N_VFS
+ "/"
+ CmsVfsConfiguration.N_XMLCONTENT
+ "/"
+ CmsVfsConfiguration.N_WIDGETS;
}
}