📄 cmsmodulexmlhandler.java
字号:
for (int i = 0; i < module.getExportPoints().size(); i++) {
CmsExportPoint point = (CmsExportPoint)module.getExportPoints().get(i);
exportpointsElement.addElement(I_CmsXmlConfiguration.N_EXPORTPOINT).addAttribute(
I_CmsXmlConfiguration.A_URI,
point.getUri()).addAttribute(I_CmsXmlConfiguration.A_DESTINATION, point.getConfiguredDestination());
}
Element resourcesElement = moduleElement.addElement(N_RESOURCES);
for (int i = 0; i < module.getResources().size(); i++) {
String resource = (String)module.getResources().get(i);
resourcesElement.addElement(I_CmsXmlConfiguration.N_RESOURCE).addAttribute(
I_CmsXmlConfiguration.A_URI,
resource);
}
Element parametersElement = moduleElement.addElement(N_PARAMETERS);
SortedMap parameters = module.getParameters();
if (parameters != null) {
List parameterList = new ArrayList(parameters.keySet());
Collections.sort(parameterList);
Iterator it = parameterList.iterator();
while (it.hasNext()) {
String name = (String)it.next();
String value = parameters.get(name).toString();
Element paramNode = parametersElement.addElement(I_CmsXmlConfiguration.N_PARAM);
paramNode.addAttribute(I_CmsXmlConfiguration.A_NAME, name);
paramNode.addText(value);
}
}
// add resource types
List resourceTypes = module.getResourceTypes();
if (resourceTypes.size() > 0) {
Element resourcetypesElement = moduleElement.addElement(CmsVfsConfiguration.N_RESOURCETYPES);
CmsVfsConfiguration.generateResourceTypeXml(resourcetypesElement, resourceTypes, true);
}
List explorerTypes = module.getExplorerTypes();
if (explorerTypes.size() > 0) {
Element explorerTypesElement = moduleElement.addElement(CmsWorkplaceConfiguration.N_EXPLORERTYPES);
CmsWorkplaceConfiguration.generateExplorerTypesXml(explorerTypesElement, explorerTypes, true);
}
// return the modules node
moduleElement.detach();
return moduleElement;
}
/**
* Generates a (hopefully) valid Java class name from an invalid class name.<p>
*
* All invalid characters are replaced by an underscore "_".
* This is for example used to make sure old (5.0) modules can still be imported,
* by converting the name to a valid class name.<p>
*
* @param className the class name to make valid
* @return a valid Java class name from an invalid class name
*/
public static String makeValidJavaClassName(String className) {
StringBuffer result = new StringBuffer(className.length());
int length = className.length();
boolean nodot = true;
for (int i = 0; i < length; i++) {
char ch = className.charAt(i);
if (nodot) {
if (ch == '.') {
// ignore, remove
} else if (Character.isJavaIdentifierStart(ch)) {
nodot = false;
result.append(ch);
} else {
result.append('_');
}
} else {
if (ch == '.') {
nodot = true;
result.append(ch);
} else if (Character.isJavaIdentifierPart(ch)) {
nodot = false;
result.append(ch);
} else {
result.append('_');
}
}
}
return result.toString();
}
/**
* Adds the digester rules for OpenCms version 5 modules.<p>
*
* @param digester the digester to add the rules to
*/
private static void addXmlDigesterRulesForVersion5Modules(Digester digester) {
// mark method
digester.addCallMethod("*/" + N_MODULE + "/author", "setOldModule");
// base module information
digester.addCallParam("*/" + N_MODULE + "/author", 6);
digester.addCallParam("*/" + N_MODULE + "/email", 7);
digester.addCallParam("*/" + N_MODULE + "/creationdate", 8);
// dependencies
digester.addCallParam("*/" + N_MODULE + "/dependencies/dependency/name", 0);
digester.addCallParam("*/" + N_MODULE + "/dependencies/dependency/minversion", 1);
// export points
digester.addCallMethod("*/" + N_MODULE + "/exportpoint", "addExportPoint", 2);
digester.addCallParam("*/" + N_MODULE + "/exportpoint/source", 0);
digester.addCallParam("*/" + N_MODULE + "/exportpoint/destination", 1);
// parameters
digester.addCallMethod("*/" + N_MODULE + "/parameters/para", "addParameter", 2);
digester.addCallParam("*/" + N_MODULE + "/parameters/para/name", 0);
digester.addCallParam("*/" + N_MODULE + "/parameters/para/value", 1);
}
/**
* Adds a module dependency to the current module.<p>
*
* @param name the module name of the dependency
* @param version the module version of the dependency
*/
public void addDependency(String name, String version) {
CmsModuleVersion moduleVersion = new CmsModuleVersion(version);
CmsModuleDependency dependency = new CmsModuleDependency(name, moduleVersion);
m_dependencies.add(dependency);
if (LOG.isDebugEnabled()) {
LOG.debug(Messages.get().getBundle().key(Messages.LOG_ADD_MOD_DEPENDENCY_2, name, version));
}
}
/**
* Adds an explorer type setting object to the list of type settings.<p>
*
* Adds the type setting as well to a map with the resource type name as key.
*
* @param settings the explorer type settings
*/
public void addExplorerTypeSetting(CmsExplorerTypeSettings settings) {
settings.setAddititionalModuleExplorerType(true);
m_explorerTypeSettings.add(settings);
}
/**
* Adds an export point to the module configuration.<p>
*
* @param uri the export point uri
* @param destination the export point destination
*/
public void addExportPoint(String uri, String destination) {
CmsExportPoint point = new CmsExportPoint(uri, destination);
m_exportPoints.add(point);
if (CmsLog.INIT.isInfoEnabled() && (point.getDestinationPath() != null)) {
CmsLog.INIT.info(Messages.get().getBundle().key(
Messages.INIT_ADD_EXPORT_POINT_2,
point.getUri(),
point.getDestinationPath()));
}
}
/**
* Adds a module parameter to the module configuration.<p>
*
* @param key the parameter key
* @param value the parameter value
*/
public void addParameter(String key, String value) {
if (CmsStringUtil.isNotEmpty(key)) {
key = key.trim();
}
if (CmsStringUtil.isNotEmpty(value)) {
value = value.trim();
}
m_parameters.put(key, value);
if (LOG.isDebugEnabled()) {
LOG.debug(Messages.get().getBundle().key(Messages.LOG_ADD_MOD_PARAM_KEY_2, key, value));
}
}
/**
* Adds a resource to the list module resources.<p>
*
* @param resource a resources uri in the OpenCms VFS
*/
public void addResource(String resource) {
if (LOG.isDebugEnabled()) {
LOG.debug(Messages.get().getBundle().key(Messages.LOG_ADD_MOD_RESOURCE_1, resource));
}
m_resources.add(resource);
}
/**
* Adds a new resource type to the internal list of loaded resource types.<p>
*
* @param resourceType the resource type to add
*
* @see I_CmsResourceType#ADD_RESOURCE_TYPE_METHOD
*/
public void addResourceType(I_CmsResourceType resourceType) {
resourceType.setAdditionalModuleResourceType(true);
m_resourceTypes.add(resourceType);
}
/**
* Created a new module from the provided parameters.<p>
*
* @param name the name of this module, usually looks like a java package name
* @param niceName the "nice" display name of this module
* @param group the group of the module
* @param actionClass the (optional) module action class name
* @param description the description of this module
* @param version the version of this module
* @param authorName the name of the author of this module
* @param authorEmail the email of the module author
* @param dateCreated the date this module was created by the author
* @param userInstalled the name of the user who uploaded this module
* @param dateInstalled the date this module was uploaded
*/
public void createdModule(
String name,
String niceName,
String group,
String actionClass,
String description,
String version,
String authorName,
String authorEmail,
String dateCreated,
String userInstalled,
String dateInstalled) {
String moduleName;
if (!CmsStringUtil.isValidJavaClassName(name)) {
// ensure backward compatibility with old (5.0) module names
LOG.error(Messages.get().getBundle().key(Messages.LOG_INVALID_MOD_NAME_IMPORTED_1, name));
moduleName = makeValidJavaClassName(name);
LOG.error(Messages.get().getBundle().key(Messages.LOG_CORRECTED_MOD_NAME_1, moduleName));
} else {
moduleName = name;
}
// parse the module version
CmsModuleVersion moduleVersion = new CmsModuleVersion(version);
// parse date created
long moduleDateCreated = CmsModule.DEFAULT_DATE;
if (dateCreated != null) {
try {
moduleDateCreated = CmsDateUtil.parseHeaderDate(dateCreated);
} catch (ParseException e) {
// noop
}
}
// parse date installed
long moduleDateInstalled = CmsModule.DEFAULT_DATE;
if (dateInstalled != null) {
try {
moduleDateInstalled = CmsDateUtil.parseHeaderDate(dateInstalled);
} catch (ParseException e1) {
// noop
}
}
if (m_oldModule) {
// make sure module path is added to resources for "old" (5.0.x) modules
String modulePath = CmsWorkplace.VFS_PATH_MODULES + name + "/";
m_resources.add(modulePath);
}
// now create the module
m_module = new CmsModule(
moduleName,
niceName,
group,
actionClass,
description,
moduleVersion,
authorName,
authorEmail,
moduleDateCreated,
userInstalled,
moduleDateInstalled,
m_dependencies,
m_exportPoints,
m_resources,
m_parameters);
// set the additional resource types;
m_module.setResourceTypes(m_resourceTypes);
// set the additional explorertypes
m_module.setExplorerTypes(m_explorerTypeSettings);
}
/**
* Returns the generated module.<p>
*
* @return the generated module
*/
public CmsModule getModule() {
return m_module;
}
/**
* Sets the current imported module to an old (5.0.x) style module.
*/
public void setOldModule() {
m_oldModule = true;
if (LOG.isDebugEnabled()) {
LOG.debug(Messages.get().getBundle().key(Messages.LOG_OLD_MODULE_IMPORTED_0));
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -