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

org.eclipse.jnosql.mapping.graph.GraphTemplate Maven / Gradle / Ivy

There is a newer version: 1.1.3
Show newest version
/*
 *  Copyright (c) 2022 Contributors to the Eclipse Foundation
 *   All rights reserved. This program and the accompanying materials
 *   are made available under the terms of the Eclipse Public License v1.0
 *   and Apache License v2.0 which accompanies this distribution.
 *   The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
 *   and the Apache License v2.0 is available at http://www.opensource.org/licenses/apache2.0.php.
 *
 *   You may elect to redistribute this code under either of these licenses.
 *
 *   Contributors:
 *
 *   Otavio Santana
 */
package org.eclipse.jnosql.mapping.graph;

import jakarta.nosql.PreparedStatement;
import jakarta.nosql.Template;
import org.apache.tinkerpop.gremlin.structure.Direction;
import org.apache.tinkerpop.gremlin.structure.Transaction;

import java.util.Collection;
import java.util.List;
import java.util.Objects;
import java.util.Optional;
import java.util.function.Supplier;
import java.util.stream.Stream;

/**
 * GraphTemplate is a helper class that increases productivity when performing common Graph operations.
 * Includes integrated object mapping between documents and POJOs {@link org.apache.tinkerpop.gremlin.structure.Vertex}
 * and {@link org.apache.tinkerpop.gremlin.structure.Edge}.
 * It represents the common operation between an entity and {@link org.apache.tinkerpop.gremlin.structure.Graph}
 *
 * @see org.apache.tinkerpop.gremlin.structure.Graph
 */
public interface GraphTemplate extends Template {

    /**
     * Deletes a {@link org.apache.tinkerpop.gremlin.structure.Vertex}
     *
     * @param id  the id to be used in the query {@link org.apache.tinkerpop.gremlin.structure.T#id}
     * @param  the id type
     * @throws NullPointerException when id is null
     */
     void delete(T id);

    /**
     * Deletes a {@link org.apache.tinkerpop.gremlin.structure.Edge}
     *
     * @param id  the id to be used in the query {@link org.apache.tinkerpop.gremlin.structure.T#id}
     * @param  the id type
     * @throws NullPointerException when either label and id are null
     */
     void deleteEdge(T id);

    /**
     * Find an entity given {@link org.apache.tinkerpop.gremlin.structure.T#label} and
     * {@link org.apache.tinkerpop.gremlin.structure.T#id}
     *
     * @param id  the id to be used in the query {@link org.apache.tinkerpop.gremlin.structure.T#id}
     * @param  the entity type
     * @param  the id type
     * @return the entity found otherwise {@link Optional#empty()}
     * @throws NullPointerException when id is null
     */
     Optional find(K id);

    /**
     * Updates entities
     *
     * @param entities entity to be updated
     * @param       the instance type
     * @return the entity saved
     * @throws IllegalStateException                     when document is null
     */
     Iterable update(Iterable entities);

    /**
     * Deletes {@link org.apache.tinkerpop.gremlin.structure.Vertex} instances
     *
     * @param ids the ids to be used in the query {@link org.apache.tinkerpop.gremlin.structure.T#id}
     * @param  the id type
     * @throws NullPointerException when id is null
     */
     void delete(Iterable ids);

    /**
     * Deletes {@link org.apache.tinkerpop.gremlin.structure.Edge} instances
     *
     * @param ids the ids to be used in the query {@link org.apache.tinkerpop.gremlin.structure.T#id}
     * @param  the id type
     * @throws NullPointerException when either label and id are null
     */
     void deleteEdge(Iterable ids);

    /**
     * Either find or create an Edge between this two entities.
     * {@link org.apache.tinkerpop.gremlin.structure.Edge}
     * 
entityOUT ---label---> entityIN.
* * @param incoming the incoming entity * @param label the Edge label * @param outgoing the outgoing entity * @param the incoming type * @param the outgoing type * @return the {@link EdgeEntity} of these two entities * @throws NullPointerException Either when any elements are null or the entity is null */ EdgeEntity edge(O outgoing, String label, I incoming); /** * Either find or create an Edge between this two entities. * {@link org.apache.tinkerpop.gremlin.structure.Edge} *
entityOUT ---label---> entityIN.
* * @param incoming the incoming entity * @param label the Edge label * @param outgoing the outgoing entity * @param the incoming type * @param the outgoing type * @return the {@link EdgeEntity} of these two entities * @throws NullPointerException Either when any elements are null or the entity is null */ default EdgeEntity edge(O outgoing, Supplier label, I incoming) { Objects.requireNonNull(label, "supplier is required"); return edge(outgoing, label.get(), incoming); } /** * returns the edges of from a vertex id * * @param id the id * @param direction the direction * @param labels the edge labels * @param the K type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edgesById(K id, Direction direction, String... labels); /** * returns the edges of from a vertex id * * @param id the id * @param direction the direction * @param labels the edge labels * @param the K type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edgesById(K id, Direction direction, Supplier... labels); /** * returns the edges of from a vertex id * * @param id the id * @param direction the direction * @param the K type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edgesById(K id, Direction direction); /** * returns the edges of from an entity * * @param entity the entity * @param direction the direction * @param labels the edge labels * @param the entity type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edges(T entity, Direction direction, String... labels); /** * returns the edges of from an entity * * @param entity the entity * @param direction the direction * @param labels the edge labels * @param the entity type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edges(T entity, Direction direction, Supplier... labels); /** * returns the edges of from an entity * * @param entity the entity * @param direction the direction * @param the entity type * @return the Edges * @throws NullPointerException where there is any parameter null */ Collection edges(T entity, Direction direction); /** * Finds an {@link EdgeEntity} from the Edge Id * * @param edgeId the edge id * @param the edge id type * @return the {@link EdgeEntity} otherwise {@link Optional#empty()} * @throws IllegalStateException when edgeId is null */ Optional edge(E edgeId); /** * Gets a {@link VertexTraversal} to run a query in the graph * * @param vertexIds get ids * @return a {@link VertexTraversal} instance * @throws IllegalStateException if any id element is null */ VertexTraversal traversalVertex(Object... vertexIds); /** * Gets a {@link EdgeTraversal} to run a query in the graph * * @param edgeIds get ids * @return a {@link VertexTraversal} instance * @throws IllegalStateException if any id element is null */ EdgeTraversal traversalEdge(Object... edgeIds); /** * Gets the current transaction * * @return the current {@link Transaction} */ Transaction transaction(); /** * Executes a Gremlin then bring the result as a {@link List} * * @param gremlin the query gremlin * @param the entity type * @return the result as {@link List} * @throws NullPointerException when the gremlin is null */ Stream query(String gremlin); /** * Executes a Gremlin query then bring the result as a unique result * * @param gremlin the gremlin query * @param the entity type * @return the result as {@link List} * @throws NullPointerException when the query is null */ Optional singleResult(String gremlin); /** * Creates a {@link PreparedStatement} from the query * * @param gremlin the gremlin query * @return a {@link PreparedStatement} instance * @throws NullPointerException when the query is null */ PreparedStatement prepare(String gremlin); /** * Returns the number of vertices from label * * @param label the label * @return the number of elements * @throws NullPointerException when label is null * @throws UnsupportedOperationException when the database dot not have support */ long count(String label); /** * Returns the number of vertices from label * * @param the entity type * @param type the label * @return the number of elements * @throws NullPointerException when label is null * @throws UnsupportedOperationException when the database dot not have support */ long count(Class type); /** * Returns all entities on the database * @param type the entity type filter * @return the {@link Stream} * @param the entity type * @throws NullPointerException when type is null */ Stream findAll(Class type); /** * delete all entities from the database * @param type the entity type filter * @param the entity type * @throws NullPointerException when type is null */ void deleteAll(Class type); }