
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.DiscoveryEntryStore;
import io.joynr.capabilities.GlobalDiscoveryEntryPersisted;
import io.joynr.provider.DeferredVoid;
import io.joynr.provider.Promise;
import java.util.Arrays;
import java.util.Collection;
import joynr.infrastructure.GlobalCapabilitiesDirectoryAbstractProvider;
import joynr.types.DiscoveryEntry;
import joynr.types.GlobalDiscoveryEntry;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
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.
*/
@Singleton
public class CapabilitiesDirectoryImpl extends GlobalCapabilitiesDirectoryAbstractProvider {
private static final Logger logger = LoggerFactory.getLogger(CapabilitiesDirectoryImpl.class);
private DiscoveryEntryStore discoveryEntryStore;
@Inject
public CapabilitiesDirectoryImpl(@Persisted DiscoveryEntryStore discoveryEntryStore) {
this.discoveryEntryStore = discoveryEntryStore;
}
@Override
public Promise add(GlobalDiscoveryEntry globalDiscoveryEntry) {
DeferredVoid deferred = new DeferredVoid();
GlobalDiscoveryEntryPersisted discoveryEntry = new GlobalDiscoveryEntryPersisted(globalDiscoveryEntry);
logger.debug("registered discovery entry: {}", discoveryEntry);
discoveryEntryStore.add(discoveryEntry);
deferred.resolve();
return new Promise(deferred);
}
@Override
public Promise add(GlobalDiscoveryEntry[] globalDiscoveryEntries) {
DeferredVoid deferred = new DeferredVoid();
for (GlobalDiscoveryEntry globalDiscoveryEntry : globalDiscoveryEntries) {
add(globalDiscoveryEntry);
}
deferred.resolve();
return new Promise(deferred);
}
@Override
public Promise remove(String participantId) {
DeferredVoid deferred = new DeferredVoid();
logger.debug("removed discovery entry with participantId: {}", participantId);
discoveryEntryStore.remove(participantId);
deferred.resolve();
return new Promise(deferred);
}
@Override
public Promise remove(String[] participantIds) {
DeferredVoid deferred = new DeferredVoid();
discoveryEntryStore.remove(Arrays.asList(participantIds));
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 discoveryEntries = discoveryEntryStore.lookup(domain, interfaceName);
GlobalDiscoveryEntry[] globalDiscoveryEntries = new GlobalDiscoveryEntry[discoveryEntries.size()];
int index = 0;
for (DiscoveryEntry discoveryEntry : discoveryEntries) {
// entries from persisted store are of type GlobalDiscoveryEntryPersisted.
// Copy required or else _typeName will be incorrect
globalDiscoveryEntries[index] = new GlobalDiscoveryEntry((GlobalDiscoveryEntry) discoveryEntry);
index++;
}
deferred.resolve(globalDiscoveryEntries);
return new Promise(deferred);
}
@Override
public Promise lookup(String forParticipantId) {
Lookup2Deferred deferred = new Lookup2Deferred();
logger.debug("Searching discovery entries for participantId: {}", forParticipantId);
DiscoveryEntry discoveryEntry = discoveryEntryStore.lookup(forParticipantId,
DiscoveryQos.NO_FILTER.getCacheMaxAgeMs());
if (discoveryEntry == null) {
deferred.resolve(null);
} else {
deferred.resolve((GlobalDiscoveryEntry) discoveryEntry);
}
return new Promise(deferred);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy