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

io.telicent.jena.graphql.fetchers.TraversalEdgesFetcher Maven / Gradle / Ivy

/**
 * Copyright (C) Telicent Ltd
 *
 * 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.
 */
package io.telicent.jena.graphql.fetchers;

import graphql.schema.DataFetcher;
import graphql.schema.DataFetchingEnvironment;
import io.telicent.jena.graphql.schemas.TraversalSchema;
import io.telicent.jena.graphql.schemas.models.EdgeDirection;
import io.telicent.jena.graphql.schemas.models.NodeKind;
import io.telicent.jena.graphql.schemas.models.TraversalEdge;
import io.telicent.jena.graphql.schemas.models.TraversalNode;
import io.telicent.jena.graphql.utils.NodeFilter;
import org.apache.jena.graph.Node;
import org.apache.jena.sparql.core.DatasetGraph;

import java.util.EnumSet;
import java.util.List;
import java.util.stream.Collectors;

/**
 * A {@link DataFetcher} that fetches the incoming/outgoing edges from a node as part of answering a Traversal GraphQL
 * schema query
 */
public class TraversalEdgesFetcher implements DataFetcher> {

    /**
     * Creates a traversal edges fetcher that finds the incoming/outgoing edges for a traversal node
     */
    public TraversalEdgesFetcher() {

    }

    @Override
    public List get(DataFetchingEnvironment environment) {
        DatasetGraph dsg = environment.getLocalContext();
        TraversalNode node = environment.getSource();

        // Determine which edges we are traversing and which edges we care about
        List predicateFilters = NodeFilter.parseList(environment.getArgument(TraversalSchema.PREDICATE_FIELD));
        EnumSet kinds = NodeFilter.parseKinds(environment.getArgument(TraversalSchema.KINDS_ARGUMENT));

        List edges = switch (environment.getField().getName()) {
            //@formatter:off
            case TraversalSchema.INCOMING_FIELD ->
                    predicateFilters
                          .stream()
                          .distinct()
                          .flatMap(p -> dsg.stream(Node.ANY, Node.ANY, p, node.getNode().getNode())
                          .map(q -> TraversalEdge.of(q.getPredicate(), EdgeDirection.IN, q.getSubject())))
                          .filter(e -> kinds.contains(e.getTarget().getNode().getKind()))
                          .collect(Collectors.toList());
            case TraversalSchema.OUTGOING_FIELD ->
                    predicateFilters
                          .stream()
                          .distinct()
                          .flatMap(p -> dsg.stream(Node.ANY, node.getNode().getNode(), p, Node.ANY))
                          .map(q -> TraversalEdge.of(q.getPredicate(), EdgeDirection.OUT, q.getObject()))
                          .filter(e -> kinds.contains(e.getTarget().getNode().getKind()))
                          .collect(Collectors.toList());
            //@formatter:on
            default -> throw new IllegalArgumentException("Unrecognised field " + environment.getField().getName());
        };
        return !edges.isEmpty() ? edges : null;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy