]> git.argeo.org Git - gpl/argeo-slc.git/commitdiff
Fixes for remote, but will not work with the current version of Jackrabbit.
authorMathieu Baudier <mbaudier@argeo.org>
Mon, 25 Mar 2013 11:39:44 +0000 (11:39 +0000)
committerMathieu Baudier <mbaudier@argeo.org>
Mon, 25 Mar 2013 11:39:44 +0000 (11:39 +0000)
git-svn-id: https://svn.argeo.org/slc/trunk@6210 4cfe0d0a-d680-48aa-b62c-e0a02a3f76cc

demo/slc_demo_remote.properties
modules/org.argeo.slc.node.jackrabbit/META-INF/spring/jackrabbit.xml
runtime/org.argeo.slc.support.jcr/src/main/java/org/argeo/slc/jcr/execution/JcrAgent.java

index bf6d879c8521e4e2c1da78575f11b2348504ac02..784038fe457b805855edfdc31cf58a019df64982 100644 (file)
@@ -1,22 +1,18 @@
 argeo.osgi.start=\
 org.springframework.osgi.extender,\
-org.argeo.node.repofactory.jackrabbit,\
-org.argeo.node.repo.jackrabbit,\
 org.argeo.security.dao.jackrabbit,\
 org.argeo.slc.node.jackrabbit,\
 org.argeo.slc.agent,\
 org.argeo.slc.agent.jcr,\
-org.argeo.slc.demo.ant,\
+org.argeo.slc.support.maven,\
+
+slc.executionModules=org.argeo.slc.demo.ant,\
 org.argeo.slc.demo.basic,\
 org.argeo.slc.demo.minimal,\
-org.argeo.elgis.rpmfactory,\
 
 eclipse.application=org.argeo.slc.client.rcp.application
 org.argeo.security.ui.initialPerspective=org.argeo.slc.client.ui.slcExecutionPerspective
 
 log4j.configuration=file:../../log4j.properties
 
-argeo.node.repo.home=data/noderepo
-argeo.node.repo.dburl=jdbc:h2:data/h2/noderepo_db
-
-argeo.node.repo.uri=http://localrepo:7070/org.argeo.jcr.webapp/remoting/node
+argeo.node.repo.uri=http://localhost:7070/data/jcr/node
index 6b068005330c79579180f1ed8f762a2447c65de2..f41c5f11539c403e3b66f1b34d5b96a2ffb63445 100644 (file)
        </bean>
 
        <!-- Security -->
-       <bean class="org.argeo.jackrabbit.JackrabbitAuthorizations"
-               init-method="run">
-               <property name="principalPrivileges">
-                       <map>
-                               <entry key="jcr:all" value="ROLE_SLC" />
-                       </map>
-               </property>
-               <property name="repository" ref="jcrRepository" />
-       </bean>
+<!--   <bean class="org.argeo.jackrabbit.JackrabbitAuthorizations" -->
+<!--           init-method="run"> -->
+<!--           <property name="principalPrivileges"> -->
+<!--                   <map> -->
+<!--                           <entry key="jcr:all" value="ROLE_SLC" /> -->
+<!--                   </map> -->
+<!--           </property> -->
+<!--           <property name="repository" ref="jcrRepository" /> -->
+<!--   </bean> -->
 
        <bean
                class="org.argeo.security.core.AuthenticatedApplicationContextInitialization">
index a7f5b7747543b8e6c6a4fd7687ab39693833f393..008b1c5f1bb9c9364a558ca99cfec44fa02987f9 100644 (file)
@@ -15,6 +15,8 @@
  */
 package org.argeo.slc.jcr.execution;
 
+import java.net.InetAddress;
+import java.net.UnknownHostException;
 import java.util.UUID;
 
 import javax.jcr.Node;
@@ -34,6 +36,9 @@ import org.argeo.slc.jcr.SlcTypes;
 
 /** SLC VM agent synchronizing with a JCR repository. */
 public class JcrAgent extends DefaultAgent implements SlcNames {
+       // final static String ROLE_REMOTE = "ROLE_REMOTE";
+       final static String NODE_REPO_URI = "argeo.node.repo.uri";
+
        private Repository repository;
 
        private String agentNodeName = "default";
@@ -45,9 +50,10 @@ public class JcrAgent extends DefaultAgent implements SlcNames {
                Session session = null;
                try {
                        session = repository.login();
+
+                       String agentFactoryPath = getAgentFactoryPath();
                        Node vmAgentFactoryNode = JcrUtils.mkdirsSafe(session,
-                                       SlcJcrConstants.VM_AGENT_FACTORY_PATH,
-                                       SlcTypes.SLC_AGENT_FACTORY);
+                                       agentFactoryPath, SlcTypes.SLC_AGENT_FACTORY);
                        if (!vmAgentFactoryNode.hasNode(agentNodeName)) {
                                String uuid = UUID.randomUUID().toString();
                                Node agentNode = vmAgentFactoryNode.addNode(agentNodeName,
@@ -89,7 +95,29 @@ public class JcrAgent extends DefaultAgent implements SlcNames {
         * UTILITIES
         */
        public String getNodePath() {
-               return SlcJcrConstants.VM_AGENT_FACTORY_PATH + '/' + getAgentNodeName();
+               return getAgentFactoryPath() + '/' + getAgentNodeName();
+       }
+
+       public String getAgentFactoryPath() {
+               try {
+                       Boolean isRemote = System.getProperty(NODE_REPO_URI) != null;
+                       String agentFactoryPath;
+                       if (isRemote) {
+                               InetAddress localhost = InetAddress.getLocalHost();
+                               agentFactoryPath = SlcJcrConstants.AGENTS_BASE_PATH + "/"
+                                               + localhost.getCanonicalHostName();
+
+                               if (agentFactoryPath
+                                               .equals(SlcJcrConstants.VM_AGENT_FACTORY_PATH))
+                                       throw new SlcException("Unsupported hostname "
+                                                       + localhost.getCanonicalHostName());
+                       } else {// local
+                               agentFactoryPath = SlcJcrConstants.VM_AGENT_FACTORY_PATH;
+                       }
+                       return agentFactoryPath;
+               } catch (UnknownHostException e) {
+                       throw new SlcException("Cannot find agent factory base path", e);
+               }
        }
 
        /*
@@ -106,5 +134,4 @@ public class JcrAgent extends DefaultAgent implements SlcNames {
        public void setAgentNodeName(String agentNodeName) {
                this.agentNodeName = agentNodeName;
        }
-
 }