mirror of
https://github.com/Alfresco/alfresco-community-repo.git
synced 2025-06-02 17:35:18 +00:00
- refactoring of generate and regenerate calls to take a FormInstanceData object - adding in support for overriding step title and description properties in wizards so as to be able to format them with parameters - making the step descriptions in create form wizard reiterate the form name so as to give the user better context - displaying avm task resources in the manage task screen. still need to get actions working and clean this up a bit. - making output path patterns sandbox relative - refactored utility method for combining avm paths sensitive to webapp vs sandbox relative paths. - adding a default description for generated renditions todo: - cleanup some usage of AVMNode from ManageTaskBean - get actions to appear in manage task screen - add a multi value property to the web project for all its webapps - properly use overridden values for forms from the web project settings git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@4687 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
139 lines
4.3 KiB
Java
139 lines
4.3 KiB
Java
/*
|
|
* Copyright (C) 2006 Alfresco, Inc.
|
|
*
|
|
* Licensed under the Mozilla Public License version 1.1
|
|
* with a permitted attribution clause. You may obtain a
|
|
* copy of the License at
|
|
*
|
|
* http://www.alfresco.org/legal/license.txt
|
|
*
|
|
* Unless required by applicable law or agreed to in writing,
|
|
* software distributed under the License is distributed on an
|
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
|
|
* either express or implied. See the License for the specific
|
|
* language governing permissions and limitations under the
|
|
* License.
|
|
*/
|
|
|
|
package org.alfresco.repo.avm;
|
|
|
|
import org.alfresco.service.cmr.avm.AVMException;
|
|
import org.alfresco.service.cmr.repository.NodeRef;
|
|
import org.alfresco.service.cmr.repository.StoreRef;
|
|
import org.alfresco.util.Pair;
|
|
import org.apache.log4j.Logger;
|
|
|
|
/**
|
|
* Utility for going back and forth between the AVM world and
|
|
* the <code>StoreRef</code>, <code>NodeRef</code> world.
|
|
* @author britt
|
|
*/
|
|
public class AVMNodeConverter
|
|
{
|
|
private static Logger fgLogger = Logger.getLogger(AVMNodeConverter.class);
|
|
|
|
/**
|
|
* Get a NodeRef corresponding to the given path and version.
|
|
* @param version The version id.
|
|
* @param avmPath The AVM path.
|
|
* @return A NodeRef with AVM info stuffed inside.
|
|
*/
|
|
public static NodeRef ToNodeRef(int version, String avmPath)
|
|
{
|
|
String [] pathParts = avmPath.split(":");
|
|
if (pathParts.length != 2)
|
|
{
|
|
throw new AVMException("Malformed AVM Path: " + avmPath);
|
|
}
|
|
while (pathParts[1].endsWith("/") && pathParts[1].length() > 1)
|
|
{
|
|
pathParts[1] = pathParts[1].substring(0, pathParts[1].length() - 1);
|
|
}
|
|
StoreRef storeRef = ToStoreRef(pathParts[0]);
|
|
String translated = version + pathParts[1];
|
|
translated = translated.replaceAll("/+", ";");
|
|
return new NodeRef(storeRef, translated);
|
|
}
|
|
|
|
/**
|
|
* Get a StoreRef that corresponds to a given AVMStore name.
|
|
* @param avmStore The name of the AVMStore.
|
|
* @return A working StoreRef.
|
|
*/
|
|
public static StoreRef ToStoreRef(String avmStore)
|
|
{
|
|
return new StoreRef(StoreRef.PROTOCOL_AVM, avmStore);
|
|
}
|
|
|
|
/**
|
|
* Convert a NodeRef into a version, AVMPath pair.
|
|
* @param nodeRef The NodeRef to convert.
|
|
* @return An Integer, String array.
|
|
*/
|
|
public static Pair<Integer, String> ToAVMVersionPath(NodeRef nodeRef)
|
|
{
|
|
StoreRef store = nodeRef.getStoreRef();
|
|
String translated = nodeRef.getId();
|
|
translated = translated.replace(';', '/');
|
|
int off = translated.indexOf("/");
|
|
if (off == -1)
|
|
{
|
|
fgLogger.error(translated);
|
|
throw new AVMException("Bad Node Reference: " + nodeRef.getId());
|
|
}
|
|
int version = Integer.parseInt(translated.substring(0, off));
|
|
String path = translated.substring(off);
|
|
return new Pair<Integer, String>(version, store.getIdentifier() + ":" + path);
|
|
}
|
|
|
|
/**
|
|
* Extend an already valid AVM path by one more component.
|
|
* @param path The starting AVM path.
|
|
* @param name The name to add to it.
|
|
* @return The extended path.
|
|
*/
|
|
public static String ExtendAVMPath(String path, String name)
|
|
{
|
|
if (path.endsWith("/"))
|
|
{
|
|
return path + name;
|
|
}
|
|
else
|
|
{
|
|
return path + "/" + name;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Split a path into its parent path and its base name.
|
|
* @param path The initial AVM path.
|
|
* @return An array of 2 Strings containing the parent path and the base
|
|
* name.
|
|
*/
|
|
public static String [] SplitBase(String path)
|
|
{
|
|
path = path.replaceAll("/+", "/");
|
|
while (path.endsWith("/") && !path.endsWith(":/"))
|
|
{
|
|
path = path.substring(0, path.length() - 1);
|
|
}
|
|
if (path.endsWith(":/"))
|
|
{
|
|
return new String[] { null, "" };
|
|
}
|
|
int off = path.lastIndexOf("/");
|
|
if (off == -1)
|
|
{
|
|
throw new AVMException("Invalid Path: " + path);
|
|
}
|
|
String [] decomposed = new String[2];
|
|
decomposed[0] = path.substring(0, off);
|
|
if (decomposed[0].endsWith(":"))
|
|
{
|
|
decomposed[0] = decomposed[0] + "/";
|
|
}
|
|
decomposed[1] = path.substring(off + 1);
|
|
return decomposed;
|
|
}
|
|
}
|