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

org.neo4j.driver.internal.util.Extract Maven / Gradle / Ivy

/*
 * Copyright (c) "Neo4j"
 * Neo4j Sweden AB [https://neo4j.com]
 *
 * 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 org.neo4j.driver.internal.util;

import static java.util.Collections.emptyList;
import static java.util.Collections.emptyMap;
import static java.util.Collections.singletonList;
import static java.util.Collections.singletonMap;
import static java.util.Collections.unmodifiableList;
import static java.util.Collections.unmodifiableMap;
import static org.neo4j.driver.Values.value;
import static org.neo4j.driver.internal.util.Iterables.newHashMapWithSize;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Map;
import java.util.function.Function;
import org.neo4j.driver.Record;
import org.neo4j.driver.Value;
import org.neo4j.driver.exceptions.ClientException;
import org.neo4j.driver.internal.InternalPair;
import org.neo4j.driver.internal.value.NodeValue;
import org.neo4j.driver.internal.value.PathValue;
import org.neo4j.driver.internal.value.RelationshipValue;
import org.neo4j.driver.types.MapAccessor;
import org.neo4j.driver.types.Node;
import org.neo4j.driver.types.Path;
import org.neo4j.driver.types.Relationship;
import org.neo4j.driver.util.Pair;

/**
 * Utility class for extracting data.
 */
public final class Extract {
    private Extract() {
        throw new UnsupportedOperationException();
    }

    public static List list(Value[] values) {
        return switch (values.length) {
            case 0 -> emptyList();
            case 1 -> singletonList(values[0]);
            default -> List.of(values);
        };
    }

    public static  List list(Value[] data, Function mapFunction) {
        var size = data.length;
        switch (size) {
            case 0 -> {
                return emptyList();
            }
            case 1 -> {
                return singletonList(mapFunction.apply(data[0]));
            }
            default -> {
                return Arrays.stream(data).map(mapFunction).toList();
            }
        }
    }

    public static  Map map(Map data, Function mapFunction) {
        if (data.isEmpty()) {
            return emptyMap();
        } else {
            var size = data.size();
            if (size == 1) {
                var head = data.entrySet().iterator().next();
                return singletonMap(head.getKey(), mapFunction.apply(head.getValue()));
            } else {
                Map map = Iterables.newLinkedHashMapWithSize(size);
                for (var entry : data.entrySet()) {
                    map.put(entry.getKey(), mapFunction.apply(entry.getValue()));
                }
                return unmodifiableMap(map);
            }
        }
    }

    public static  Map map(Record record, Function mapFunction) {
        var size = record.size();
        switch (size) {
            case 0 -> {
                return emptyMap();
            }
            case 1 -> {
                return singletonMap(record.keys().get(0), mapFunction.apply(record.get(0)));
            }
            default -> {
                Map map = Iterables.newLinkedHashMapWithSize(size);
                var keys = record.keys();
                for (var i = 0; i < size; i++) {
                    map.put(keys.get(i), mapFunction.apply(record.get(i)));
                }
                return unmodifiableMap(map);
            }
        }
    }

    public static  Iterable> properties(
            final MapAccessor map, final Function mapFunction) {
        var size = map.size();
        switch (size) {
            case 0 -> {
                return emptyList();
            }
            case 1 -> {
                var key = map.keys().iterator().next();
                var value = map.get(key);
                return singletonList(InternalPair.of(key, mapFunction.apply(value)));
            }
            default -> {
                List> list = new ArrayList<>(size);
                for (var key : map.keys()) {
                    var value = map.get(key);
                    list.add(InternalPair.of(key, mapFunction.apply(value)));
                }
                return unmodifiableList(list);
            }
        }
    }

    public static  List> fields(final Record map, final Function mapFunction) {
        var size = map.keys().size();
        switch (size) {
            case 0 -> {
                return emptyList();
            }
            case 1 -> {
                var key = map.keys().iterator().next();
                var value = map.get(key);
                return singletonList(InternalPair.of(key, mapFunction.apply(value)));
            }
            default -> {
                List> list = new ArrayList<>(size);
                var keys = map.keys();
                for (var i = 0; i < size; i++) {
                    var key = keys.get(i);
                    var value = map.get(i);
                    list.add(InternalPair.of(key, mapFunction.apply(value)));
                }
                return unmodifiableList(list);
            }
        }
    }

    public static Map mapOfValues(Map map) {
        if (map == null || map.isEmpty()) {
            return emptyMap();
        }

        Map result = newHashMapWithSize(map.size());
        for (var entry : map.entrySet()) {
            var value = entry.getValue();
            assertParameter(value);
            result.put(entry.getKey(), value(value));
        }
        return result;
    }

    public static void assertParameter(Object value) {
        if (value instanceof Node || value instanceof NodeValue) {
            throw new ClientException("Nodes can't be used as parameters.");
        }
        if (value instanceof Relationship || value instanceof RelationshipValue) {
            throw new ClientException("Relationships can't be used as parameters.");
        }
        if (value instanceof Path || value instanceof PathValue) {
            throw new ClientException("Paths can't be used as parameters.");
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy