All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.modeshape.jcr.api.RepositoriesContainer Maven / Gradle / Ivy

There is a newer version: 5.4.1.Final
Show newest version
/*
 * ModeShape (http://www.modeshape.org)
 * See the COPYRIGHT.txt file distributed with this work for information
 * regarding copyright ownership.  Some portions may be licensed
 * to Red Hat, Inc. under one or more contributor license agreements.
 * See the AUTHORS.txt file in the distribution for a full listing of
 * individual contributors.
 *
 * ModeShape is free software. Unless otherwise indicated, all code in ModeShape
 * is licensed to you under the terms of the GNU Lesser General Public License as
 * published by the Free Software Foundation; either version 2.1 of
 * the License, or (at your option) any later version.
 *
 * ModeShape is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this software; if not, write to the Free
 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
 * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
 */

package org.modeshape.jcr.api;

import java.util.Map;
import java.util.Set;
import java.util.concurrent.Future;
import java.util.concurrent.TimeUnit;
import javax.jcr.RepositoryException;

/**
 * Interface which defines components acting as containers for one or more {@link Repository} instances.
 * A repository container is an entity that can manage a number of repositories, each repository being identified by a name.
 * It is also able to start/{@link #shutdown()}/return the names of all the repositories it manages.
 * 

* This is meant to replace the "container aspect" of the current {@link RepositoryFactory} interface. * {@link RepositoryFactory} should only be used for creating/obtaining a new repository instance, as defined in the * {@link javax.jcr.RepositoryFactory} contract. *

* When looking for and initializing specific repositories, this will use a similar {@link java.util.Map} of named parameters as * {@link RepositoryFactory} but with a more "loose semantic": *

    *
  • * when a repository should be initialized for the first time, the {@link #getRepository(String, java.util.Map)} should * be called, where the map of parameters contains a parameter named {@code org.modeshape.jcr.URL} which has * a {@code String} value representing either the path to a JSON configuration file or, if it uses the {@code jndi} * protocol, the name under which the repository is bound in JNDI. *
  • *
  • * if a repository has already been initialized & started up as described above, the {@link #getRepository(String, java.util.Map)} * method can be called with a {@code null} or empty map, as the container already holds a reference to the repository. *
  • *
*

*

Getting a RepositoriesContainer instance

* In order to use this service, clients will need to use the ModeShape API via the standard {@link java.util.ServiceLoader} mechanism, * *
 *   Iterator containersIterator = ServiceLoader.load(RepositoriesContainer.class).iterator();
 *   if (!containersIterator.hasNext()) {
 *    // no implementations are found on the classpath, meaning the modeshape-jcr.jar has not been correctly loaded.
 *   }
 *   //there shouldn't be more than 1 container
 *   RepositoriesContainer repositoriesContainer = containersIterator.next();
 * 
* * @author Horia Chiorean ([email protected]) * @since 3.4 */ public interface RepositoriesContainer { /** * The name of the key for the ModeShape JCR URL in the parameter map. * * @see RepositoryFactory#URL */ public static final String URL = RepositoryFactory.URL; /** * The name of the key for the ModeShape JCR repository name in the parameter map. This can be used as an alternative to * specifying the repository name as a URL parameter within the {@link #URL URL}. * * @see RepositoryFactory#REPOSITORY_NAME */ public static final String REPOSITORY_NAME = RepositoryFactory.REPOSITORY_NAME; /** * Shutdown this engine to stop all repositories created by calls to {@link #getRepository(String, java.util.Map)}, terminate any ongoing * background operations (such as sequencing), and reclaim any resources that were acquired by the repositories. This method * may be called multiple times, but only the first time has an effect. *

* Invoking this method does not preclude creating new {@link javax.jcr.Repository} instances with future calls to * {@link #getRepository(String, java.util.Map)}. Any caller using this method as part of an application shutdown process should take care to * cease invocations of {@link #getRepository(String, java.util.Map)} prior to invoking this method. *

*

* This method returns immediately, even before the repositories have been shut down. However, the caller can simply call the * {@link java.util.concurrent.Future#get() get()} method on the returned {@link java.util.concurrent.Future} to block until all repositories have shut down. Note that * the {@link java.util.concurrent.Future#get(long, java.util.concurrent.TimeUnit)} method can be called to block for a maximum amount of time. *

* * @return a future that allows the caller to block until the engine is shutdown; any error during shutdown will be thrown * when {@link java.util.concurrent.Future#get() getting} the repository from the future, where the exception is wrapped in a * {@link java.util.concurrent.ExecutionException}. The value returned from the future will always be true if the engine shutdown (or was * not running), or false if the engine is still running. */ public Future shutdown(); /** * Shutdown this engine to stop all repositories created by calls to {@link #getRepository(String, java.util.Map)}, terminate any ongoing * background operations (such as sequencing), and reclaim any resources that were acquired by the repositories. This method * may be called multiple times, but only the first time has an effect. *

* This method is equivalent to calling "shutdown().get(timeout,unit)" on this method. *

*

* Invoking this method does not preclude creating new {@link javax.jcr.Repository} instances with future calls to * {@link #getRepository(String, java.util.Map)}. Any caller using this method as part of an application shutdown process should take care to * cease invocations of {@link #getRepository(String, java.util.Map)} prior to invoking this method. *

*

* This method returns immediately, even before the repositories have been shut down. However, the caller can simply call the * {@link Future#get() get()} method on the returned {@link Future} to block until all repositories have shut down. Note that * the {@link Future#get(long, java.util.concurrent.TimeUnit)} method can be called to block for a maximum amount of time. *

* * @param timeout the maximum time per engine to allow for shutdown * @param unit the time unit of the timeout argument * @return true if all engines completely shut down and false if the timeout elapsed before it was shut down * completely * @throws InterruptedException if interrupted while waiting */ public boolean shutdown( long timeout, TimeUnit unit ) throws InterruptedException; /** * Returns the names of all the available repositories, using an optional map of parameters which may be used to initialize * additional repositories, which will also be returned. * * @param parameters map of string key/value pairs as repository arguments or {@code null} if none are provided * @return the immutable set of repository names provided by this container; never {@code null} * @throws javax.jcr.RepositoryException if there is an error performing the lookup. * * @see RepositoryFactory#getRepository(java.util.Map) */ public Set getRepositoryNames( Map parameters ) throws RepositoryException; /** * Return the JCR Repository with the supplied name and an optional map of parameters which can be used to initialize the * repository. * * @param repositoryName the name of the repository to return; may be {@code null} if, for example, the parameters map already * contains this information. * @param parameters map of string key/value pairs as repository arguments. My be {@code null} if no configuration parameters * exist. * @return the repository with the given name or {@code null} if no repository is found * @throws javax.jcr.RepositoryException if there is an error communicating with the repository * * @see RepositoryFactory#getRepository(java.util.Map) */ public javax.jcr.Repository getRepository( String repositoryName, Map parameters ) throws javax.jcr.RepositoryException; }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy