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

io.joynr.capabilities.directory.CapabilitiesDirectoryImpl Maven / Gradle / Ivy

package io.joynr.capabilities.directory;

/*
 * #%L
 * %%
 * Copyright (C) 2011 - 2014 BMW Car IT GmbH
 * %%
 * 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.
 * #L%
 */

import io.joynr.arbitration.DiscoveryQos;
import io.joynr.capabilities.CapabilitiesStore;
import io.joynr.capabilities.CapabilityEntry;
import io.joynr.capabilities.CapabilityEntryPersisted;
import io.joynr.provider.DeferredVoid;
import io.joynr.provider.Promise;

import java.util.Arrays;
import java.util.Collection;
import java.util.List;

import joynr.infrastructure.GlobalCapabilitiesDirectoryAbstractProvider;
import joynr.types.CapabilityInformation;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.google.common.collect.Lists;
import com.google.inject.Inject;
import com.google.inject.Singleton;

/**
 * The capabilities directory implementation for server-side capabilities querying.
 * Capability informations are stored in a concurrentHashMap. Using a in memory database could be possible optimization.
 */

// TODO Evaluate pro /cons of a in memory database
// TODO Using the interfaceAddress as the key may increase performance in most
// requests.

@Singleton
public class CapabilitiesDirectoryImpl extends GlobalCapabilitiesDirectoryAbstractProvider {
    private static final Logger logger = LoggerFactory.getLogger(CapabilitiesDirectoryImpl.class);
    private CapabilitiesStore capabiltiesStore;

    @Inject
    public CapabilitiesDirectoryImpl(CapabilitiesStore capabiltiesStore) {
        this.capabiltiesStore = capabiltiesStore;
    }

    @Override
    public Promise add(CapabilityInformation capabilityInformation) {
        DeferredVoid deferred = new DeferredVoid();
        CapabilityEntry capabilityEntry = new CapabilityEntryPersisted(capabilityInformation);
        logger.debug("registered capability: {}", capabilityEntry);
        capabiltiesStore.add(capabilityEntry);
        deferred.resolve();
        return new Promise(deferred);
    }

    @Override
    public Promise add(CapabilityInformation[] capabilitiesInformation) {
        DeferredVoid deferred = new DeferredVoid();
        // TODO check interfaces before adding them
        List capabilityEntries = Lists.newArrayList();
        for (CapabilityInformation capInfo : capabilitiesInformation) {
            capabilityEntries.add(new CapabilityEntryPersisted(capInfo));
        }

        logger.debug("registered capabilities: interface {}", capabilityEntries.toString());

        capabiltiesStore.add(capabilityEntries);
        deferred.resolve();
        return new Promise(deferred);
    }

    @Override
    public Promise remove(String participantId) {
        DeferredVoid deferred = new DeferredVoid();
        logger.debug("removed capability with participantId: {}", participantId);
        capabiltiesStore.remove(participantId);
        deferred.resolve();
        return new Promise(deferred);
    }

    @Override
    public Promise remove(String[] capabilities) {
        DeferredVoid deferred = new DeferredVoid();
        // TODO who is allowed to remove capabilities
        List capabilityEntries = Lists.newArrayList();
        logger.debug("Removing capabilities: Capabilities {}", capabilityEntries);
        capabiltiesStore.remove(Arrays.asList(capabilities));
        deferred.resolve();
        return new Promise(deferred);
    }

    @Override
    public Promise lookup(final String domain, final String interfaceName) {
        Lookup1Deferred deferred = new Lookup1Deferred();
        logger.debug("Searching channels for domain: " + domain + " interfaceName: " + interfaceName + " {}");
        Collection entryCollection = capabiltiesStore.lookup(domain, interfaceName);
        CapabilityInformation[] capabilityInformationList = new CapabilityInformation[entryCollection.size()];
        int index = 0;
        for (CapabilityEntry entry : entryCollection) {
            capabilityInformationList[index] = entry.toCapabilityInformation();
            index++;
        }
        deferred.resolve(capabilityInformationList);
        return new Promise(deferred);
    }

    @Override
    public Promise lookup(String forParticipantId) {
        Lookup2Deferred deferred = new Lookup2Deferred();
        logger.debug("Searching capabilities for participantId: {}", forParticipantId);
        CapabilityEntry capEntry = capabiltiesStore.lookup(forParticipantId, DiscoveryQos.NO_FILTER.getCacheMaxAge());
        if (capEntry == null) {
            deferred.resolve(null);
        } else {
            deferred.resolve(capEntry.toCapabilityInformation());
        }
        return new Promise(deferred);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy