]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - server/runtime/org.argeo.server.jackrabbit/src/main/java/org/argeo/jcr/JcrUtils.java
Add query in JCR controller
[lgpl/argeo-commons.git] / server / runtime / org.argeo.server.jackrabbit / src / main / java / org / argeo / jcr / JcrUtils.java
index 8792a36de3aeb3e79d02f2376c68aaf9baee4660..d3174a1cace4427be061598273b2039b529968c7 100644 (file)
@@ -3,6 +3,7 @@ package org.argeo.jcr;
 import java.util.Calendar;
 import java.util.StringTokenizer;
 
+import javax.jcr.NamespaceRegistry;
 import javax.jcr.Node;
 import javax.jcr.NodeIterator;
 import javax.jcr.Property;
@@ -38,10 +39,10 @@ public class JcrUtils {
                        throw new ArgeoException("Query returned more than one node.");
                return node;
        }
-       
-       public static String removeForbiddenCharacters(String str){
-               return str.replace('[', '_').replace(']', '_')
-               .replace('/', '_').replace('*', '_');
+
+       public static String removeForbiddenCharacters(String str) {
+               return str.replace('[', '_').replace(']', '_').replace('/', '_')
+                               .replace('*', '_');
 
        }
 
@@ -59,18 +60,19 @@ public class JcrUtils {
        }
 
        public static String dateAsPath(Calendar cal) {
-               StringBuffer buf = new StringBuffer(11);
-               buf.append(cal.get(Calendar.YEAR));// 4
+               StringBuffer buf = new StringBuffer(14);
+               buf.append('Y').append(cal.get(Calendar.YEAR));// 5
                buf.append('/');// 1
                int month = cal.get(Calendar.MONTH) + 1;
+               buf.append('M');
                if (month < 10)
                        buf.append(0);
-               buf.append(month);// 2
+               buf.append(month);// 3
                buf.append('/');// 1
                int day = cal.get(Calendar.DAY_OF_MONTH);
                if (day < 10)
                        buf.append(0);
-               buf.append(day);// 2
+               buf.append('D').append(day);// 3
                buf.append('/');// 1
                return buf.toString();
 
@@ -128,6 +130,39 @@ public class JcrUtils {
                }
        }
 
+       public static void registerNamespaceSafely(Session session, String prefix,
+                       String uri) {
+               try {
+                       registerNamespaceSafely(session.getWorkspace()
+                                       .getNamespaceRegistry(), prefix, uri);
+               } catch (RepositoryException e) {
+                       throw new ArgeoException("Cannot find namespace registry", e);
+               }
+       }
+
+       public static void registerNamespaceSafely(NamespaceRegistry nr,
+                       String prefix, String uri) {
+               try {
+                       String[] prefixes = nr.getPrefixes();
+                       for (String pref : prefixes)
+                               if (pref.equals(prefix)) {
+                                       String registeredUri = nr.getURI(pref);
+                                       if (!registeredUri.equals(uri))
+                                               throw new ArgeoException("Prefix " + pref
+                                                               + " already registered for URI "
+                                                               + registeredUri
+                                                               + " which is different from provided URI "
+                                                               + uri);
+                                       else
+                                               return;// skip
+                               }
+                       nr.registerNamespace(prefix, uri);
+               } catch (RepositoryException e) {
+                       throw new ArgeoException("Cannot register namespace " + uri
+                                       + " under prefix " + prefix, e);
+               }
+       }
+
        /** Recursively outputs the contents of the given node. */
        public static void debug(Node node) throws RepositoryException {
                // First output the node path
@@ -146,8 +181,8 @@ public class JcrUtils {
 
                // Then output the properties
                PropertyIterator properties = node.getProperties();
-               //log.debug("Property are : ");
-               
+               // log.debug("Property are : ");
+
                while (properties.hasNext()) {
                        Property property = properties.nextProperty();
                        if (property.getDefinition().isMultiple()) {