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

com.arangodb.ArangoDatabase Maven / Gradle / Ivy

There is a newer version: 7.15.0
Show newest version
/*
 * 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 java.util.Collection;
import java.util.Map;

import com.arangodb.entity.AqlExecutionExplainEntity;
import com.arangodb.entity.AqlFunctionEntity;
import com.arangodb.entity.AqlParseEntity;
import com.arangodb.entity.ArangoDBVersion;
import com.arangodb.entity.CollectionEntity;
import com.arangodb.entity.DatabaseEntity;
import com.arangodb.entity.EdgeDefinition;
import com.arangodb.entity.GraphEntity;
import com.arangodb.entity.IndexEntity;
import com.arangodb.entity.Permissions;
import com.arangodb.entity.QueryCachePropertiesEntity;
import com.arangodb.entity.QueryEntity;
import com.arangodb.entity.QueryTrackingPropertiesEntity;
import com.arangodb.entity.TraversalEntity;
import com.arangodb.entity.ViewEntity;
import com.arangodb.entity.ViewType;
import com.arangodb.model.AqlFunctionCreateOptions;
import com.arangodb.model.AqlFunctionDeleteOptions;
import com.arangodb.model.AqlFunctionGetOptions;
import com.arangodb.model.AqlQueryExplainOptions;
import com.arangodb.model.AqlQueryOptions;
import com.arangodb.model.CollectionCreateOptions;
import com.arangodb.model.CollectionsReadOptions;
import com.arangodb.model.DocumentReadOptions;
import com.arangodb.model.GraphCreateOptions;
import com.arangodb.model.TransactionOptions;
import com.arangodb.model.TraversalOptions;
import com.arangodb.model.arangosearch.ArangoSearchCreateOptions;

/**
 * Interface for operations on ArangoDB database level.
 * 
 * @see Databases API Documentation
 * @see Query API Documentation
 * @author Mark Vollmary
 */
public interface ArangoDatabase extends ArangoSerializationAccessor {

	/**
	 * Return the main entry point for the ArangoDB driver
	 * 
	 * @return main entry point
	 */
	ArangoDB arango();

	/**
	 * Returns the name of the database
	 * 
	 * @return database name
	 */
	String name();

	/**
	 * Returns the server name and version number.
	 * 
	 * @see API
	 *      Documentation
	 * @return the server version, number
	 * @throws ArangoDBException
	 */
	ArangoDBVersion getVersion() throws ArangoDBException;

	/**
	 * Checks whether the database exists
	 * 
	 * @return true if the database exists, otherwise false
	 */
	boolean exists() throws ArangoDBException;

	/**
	 * Retrieves a list of all databases the current user can access
	 * 
	 * @see API
	 *      Documentation
	 * @return a list of all databases the current user can access
	 * @throws ArangoDBException
	 */
	Collection getAccessibleDatabases() throws ArangoDBException;

	/**
	 * Returns a {@code ArangoCollection} instance for the given collection name.
	 * 
	 * @param name
	 *            Name of the collection
	 * @return collection handler
	 */
	ArangoCollection collection(String name);

	/**
	 * Creates a collection for the given collection's name, then returns collection information from the server.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            The name of the collection
	 * @return information about the collection
	 * @throws ArangoDBException
	 */
	CollectionEntity createCollection(String name) throws ArangoDBException;

	/**
	 * Creates a collection with the given {@code options} for this collection's name, then returns collection
	 * information from the server.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            The name of the collection
	 * @param options
	 *            Additional options, can be null
	 * @return information about the collection
	 * @throws ArangoDBException
	 */
	CollectionEntity createCollection(String name, CollectionCreateOptions options) throws ArangoDBException;

	/**
	 * Fetches all collections from the database and returns an list of collection descriptions.
	 * 
	 * @see API
	 *      Documentation
	 * @return list of information about all collections
	 * @throws ArangoDBException
	 */
	Collection getCollections() throws ArangoDBException;

	/**
	 * Fetches all collections from the database and returns an list of collection descriptions.
	 * 
	 * @see API
	 *      Documentation
	 * @param options
	 *            Additional options, can be null
	 * @return list of information about all collections
	 * @throws ArangoDBException
	 */
	Collection getCollections(CollectionsReadOptions options) throws ArangoDBException;

	/**
	 * Returns an index
	 * 
	 * @see API Documentation
	 * @param id
	 *            The index-handle
	 * @return information about the index
	 * @throws ArangoDBException
	 */
	IndexEntity getIndex(String id) throws ArangoDBException;

	/**
	 * Deletes an index
	 * 
	 * @see API Documentation
	 * @param id
	 *            The index-handle
	 * @return the id of the index
	 * @throws ArangoDBException
	 */
	String deleteIndex(String id) throws ArangoDBException;

	/**
	 * Creates the database
	 * 
	 * @see API
	 *      Documentation
	 * @return true if the database was created successfully.
	 * @throws ArangoDBException
	 */
	Boolean create() throws ArangoDBException;

	/**
	 * Deletes the database from the server.
	 * 
	 * @see API
	 *      Documentation
	 * @return true if the database was dropped successfully
	 * @throws ArangoDBException
	 */
	Boolean drop() throws ArangoDBException;

	/**
	 * Grants or revoke access to the database for user {@code user}. You need permission to the _system database in
	 * order to execute this call.
	 * 
	 * @see 
	 *      API Documentation
	 * @param user
	 *            The name of the user
	 * @param permissions
	 *            The permissions the user grant
	 * @throws ArangoDBException
	 */
	void grantAccess(String user, Permissions permissions) throws ArangoDBException;

	/**
	 * Grants access to the database for user {@code user}. You need permission to the _system database in order to
	 * execute this call.
	 *
	 * @see 
	 *      API Documentation
	 * @param user
	 *            The name of the user
	 * @throws ArangoDBException
	 */
	void grantAccess(String user) throws ArangoDBException;

	/**
	 * Revokes access to the database dbname for user {@code user}. You need permission to the _system database in order
	 * to execute this call.
	 * 
	 * @see 
	 *      API Documentation
	 * @param user
	 *            The name of the user
	 * @throws ArangoDBException
	 */
	void revokeAccess(String user) throws ArangoDBException;

	/**
	 * Clear the database access level, revert back to the default access level.
	 * 
	 * @see 
	 *      API Documentation
	 * @param user
	 *            The name of the user
	 * @since ArangoDB 3.2.0
	 * @throws ArangoDBException
	 */
	void resetAccess(String user) throws ArangoDBException;

	/**
	 * Sets the default access level for collections within this database for the user {@code user}. You need permission
	 * to the _system database in order to execute this call.
	 * 
	 * @param user
	 *            The name of the user
	 * @param permissions
	 *            The permissions the user grant
	 * @since ArangoDB 3.2.0
	 * @throws ArangoDBException
	 */
	void grantDefaultCollectionAccess(String user, Permissions permissions) throws ArangoDBException;

	/**
	 * Get specific database access level
	 * 
	 * @see  API
	 *      Documentation
	 * @param user
	 *            The name of the user
	 * @return permissions of the user
	 * @since ArangoDB 3.2.0
	 * @throws ArangoDBException
	 */
	Permissions getPermissions(String user) throws ArangoDBException;

	/**
	 * Performs a database query using the given {@code query} and {@code bindVars}, then returns a new
	 * {@code ArangoCursor} instance for the result list.
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            An AQL query string
	 * @param bindVars
	 *            key/value pairs defining the variables to bind the query to
	 * @param options
	 *            Additional options that will be passed to the query API, can be null
	 * @param type
	 *            The type of the result (POJO class, VPackSlice, String for Json, or Collection/List/Map)
	 * @return cursor of the results
	 * @throws ArangoDBException
	 */
	 ArangoCursor query(String query, Map bindVars, AqlQueryOptions options, Class type)
			throws ArangoDBException;

	/**
	 * Performs a database query using the given {@code query}, then returns a new {@code ArangoCursor} instance for the
	 * result list.
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            An AQL query string
	 * @param options
	 *            Additional options that will be passed to the query API, can be null
	 * @param type
	 *            The type of the result (POJO class, VPackSlice, String for Json, or Collection/List/Map)
	 * @return cursor of the results
	 * @throws ArangoDBException
	 */
	 ArangoCursor query(String query, AqlQueryOptions options, Class type) throws ArangoDBException;

	/**
	 * Performs a database query using the given {@code query} and {@code bindVars}, then returns a new
	 * {@code ArangoCursor} instance for the result list.
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            An AQL query string
	 * @param bindVars
	 *            key/value pairs defining the variables to bind the query to
	 * @param type
	 *            The type of the result (POJO class, VPackSlice, String for Json, or Collection/List/Map)
	 * @return cursor of the results
	 * @throws ArangoDBException
	 */
	 ArangoCursor query(String query, Map bindVars, Class type) throws ArangoDBException;

	/**
	 * Performs a database query using the given {@code query}, then returns a new {@code ArangoCursor} instance for the
	 * result list.
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            An AQL query string
	 * @param type
	 *            The type of the result (POJO class, VPackSlice, String for Json, or Collection/List/Map)
	 * @return cursor of the results
	 * @throws ArangoDBException
	 */
	 ArangoCursor query(String query, Class type) throws ArangoDBException;

	/**
	 * Return an cursor from the given cursor-ID if still existing
	 * 
	 * @see API
	 *      Documentation
	 * @param cursorId
	 *            The ID of the cursor
	 * @param type
	 *            The type of the result (POJO class, VPackSlice, String for Json, or Collection/List/Map)
	 * @return cursor of the results
	 * @throws ArangoDBException
	 */
	 ArangoCursor cursor(String cursorId, Class type) throws ArangoDBException;

	/**
	 * Explain an AQL query and return information about it
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            the query which you want explained
	 * @param bindVars
	 *            key/value pairs representing the bind parameters
	 * @param options
	 *            Additional options, can be null
	 * @return information about the query
	 * @throws ArangoDBException
	 */
	AqlExecutionExplainEntity explainQuery(String query, Map bindVars, AqlQueryExplainOptions options)
			throws ArangoDBException;

	/**
	 * Parse an AQL query and return information about it This method is for query validation only. To actually query
	 * the database, see {@link ArangoDatabase#query(String, Map, AqlQueryOptions, Class)}
	 * 
	 * @see API
	 *      Documentation
	 * @param query
	 *            the query which you want parse
	 * @return imformation about the query
	 * @throws ArangoDBException
	 */
	AqlParseEntity parseQuery(String query) throws ArangoDBException;

	/**
	 * Clears the AQL query cache
	 * 
	 * @see API
	 *      Documentation
	 * @throws ArangoDBException
	 */
	void clearQueryCache() throws ArangoDBException;

	/**
	 * Returns the global configuration for the AQL query cache
	 * 
	 * @see API
	 *      Documentation
	 * @return configuration for the AQL query cache
	 * @throws ArangoDBException
	 */
	QueryCachePropertiesEntity getQueryCacheProperties() throws ArangoDBException;

	/**
	 * Changes the configuration for the AQL query cache. Note: changing the properties may invalidate all results in
	 * the cache.
	 * 
	 * @see API
	 *      Documentation
	 * @param properties
	 *            properties to be set
	 * @return current set of properties
	 * @throws ArangoDBException
	 */
	QueryCachePropertiesEntity setQueryCacheProperties(QueryCachePropertiesEntity properties) throws ArangoDBException;

	/**
	 * Returns the configuration for the AQL query tracking
	 * 
	 * @see API
	 *      Documentation
	 * @return configuration for the AQL query tracking
	 * @throws ArangoDBException
	 */
	QueryTrackingPropertiesEntity getQueryTrackingProperties() throws ArangoDBException;

	/**
	 * Changes the configuration for the AQL query tracking
	 * 
	 * @see API
	 *      Documentation
	 * @param properties
	 *            properties to be set
	 * @return current set of properties
	 * @throws ArangoDBException
	 */
	QueryTrackingPropertiesEntity setQueryTrackingProperties(QueryTrackingPropertiesEntity properties)
			throws ArangoDBException;

	/**
	 * Returns a list of currently running AQL queries
	 * 
	 * @see API
	 *      Documentation
	 * @return a list of currently running AQL queries
	 * @throws ArangoDBException
	 */
	Collection getCurrentlyRunningQueries() throws ArangoDBException;

	/**
	 * Returns a list of slow running AQL queries
	 * 
	 * @see API
	 *      Documentation
	 * @return a list of slow running AQL queries
	 * @throws ArangoDBException
	 */
	Collection getSlowQueries() throws ArangoDBException;

	/**
	 * Clears the list of slow AQL queries
	 * 
	 * @see API
	 *      Documentation
	 * @throws ArangoDBException
	 */
	void clearSlowQueries() throws ArangoDBException;

	/**
	 * Kills a running query. The query will be terminated at the next cancelation point.
	 * 
	 * @see API
	 *      Documentation
	 * @param id
	 *            The id of the query
	 * @throws ArangoDBException
	 */
	void killQuery(String id) throws ArangoDBException;

	/**
	 * Create a new AQL user function
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            A valid AQL function name, e.g.: `"myfuncs::accounting::calculate_vat"`
	 * @param code
	 *            A String evaluating to a JavaScript function
	 * @param options
	 *            Additional options, can be null
	 * @throws ArangoDBException
	 */
	void createAqlFunction(String name, String code, AqlFunctionCreateOptions options) throws ArangoDBException;

	/**
	 * Deletes the AQL user function with the given name from the database.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            The name of the user function to delete
	 * @param options
	 *            Additional options, can be null
	 * @return number of deleted functions (since ArangoDB 3.4.0)
	 * @throws ArangoDBException
	 */
	Integer deleteAqlFunction(String name, AqlFunctionDeleteOptions options) throws ArangoDBException;

	/**
	 * Gets all reqistered AQL user functions
	 * 
	 * @see API
	 *      Documentation
	 * @param options
	 *            Additional options, can be null
	 * @return all reqistered AQL user functions
	 * @throws ArangoDBException
	 */
	Collection getAqlFunctions(AqlFunctionGetOptions options) throws ArangoDBException;

	/**
	 * Returns a {@code ArangoGraph} instance for the given graph name.
	 * 
	 * @param name
	 *            Name of the graph
	 * @return graph handler
	 */
	ArangoGraph graph(String name);

	/**
	 * Create a new graph in the graph module. The creation of a graph requires the name of the graph and a definition
	 * of its edges.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            Name of the graph
	 * @param edgeDefinitions
	 *            An array of definitions for the edge
	 * @return information about the graph
	 * @throws ArangoDBException
	 */
	GraphEntity createGraph(String name, Collection edgeDefinitions) throws ArangoDBException;

	/**
	 * Create a new graph in the graph module. The creation of a graph requires the name of the graph and a definition
	 * of its edges.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            Name of the graph
	 * @param edgeDefinitions
	 *            An array of definitions for the edge
	 * @param options
	 *            Additional options, can be null
	 * @return information about the graph
	 * @throws ArangoDBException
	 */
	GraphEntity createGraph(String name, Collection edgeDefinitions, GraphCreateOptions options)
			throws ArangoDBException;

	/**
	 * Lists all graphs known to the graph module
	 * 
	 * @see API
	 *      Documentation
	 * @return graphs stored in this database
	 * @throws ArangoDBException
	 */
	Collection getGraphs() throws ArangoDBException;

	/**
	 * Performs a server-side transaction and returns its return value.
	 * 
	 * @see API
	 *      Documentation
	 * @param action
	 *            A String evaluating to a JavaScript function to be executed on the server.
	 * @param type
	 *            The type of the result (POJO class, VPackSlice or String for Json)
	 * @param options
	 *            Additional options, can be null
	 * @return the result of the transaction if it succeeded
	 * @throws ArangoDBException
	 */
	 T transaction(String action, Class type, TransactionOptions options) throws ArangoDBException;

	/**
	 * Retrieves information about the current database
	 * 
	 * @see API
	 *      Documentation
	 * @return information about the current database
	 * @throws ArangoDBException
	 */
	DatabaseEntity getInfo() throws ArangoDBException;

	/**
	 * Execute a server-side traversal
	 * 
	 * @see API
	 *      Documentation
	 * @param vertexClass
	 *            The type of the vertex documents (POJO class, VPackSlice or String for Json)
	 * @param edgeClass
	 *            The type of the edge documents (POJO class, VPackSlice or String for Json)
	 * @param options
	 *            Additional options
	 * @return Result of the executed traversal
	 * @throws ArangoDBException
	 */
	 TraversalEntity executeTraversal(Class vertexClass, Class edgeClass, TraversalOptions options)
			throws ArangoDBException;

	/**
	 * Reads a single document
	 * 
	 * @see API
	 *      Documentation
	 * @param id
	 *            The id of the document
	 * @param type
	 *            The type of the document (POJO class, VPackSlice or String for Json)
	 * @return the document identified by the id
	 * @throws ArangoDBException
	 */
	 T getDocument(String id, Class type) throws ArangoDBException;

	/**
	 * Reads a single document
	 * 
	 * @see API
	 *      Documentation
	 * @param id
	 *            The id of the document
	 * @param type
	 *            The type of the document (POJO class, VPackSlice or String for Json)
	 * @param options
	 *            Additional options, can be null
	 * @return the document identified by the id
	 * @throws ArangoDBException
	 */
	 T getDocument(String id, Class type, DocumentReadOptions options) throws ArangoDBException;

	/**
	 * Reload the routing table.
	 * 
	 * @see API
	 *      Documentation
	 * @throws ArangoDBException
	 */
	void reloadRouting() throws ArangoDBException;

	/**
	 * Returns a new {@link ArangoRoute} instance for the given path (relative to the database) that can be used to
	 * perform arbitrary requests.
	 * 
	 * @param path
	 *            The database-relative URL of the route
	 * @return {@link ArangoRoute}
	 */
	ArangoRoute route(String... path);

	/**
	 * Fetches all views from the database and returns an list of view descriptions.
	 * 
	 * @see API Documentation
	 * @return list of information about all views
	 * @throws ArangoDBException
	 * @since ArangoDB 3.4.0
	 */
	Collection getViews() throws ArangoDBException;

	/**
	 * Returns a {@code ArangoView} instance for the given view name.
	 * 
	 * @param name
	 *            Name of the view
	 * @return view handler
	 * @since ArangoDB 3.4.0
	 */
	ArangoView view(String name);

	/**
	 * Returns a {@code ArangoSearch} instance for the given ArangoSearch view name.
	 * 
	 * @param name
	 *            Name of the view
	 * @return ArangoSearch view handler
	 * @since ArangoDB 3.4.0
	 */
	ArangoSearch arangoSearch(String name);

	/**
	 * Creates a view of the given {@code type}, then returns view information from the server.
	 * 
	 * @param name
	 *            The name of the view
	 * @param type
	 *            The type of the view
	 * @return information about the view
	 * @since ArangoDB 3.4.0
	 * @throws ArangoDBException
	 */
	ViewEntity createView(String name, ViewType type) throws ArangoDBException;

	/**
	 * Creates a ArangoSearch view with the given {@code options}, then returns view information from the server.
	 * 
	 * @see API
	 *      Documentation
	 * @param name
	 *            The name of the view
	 * @param options
	 *            Additional options, can be null
	 * @return information about the view
	 * @since ArangoDB 3.4.0
	 * @throws ArangoDBException
	 */
	ViewEntity createArangoSearch(String name, ArangoSearchCreateOptions options) throws ArangoDBException;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy