All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.opencms.xml.CmsXmlMessages Maven / Gradle / Ivy

Go to download

OpenCms is an enterprise-ready, easy to use website content management system based on Java and XML technology. Offering a complete set of features, OpenCms helps content managers worldwide to create and maintain beautiful websites fast and efficiently.

The newest version!
/*
 * 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.xml;

import org.opencms.cache.CmsVfsMemoryObjectCache;
import org.opencms.file.CmsFile;
import org.opencms.file.CmsObject;
import org.opencms.i18n.CmsMessages;
import org.opencms.main.CmsException;
import org.opencms.main.CmsLog;
import org.opencms.main.OpenCms;
import org.opencms.util.CmsMacroResolver;
import org.opencms.util.CmsStringUtil;
import org.opencms.xml.content.CmsXmlContent;
import org.opencms.xml.content.CmsXmlContentFactory;

import java.util.Locale;

import org.apache.commons.logging.Log;

/**
 * The xml messages overwrite some methods of the general CmsMessages class to get keys from an individual configuration file.

* * As fallback if no file was specified or no value was found for the desired key, * a common CmsMessages object is used to get the localized value.

* * @since 6.5.4 */ public class CmsXmlMessages extends CmsMessages { /** The log object for this class. */ private static final Log LOG = CmsLog.getLog(CmsXmlMessages.class); /** The locale to use for getting localized String values. */ private Locale m_locale; /** The content holding the localized values. */ private CmsXmlContent m_localizationContent; /** The initialized messages used as fallback if no value was found in the configuration file. */ private CmsMessages m_messages; /** The (optional) xPath prefix to the element nodes. */ private String m_pathPrefix; /** * Constructor, with parameters.

* * Creates the necessary member objects using the passed arguments.

* * @param messages the messages object to use as fallback * @param configurationFileName the absolute path (including site root!) to the configuration file containing localized keys * @param pathPrefix the (optional) xPath prefix to the element nodes * @param locale the locale to use for localization */ public CmsXmlMessages(CmsMessages messages, String configurationFileName, String pathPrefix, Locale locale) { m_messages = messages; initLocalizationContent(configurationFileName); initPathPrefix(pathPrefix); m_locale = locale; } /** * Constructor, with parameters.

* * Creates the necessary member objects using the passed arguments.

* * @param bundleName the name of the ResourceBundle to use * @param configurationFileName the absolute path (including site root!) to the configuration file containing localized keys * @param pathPrefix the (optional) xPath prefix to the element nodes * @param locale the locale to use for localization */ public CmsXmlMessages(String bundleName, String configurationFileName, String pathPrefix, Locale locale) { m_messages = new CmsMessages(bundleName, locale); initLocalizationContent(configurationFileName); initPathPrefix(pathPrefix); m_locale = locale; } /** * Returns the messages.

* * @return the messages */ public CmsMessages getMessages() { return m_messages; } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#key(java.lang.String) */ @Override public String key(String keyName) { if (hasConfigValue(keyName)) { return getConfigValue(keyName); } return m_messages.key(keyName); } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#key(java.lang.String, java.lang.Object) */ @Override public String key(String key, Object arg0) { if (hasConfigValue(key)) { return getConfigValue(key, new Object[] {arg0}); } return m_messages.key(key, arg0); } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#key(java.lang.String, java.lang.Object, java.lang.Object) */ @Override public String key(String key, Object arg0, Object arg1) { if (hasConfigValue(key)) { return getConfigValue(key, new Object[] {arg0, arg1}); } return m_messages.key(key, arg0, arg1); } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#key(java.lang.String, java.lang.Object, java.lang.Object, java.lang.Object) */ @Override public String key(String key, Object arg0, Object arg1, Object arg2) { if (hasConfigValue(key)) { return getConfigValue(key, new Object[] {arg0, arg1, arg2}); } return m_messages.key(key, arg0, arg1, arg2); } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#key(java.lang.String, java.lang.Object[]) */ @Override public String key(String key, Object[] args) { if (hasConfigValue(key)) { return getConfigValue(key, args); } return m_messages.key(key, args); } /** * Returns the localized resource String from the configuration file, if not found or set from the resource bundle.

* * @see org.opencms.i18n.CmsMessages#keyDefault(java.lang.String, java.lang.String) */ @Override public String keyDefault(String keyName, String defaultValue) { if (hasConfigValue(keyName)) { return getConfigValue(keyName); } return m_messages.keyDefault(keyName, defaultValue); } /** * Sets the messages.

* * @param messages the messages */ public void setMessages(CmsMessages messages) { m_messages = messages; } /** * Returns the value for the given key from the configuration file.

* @param key the key to get the value for * @return the value for the given key */ protected String getConfigValue(String key) { if (m_localizationContent != null) { try { return m_localizationContent.getStringValue(null, m_pathPrefix + key, m_locale); } catch (NullPointerException e) { // a cms object is needed, log this error if (LOG.isErrorEnabled()) { LOG.error(Messages.get().getBundle().key(Messages.ERR_NULL_CMSOBJECT_0)); } } } return null; } /** * Returns the substituted value for the given key and arguments from the configuration file.

* * @param key the key to get the value for * @param args the arguments that should be substituted * @return the substituted value for the given key and arguments */ protected String getConfigValue(String key, Object[] args) { String value = getConfigValue(key); CmsMacroResolver resolver = CmsMacroResolver.newInstance(); for (int i = 0; i < args.length; i++) { resolver.addMacro(String.valueOf(i), args[i].toString()); } return resolver.resolveMacros(value); } /** * Checks if the given key is provided in the configuration file.

* * @param key the key to check * @return true if the given key is provided in the configuration file, otherwise false */ protected boolean hasConfigValue(String key) { return CmsStringUtil.isNotEmptyOrWhitespaceOnly(getConfigValue(key)); } /** * Initializes the content used for localizing the output.

* * @param configurationFileName the absolute path including site root to the configuration file containing localized keys */ protected void initLocalizationContent(String configurationFileName) { CmsObject cms = null; try { // this will always be in the root site cms = OpenCms.initCmsObject(OpenCms.getDefaultUsers().getUserGuest()); } catch (CmsException e) { // error initializing cms object, log error if (LOG.isErrorEnabled()) { LOG.error( Messages.get().getBundle().key( Messages.ERR_INVALID_INIT_USER_1, OpenCms.getDefaultUsers().getUserGuest())); } } if ((cms != null) && CmsStringUtil.isNotEmptyOrWhitespaceOnly(configurationFileName)) { // try to get XML content from cache Object o = CmsVfsMemoryObjectCache.getVfsMemoryObjectCache().getCachedObject(cms, configurationFileName); if (o != null) { // found the cached XML content, use it m_localizationContent = (CmsXmlContent)o; return; } try { CmsFile configFile = cms.readFile(configurationFileName); m_localizationContent = CmsXmlContentFactory.unmarshal(cms, configFile); // store unmarshaled content in cache CmsVfsMemoryObjectCache.getVfsMemoryObjectCache().putCachedObject( cms, configurationFileName, m_localizationContent); } catch (CmsException e) { // ignore, no configuration file found } } } /** * Initializes the (optional) xPath prefix to the element nodes.

* * @param pathPrefix the (optional) xPath prefix to the element nodes */ protected void initPathPrefix(String pathPrefix) { if (CmsStringUtil.isNotEmptyOrWhitespaceOnly(pathPrefix)) { m_pathPrefix = pathPrefix; } else { m_pathPrefix = ""; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy