/*
* Copyright (c) 2006-2011 Nuxeo SA (http://nuxeo.com/) and others.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Nuxeo - initial API and implementation
*/
package org.eclipse.ecr.core.api.localconfiguration;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.eclipse.ecr.core.api.ClientException;
import org.eclipse.ecr.core.api.CoreSession;
import org.eclipse.ecr.core.api.DocumentModel;
import org.eclipse.ecr.core.api.DocumentRef;
import org.eclipse.ecr.runtime.model.DefaultComponent;
/**
* Default implementation of {@code LocalConfigurationService}.
*
* @author <a href="mailto:troger@nuxeo.com">Thomas Roger</a>
* @since 5.4.2
*/
public class LocalConfigurationServiceImpl extends DefaultComponent implements
LocalConfigurationService {
private static final Log log = LogFactory.getLog(LocalConfigurationServiceImpl.class);
@Override
public <T extends LocalConfiguration> T getConfiguration(
Class<T> configurationClass, String configurationFacet,
DocumentModel currentDoc) {
if (currentDoc == null) {
return null;
}
try {
CoreSession session = currentDoc.getCoreSession();
T localConfiguration = session.adaptFirstMatchingDocumentWithFacet(
currentDoc.getRef(), configurationFacet, configurationClass);
if (localConfiguration == null) {
// no local configuration found
return null;
}
while (localConfiguration.canMerge()) {
DocumentRef parentRef = session.getParentDocumentRef(localConfiguration.getDocumentRef());
T parentConfiguration = session.adaptFirstMatchingDocumentWithFacet(
parentRef, configurationFacet, configurationClass);
if (parentConfiguration == null) {
// stop merging
break;
}
localConfiguration.merge(parentConfiguration);
}
return localConfiguration;
} catch (ClientException e) {
String message = String.format(
"Unable to retrieve local configuration for '%s' and '%s' facet: %s",
currentDoc, configurationFacet, e.getMessage());
log.warn(message);
log.debug(e, e);
}
return null;
}
}