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

org.jnosql.artemis.graph.EdgeEntity Maven / Gradle / Ivy

The newest version!
/*
 *  Copyright (c) 2017 Otávio Santana and others
 *   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.jnosql.artemis.graph;

import org.apache.tinkerpop.gremlin.structure.Edge;
import org.apache.tinkerpop.gremlin.structure.Property;
import org.jnosql.diana.api.Value;

import java.util.List;
import java.util.Optional;

import static java.util.Objects.requireNonNull;

/**
 * The representation of {@link org.apache.tinkerpop.gremlin.structure.Edge} that links two Entity.
 * Along with its Property objects, an Edge has both a Direction and a label.
 * Any Change at the Edge is automatically continued in the database. However, any, change in the Entity will be ignored.
 * {@link GraphTemplate#update(Object)}
 * 

*

outVertex ---label---> inVertex.
*/ public interface EdgeEntity { /** * Returns the id * * @return the id */ Value getId(); /** * Returns the label of the vertex * * @return the label */ String getLabel(); /** * Gets the incoming entity * * @param the type * @return the incoming entity */ T getIncoming(); /** * Gets the outgoing entity * * @param the type * @return the outgoing entity */ T getOutgoing(); /** * Returns the properties of this vertex * * @return the properties */ List getProperties(); /** * Add a new element in the Vertex * * @param key the key * @param value the information * @throws NullPointerException when either key or value are null */ void add(String key, Object value); /** * Add a new element in the Vertex * * @param key the key * @param value the information * @throws NullPointerException when either key or value are null */ void add(String key, Value value); /** * Removes an property * * @param key the key * @throws NullPointerException whe key is null */ void remove(String key); /** * Returns the property from the key * * @param key the key to find the property * @return the property to the respective key otherwise {@link Optional#empty()} * @throws NullPointerException when key is null */ Optional get(String key); /** * Returns true if this Edge contains no elements. * * @return true if this collection contains no elements */ boolean isEmpty(); /** * Returns the number of property in Edge * * @return the number of elements in this Edge */ int size(); /** * Deletes the Edge from the database, after this operation, any write operation * such as add a property will an illegal state. */ void delete(); /** * Creates a new {@link EdgeEntity} instance * * @param outgoing the outgoing * @param edge the Tinkerpop edge representation * @param incoming the incoming object * @param the outgoing type * @param the incoming type * @return an {@link EdgeEntity} instance * @throws NullPointerException if any parameters is null */ static EdgeEntity of(OUT outgoing, Edge edge, IN incoming) { requireNonNull(outgoing, "outgoing is required"); requireNonNull(edge, "edge is required"); requireNonNull(incoming, "incoming is required"); return new DefaultEdgeEntity<>(edge, incoming, outgoing); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy