com.arangodb.ArangoEdgeCollection Maven / Gradle / Ivy
/*
* DISCLAIMER
*
* Copyright 2016 ArangoDB GmbH, Cologne, Germany
*
* 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.
*
* Copyright holder is ArangoDB GmbH, Cologne, Germany
*/
package com.arangodb;
import com.arangodb.entity.EdgeEntity;
import com.arangodb.entity.EdgeUpdateEntity;
import com.arangodb.model.DocumentReadOptions;
import com.arangodb.model.EdgeCreateOptions;
import com.arangodb.model.EdgeDeleteOptions;
import com.arangodb.model.EdgeReplaceOptions;
import com.arangodb.model.EdgeUpdateOptions;
/**
* Interface for operations on ArangoDB edge collection level.
*
* @see API Documentation
* @author Mark Vollmary
*/
public interface ArangoEdgeCollection extends ArangoSerializationAccessor {
/**
* The the handler of the named graph the edge collection is within
*
* @return graph handler
*/
ArangoGraph graph();
/**
* The name of the edge collection
*
* @return collection name
*/
String name();
/**
* Creates a new edge in the collection
*
* @see API Documentation
* @param value
* A representation of a single edge (POJO, VPackSlice or String for Json)
* @return information about the edge
* @throws ArangoDBException
*/
EdgeEntity insertEdge(T value) throws ArangoDBException;
/**
* Creates a new edge in the collection
*
* @see API Documentation
* @param value
* A representation of a single edge (POJO, VPackSlice or String for Json)
* @param options
* Additional options, can be null
* @return information about the edge
* @throws ArangoDBException
*/
EdgeEntity insertEdge(T value, EdgeCreateOptions options) throws ArangoDBException;
/**
* Fetches an existing edge
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @return the edge identified by the key
* @throws ArangoDBException
*/
T getEdge(String key, Class type) throws ArangoDBException;
/**
* Fetches an existing edge
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @param options
* Additional options, can be null
* @return the edge identified by the key
* @throws ArangoDBException
*/
T getEdge(String key, Class type, DocumentReadOptions options) throws ArangoDBException;
/**
* Replaces the edge with key with the one in the body, provided there is such a edge and no precondition is
* violated
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @return information about the edge
* @throws ArangoDBException
*/
EdgeUpdateEntity replaceEdge(String key, T value) throws ArangoDBException;
/**
* Replaces the edge with key with the one in the body, provided there is such a edge and no precondition is
* violated
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @param options
* Additional options, can be null
* @return information about the edge
* @throws ArangoDBException
*/
EdgeUpdateEntity replaceEdge(String key, T value, EdgeReplaceOptions options) throws ArangoDBException;
/**
* Partially updates the edge identified by document-key. The value must contain a document with the attributes to
* patch (the patch document). All attributes from the patch document will be added to the existing document if they
* do not yet exist, and overwritten in the existing document if they do exist there.
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @return information about the edge
* @throws ArangoDBException
*/
EdgeUpdateEntity updateEdge(String key, T value) throws ArangoDBException;
/**
* Partially updates the edge identified by document-key. The value must contain a document with the attributes to
* patch (the patch document). All attributes from the patch document will be added to the existing document if they
* do not yet exist, and overwritten in the existing document if they do exist there.
*
* @see API Documentation
* @param key
* The key of the edge
* @param type
* The type of the edge-document (POJO class, VPackSlice or String for Json)
* @param options
* Additional options, can be null
* @return information about the edge
* @throws ArangoDBException
*/
EdgeUpdateEntity updateEdge(String key, T value, EdgeUpdateOptions options) throws ArangoDBException;
/**
* Removes a edge
*
* @see API Documentation
* @param key
* The key of the edge
* @throws ArangoDBException
*/
void deleteEdge(String key) throws ArangoDBException;
/**
* Removes a edge
*
* @see API Documentation
* @param key
* The key of the edge
* @param options
* Additional options, can be null
* @throws ArangoDBException
*/
void deleteEdge(String key, EdgeDeleteOptions options) throws ArangoDBException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy