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

com.quorum.tessera.discovery.DiscoveryHelperImpl Maven / Gradle / Ivy

package com.quorum.tessera.discovery;

import com.quorum.tessera.context.RuntimeContext;
import com.quorum.tessera.enclave.Enclave;
import com.quorum.tessera.encryption.KeyNotFoundException;
import com.quorum.tessera.encryption.PublicKey;
import com.quorum.tessera.partyinfo.node.NodeInfo;
import com.quorum.tessera.partyinfo.node.Recipient;
import com.quorum.tessera.version.ApiVersion;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.net.URI;
import java.util.List;
import java.util.Optional;
import java.util.Set;
import java.util.stream.Collectors;

public class DiscoveryHelperImpl implements DiscoveryHelper {

    private static final Logger LOGGER = LoggerFactory.getLogger(DiscoveryHelperImpl.class);

    private Enclave enclave;

    private final NetworkStore networkStore;

    public DiscoveryHelperImpl(NetworkStore networkStore, Enclave enclave) {
        this.networkStore = networkStore;
        this.enclave = enclave;
    }

    @Override
    public void onCreate() {
        RuntimeContext runtimeContext = RuntimeContext.getInstance();

        final NodeUri nodeUri =
            Optional.of(runtimeContext).map(RuntimeContext::getP2pServerUri).map(NodeUri::create).get();

        ActiveNode thisNode =
            ActiveNode.Builder.create()
                .withUri(nodeUri)
                .withKeys(enclave.getPublicKeys())
                .withSupportedVersions(ApiVersion.versions())
                .build();

        networkStore.store(thisNode);
    }

    @Override
    public NodeInfo buildCurrent() {

        final URI uri = RuntimeContext.getInstance().getP2pServerUri();
        final NodeUri nodeUri = NodeUri.create(uri);
        final List activeNodes = networkStore.getActiveNodes().collect(Collectors.toList());

        Set recipients =
                activeNodes.stream()
                        .filter(a -> !a.getKeys().isEmpty())
                        .flatMap(a -> a.getKeys().stream().map(k -> Recipient.of(k, a.getUri().asString())))
                        .collect(Collectors.toSet());

        NodeInfo nodeInfo =
                NodeInfo.Builder.create()
                        .withRecipients(recipients)
                        .withUrl(nodeUri.asString())
                        .withSupportedApiVersions(ApiVersion.versions())
                        .build();

        LOGGER.debug("Built nodeinfo {}", nodeInfo);
        return nodeInfo;
    }

    @Override
    public NodeInfo buildRemoteNodeInfo(PublicKey recipientKey) {

        final ActiveNode activeNode =
                networkStore
                        .getActiveNodes()
                        .filter(node -> node.getKeys().contains(recipientKey))
                        .findAny()
                        .orElseThrow(
                                () ->
                                        new KeyNotFoundException(
                                                "Recipient not found for key: " + recipientKey.encodeToBase64()));

        final String nodeUrl = activeNode.getUri().asString();

        final Set recipients =
                activeNode.getKeys().stream().map(k -> Recipient.of(k, nodeUrl)).collect(Collectors.toSet());

        final NodeInfo nodeInfo =
                NodeInfo.Builder.create()
                        .withUrl(nodeUrl)
                        .withRecipients(recipients)
                        .withSupportedApiVersions(activeNode.getSupportedVersions())
                        .build();

        return nodeInfo;
    }

    @Override
    public Set buildRemoteNodeInfos() {

        final NodeUri uri = NodeUri.create(RuntimeContext.getInstance().getP2pServerUri());

        return networkStore.getActiveNodes()
            .filter(n -> !n.getUri().equals(uri))
            .map(activeNode -> {
                String url = activeNode.getUri().asString();
                return NodeInfo.Builder.create()
                    .withUrl(url)
                    .withRecipients(activeNode.getKeys().stream().map(k -> Recipient.of(k, url)).collect(Collectors.toSet()))
                    .withSupportedApiVersions(activeNode.getSupportedVersions())
                    .build();
            }
        ).collect(Collectors.toSet());
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy