io.joynr.capabilities.directory.CapabilitiesDirectoryImpl Maven / Gradle / Ivy
/*
* #%L
* %%
* Copyright (C) 2011 - 2017 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%
*/
package io.joynr.capabilities.directory;
import io.joynr.arbitration.DiscoveryQos;
import io.joynr.capabilities.CapabilityUtils;
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.exceptions.ProviderRuntimeException;
import joynr.infrastructure.GlobalCapabilitiesDirectoryAbstractProvider;
import joynr.system.RoutingTypes.Address;
import joynr.system.RoutingTypes.ChannelAddress;
import joynr.system.RoutingTypes.MqttAddress;
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();
Promise promise = new Promise(deferred);
Address address = CapabilityUtils.getAddressFromGlobalDiscoveryEntry(globalDiscoveryEntry);
String clusterControllerId;
if (address instanceof MqttAddress) {
clusterControllerId = ((MqttAddress) address).getTopic();
} else if (address instanceof ChannelAddress) {
clusterControllerId = ((ChannelAddress) address).getChannelId();
} else {
deferred.reject(new ProviderRuntimeException(""));
return promise;
}
GlobalDiscoveryEntryPersisted discoveryEntry = new GlobalDiscoveryEntryPersisted(globalDiscoveryEntry,
clusterControllerId);
logger.debug("registered discovery entry: {}", discoveryEntry);
discoveryEntryStore.add(discoveryEntry);
deferred.resolve();
return promise;
}
@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[] domains, final String interfaceName) {
Lookup1Deferred deferred = new Lookup1Deferred();
logger.debug("Searching channels for domains: {} interfaceName: {}", domains, interfaceName);
Collection discoveryEntries = discoveryEntryStore.lookup(domains, 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);
}
@Override
public Promise touch(String clusterControllerId) {
DeferredVoid deferred = new DeferredVoid();
discoveryEntryStore.touch(clusterControllerId);
deferred.resolve();
return new Promise(deferred);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy