]> git.argeo.org Git - lgpl/argeo-commons.git/blobdiff - server/plugins/org.argeo.jcr.ui.explorer/src/main/java/org/argeo/jcr/ui/explorer/model/RepositoriesNode.java
Update license headers
[lgpl/argeo-commons.git] / server / plugins / org.argeo.jcr.ui.explorer / src / main / java / org / argeo / jcr / ui / explorer / model / RepositoriesNode.java
index 6634603aa18fe4bf28a033ba51b2db644efe0aa4..975c87cba480d48f9414e46f647579e2e60e3ca9 100644 (file)
@@ -1,3 +1,18 @@
+/*
+ * Copyright (C) 2007-2012 Mathieu Baudier
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *         http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * 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.argeo.jcr.ui.explorer.model;
 
 import java.util.Hashtable;
@@ -32,13 +47,16 @@ import org.argeo.jcr.security.JcrKeyring;
 
 public class RepositoriesNode extends TreeParent implements ArgeoNames {
        private final RepositoryRegister repositoryRegister;
+       private final RepositoryFactory repositoryFactory;
 
        private final JcrKeyring jcrKeyring;
 
        public RepositoriesNode(String name, RepositoryRegister repositoryRegister,
-                       TreeParent parent, JcrKeyring jcrKeyring) {
+                       RepositoryFactory repositoryFactory, TreeParent parent,
+                       JcrKeyring jcrKeyring) {
                super(name);
                this.repositoryRegister = repositoryRegister;
+               this.repositoryFactory = repositoryFactory;
                this.jcrKeyring = jcrKeyring;
        }
 
@@ -76,7 +94,7 @@ public class RepositoriesNode extends TreeParent implements ArgeoNames {
                        throws RepositoryException {
                Session userSession = jcrKeyring.getSession();
                Node userHome = JcrUtils.getUserHome(userSession);
-               if (userHome.hasNode(ARGEO_REMOTE)) {
+               if (userHome != null && userHome.hasNode(ARGEO_REMOTE)) {
                        NodeIterator it = userHome.getNode(ARGEO_REMOTE).getNodes();
                        while (it.hasNext()) {
                                Node remoteNode = it.nextNode();
@@ -86,7 +104,7 @@ public class RepositoriesNode extends TreeParent implements ArgeoNames {
                                        params.put(ArgeoJcrConstants.JCR_REPOSITORY_URI, uri);
                                        params.put(ArgeoJcrConstants.JCR_REPOSITORY_ALIAS,
                                                        remoteNode.getName());
-                                       Repository repository = repositoryRegister
+                                       Repository repository = repositoryFactory
                                                        .getRepository(params);
                                        RemoteRepositoryNode remoteRepositoryNode = new RemoteRepositoryNode(
                                                        remoteNode.getName(), repository, this, jcrKeyring,
@@ -107,7 +125,7 @@ public class RepositoriesNode extends TreeParent implements ArgeoNames {
                // super.addChild(new RepositoriesNode(...));
        }
 
-       /** Returns the {@link RepositoryRegister} wrapped by thgis object. */
+       /** Returns the {@link RepositoryRegister} wrapped by this object. */
        public RepositoryRegister getRepositoryRegister() {
                return repositoryRegister;
        }