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

com.datastax.driver.dse.graph.GraphNode Maven / Gradle / Ivy

Go to download

A driver for DataStax Enterprise (DSE) and Apache Cassandra 1.2+ clusters that works exclusively with the Cassandra Query Language version 3 (CQL3) and Cassandra's binary protocol, supporting DSE-specific features such as geospatial types, DSE Graph and DSE authentication.

There is a newer version: 2.4.0
Show newest version
/*
 * Copyright DataStax, Inc.
 *
 * This software can be used solely with DataStax Enterprise. Please consult the license at
 * http://www.datastax.com/terms/datastax-dse-driver-license-terms
 */
package com.datastax.driver.dse.graph;

import com.datastax.driver.core.exceptions.DriverException;
import com.datastax.driver.dse.serde.Node;

/**
 * A node in a tree-like structure representing a Graph or a Graph component. It contains additional
 * methods that perform conversion to Graph elements (vertex, edge, etc.).
 */
public interface GraphNode extends Node {

  @Override
  GraphNode get(String fieldName);

  @Override
  GraphNode get(int index);

  /**
   * Returns {@code true} if this node is a vertex.
   *
   * 

If this node is a vertex, then {@link #asVertex()} can be safely called. * * @return {@code true} if this node is a vertex, {@code false} otherwise. */ boolean isVertex(); /** * Returns {@code true} if this node is an edge. * *

If this node is an edge, then {@link #asEdge()} can be safely called. * * @return {@code true} if this node is an edge, {@code false} otherwise. */ boolean isEdge(); /** * Returns this node as a {@link Vertex}. * * @return a {@link Vertex} representation of this node. * @throws DriverException if this node cannot be converted to a {@link Vertex}. */ Vertex asVertex(); /** * Returns this node as an {@link Edge}. * * @return an {@link Edge} representation of this node. * @throws DriverException if this node cannot be converted to a {@link Edge}. */ Edge asEdge(); /** * Returns this node as a {@link Path}. * * @return a {@link Path} representation of this node. * @throws DriverException if this node cannot be converted to a {@link Path}. */ Path asPath(); /** * Returns this node as a {@link Property}. * * @return a {@link Property} representation of this node. * @throws DriverException if this node cannot be converted to a {@link Property}. */ Property asProperty(); /** * Returns this node as a {@link VertexProperty}. * * @return a {@link VertexProperty} representation of this node. * @throws DriverException if this node cannot be converted to a {@link VertexProperty}. */ VertexProperty asVertexProperty(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy