001/*
002 * (C) Copyright 2006-2007 Nuxeo SA (http://nuxeo.com/) and others.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 *     http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 * See the License for the specific language governing permissions and
014 * limitations under the License.
015 *
016 * Contributors:
017 *     <a href="mailto:at@nuxeo.com">Anahide Tchertchian</a>
018 *
019 * $Id: IOManagerComponent.java 24959 2007-09-14 13:46:47Z atchertchian $
020 */
021
022package org.nuxeo.ecm.platform.io.impl;
023
024import org.apache.commons.logging.Log;
025import org.apache.commons.logging.LogFactory;
026import org.nuxeo.ecm.platform.io.api.IOManager;
027import org.nuxeo.ecm.platform.io.api.IOResourceAdapter;
028import org.nuxeo.ecm.platform.io.descriptors.IOResourceAdapterDescriptor;
029import org.nuxeo.runtime.model.ComponentInstance;
030import org.nuxeo.runtime.model.ComponentName;
031import org.nuxeo.runtime.model.DefaultComponent;
032
033/**
034 * Component registering {@link IOResourceAdapter} instances to an {@link IOManager}.
035 *
036 * @author <a href="mailto:at@nuxeo.com">Anahide Tchertchian</a>
037 */
038public class IOManagerComponent extends DefaultComponent {
039
040    public static final ComponentName NAME = new ComponentName(IOManagerComponent.class.getName());
041
042    public static final String ADAPTERS_EP_NAME = "adapters";
043
044    private static final Log log = LogFactory.getLog(IOManagerComponent.class);
045
046    private final IOManager service;
047
048    public IOManagerComponent() {
049        service = new IOManagerImpl();
050    }
051
052    public IOManager getIOManager() {
053        return service;
054    }
055
056    @Override
057    public void registerContribution(Object contribution, String extensionPoint, ComponentInstance contributor) {
058        if (extensionPoint.equals(ADAPTERS_EP_NAME)) {
059            IOResourceAdapterDescriptor desc = (IOResourceAdapterDescriptor) contribution;
060            String name = desc.getName();
061            String className = desc.getClassName();
062            IOResourceAdapter adapter;
063            try {
064                // Thread context loader is not working in isolated EARs
065                adapter = (IOResourceAdapter) IOManagerComponent.class.getClassLoader().loadClass(className).newInstance();
066            } catch (ReflectiveOperationException e) {
067                log.error("Caught error when instantiating adapter", e);
068                return;
069            }
070            adapter.setProperties(desc.getProperties());
071            IOResourceAdapter existing = service.getAdapter(name);
072            if (existing != null) {
073                log.warn(String.format("Overriding IO Resource adapter definition %s", name));
074                service.removeAdapter(name);
075            }
076            service.addAdapter(name, adapter);
077            log.info(String.format("IO resource adapter %s registered", name));
078        } else {
079            log.error(String.format("Unknown extension point %s, can't register !", extensionPoint));
080        }
081    }
082
083    @Override
084    public void unregisterContribution(Object contribution, String extensionPoint, ComponentInstance contributor) {
085        if (extensionPoint.equals(ADAPTERS_EP_NAME)) {
086            IOResourceAdapterDescriptor desc = (IOResourceAdapterDescriptor) contribution;
087            service.removeAdapter(desc.getName());
088        } else {
089            log.error(String.format("Unknown extension point %s, can't unregister !", extensionPoint));
090        }
091    }
092
093    @Override
094    @SuppressWarnings("unchecked")
095    public <T> T getAdapter(Class<T> adapter) {
096        if (adapter.isAssignableFrom(IOManager.class)) {
097            return (T) service;
098        }
099        return null;
100    }
101
102}