Starting from release 3.3.1, the PHP driver has support for automatic failover, for ArangoDB servers that are started in the active failover mode. This setup requires using ArangoDB 3.3.
In order to use automatic failover from the PHP driver, simply change the "endpoint" attribute of the connection options from a simple endpoint string into an array of endpoint strings:
$connectionOptions = [
ConnectionOptions::OPTION_ENDPOINT => [ 'tcp://localhost:8531', 'tcp://localhost:8532', 'tcp://localhost:8530' ],
...
];
$connection = new Connection($connectionOptions);
instead of just
$connectionOptions = [
ConnectionOptions::OPTION_ENDPOINT => 'tcp://localhost:8530',
...
];
$connection = new Connection($connectionOptions);
Additionally, retrieving the endpoint value of ConnectionOptions
will now always
return an array of endpoints. For the single-server case, the returned value will be
an array with the specified endpoint. When active failover is used, the result will
be an array with the specified endpoints or the endpoints found (added) at runtime.
For example, in
$options = [ ConnectionOptions::OPTION_ENDPOINT => 'tcp://127.0.0.1:8529' ];
$co = new ConnectionOptions($options);
print_r($co[ConnectionOptions::OPTION_ENDPOINT]);
This will now print an array ([ 'tcp://127.0.0.1:8529' ]
) and not just the string
(tcp://127.0.0.1:8529'). Client applications that retrieve the endpoint value via the
ConnectionOptions` object and expect it to be a string should be adjusted to
pick the first value from the now-returned result array instead.
Using the port option for setting up ConnectionOptions
and reading it back is now
deprecated and will not be useful when using different endpoints with different port
numbers.
For example, reading the port
option here will provide just one of the specified
ports, so it should be avoided:
$options = [ ConnectionOptions::OPTION_ENDPOINT => [ 'tcp://127.0.0.1:8529', 'tcp://127.0.0.1:8530' ] ];
$co = new ConnectionOptions($options);
print_r($co[ConnectionOptions::OPTION_PORT]);
-
the default value for the authentication type of the
Connection
class is nowBasic
-
the default value for the connection type is now
Keep-Alive
and notClose
-
Document ID's are now handled correctly. This is a necessary and backwards incompatible change, in order to be consistent with ArangoDB's API.
Why: It was necessary to fix the document ids to correctly use ArangoDB's _ids instead of only the _key.
Important incompatible changes related to this:
- Document::getId(): Will return the correct id (CollectionName/DocumentID) instead of the key (DocumentID).
- UrlHelper::getDocumentIdFromLocation(): Will now return a "real" _id instead of what was essentially the
_key
Other changes related to this:
- DocumentHandler::getById(): Will work as before, but it will also accept a "real" document ID in addition to the key.
If a real document ID is given, the collection data will be extracted from that string. That means that the first parameter
$collection
does not need to have a valid value, in that case.
-
The namespace
\triagens\ArangoDb
was replaced with\ArangoDBClient
. For each class in the old namespace there is now a class alias that points from the new namespace to the old namespace, so existing applications can still use the class names from the\triagens\ArangoDb
namespace -
Support for PHP 5.5 has been removed.
-
added new methods for collection and database level permissions:
UserHandler::getDatabasePermissionLevel
UserHandler::getCollectionPermissionLevel
UserHandler::grantCollectionPermissions
UserHandler::revokeCollectionPermissions
This version of the driver is compatible with ArangoDB 3.1.x
It is not compatible to earlier versions of ArangoDB (i.e. 2.x).
Please use one of the 2.x
branches of the driver for 2.x-compatibility.
- Up until the 3.0.x versions of this driver, there were still deprecated methods and parameter compatibility functions in the code, which unfortunately were not removed according to their deprecation annotations. That deprecated code was now finally removed with this version (3.1.0) of the driver, in order to clean up the codebase.
- With this version of the driver, the method signature that used to accept $options either as an array or a non-array type has been removed. The specific compatibility layer was deprecated a long time ago and did not provide any benefits apart from compatibility. Starting with this version of the driver, there is now only one method signature that will require $options to be an array.
Please check and change your code accordingly!
-
Removed old deprecated methods:
- AdminHandler::flushServerModuleCache()
- CollectionHandler::add()
- CollectionHandler::getCount()
- CollectionHandler::getFigures()
- CollectionHandler::delete()
- DocumentHandler::getAllIds()
- DocumentHandler::getByExample()
- DocumentHandler::add()
- DocumentHandler::delete()
- DocumentHandler::deleteById()
- EdgeHandler::add()
- Graph::setVerticesCollection()
- Graph::getVerticesCollection()
- Graph::setEdgesCollection()
- Graph::getEdgesCollection()
- Handler::getCursorOptions()
-
Removed the old-style compatibility layer for parameter-passing in various methods that was used prior to switching to the $options parameter. This means, that wherever an $option array is passed to methods and a non-array type was also allowed (bool, string) for $options, the $options parameter must now be an array - it will not accept bool values or string values anymore, like for example a policy definition.
-
Performance might be a bit better due to the removal of the compatibility layer for $options.
-
Cleaned up and enriched annotations
-
Applied various smaller bug fixes
-
GraphHandler: Optimized code to do less work when not necessary
-
GraphHandler: Implemented optional cache that caches the Vertex/Edge-Collections instead of making expensive calls to the DB.
-
GraphHandler: Is now batch-able. However, if any collections need to be fetched, they will be done out-of-batch. If a lot of calls to the GraphHandler are being made, the use of the new caching functionality is encouraged.
-
Batches: Some work has been done, to optimize batches. This is still in development.
-
Switched from phpDocumentor to apigen
-
New Docs were generated
============================================================================================================
This version of the driver is compatible with ArangoDB 3.0.x
It is not compatible to earlier versions of ArangoDB (i.e. 2.x).
Please use ones of the 2.x
branches of the driver for 2.x-compatibility.
Fixed bug related to creating the correct collection type. This was no problem for the default, which is 'document', but it was a problem when the option 'createCollection'=>true was passed with save_edge().
============================================================================================================
This version of the driver is compatible with ArangoDB 3.0.7
It is not compatible to earlier versions of ArangoDB (i.e. 2.x).
Please use ones of the 2.x
branches of the driver for 2.x-compatibility.
Added an option to pre-define a batch size for a batch. This results in the driver using an SplFixedArray for the storage of the batch parts, which in turn results to a bit (5% to 15%) more performance in batch processing.
The option is called batchSize and accepts an integer.
Example: $batch = new Batch($this->connection, ['batchSize' => 10000]);
Do to the many API changes in version 3 of ArangoDB, the driver had to go through a lot of changes too. This resulted in some inconsistencies in its functionality. Version 3.0.7 has hopefully dealt with them all. If there should be any more left, please create an issue to report it.
============================================================================================================
This version of the driver is compatible with ArangoDB 3.0.
It is not compatible to earlier versions of ArangoDB (i.e. 2.x).
Please use ones of the 2.x
branches of the driver for 2.x-compatibility.
The user management APIs in class UserHandler
have changed slightly. The methods for adding,
replacing and updating users had an optional parameter named $options
, which did nothing.
This parameter has been removed.
The API methods simplify to:
-
UserHandler::addUser($username, $passwd = null, $active = null, $extra = null, $options = array())
-
UserHandler::replaceUser($username, $passwd = null, $active = null, $extra = null, $options = array())
-
UserHandler::updateUser($username, $passwd = null, $active = null, $extra = null, $options = array())
-
UserHandler::addUser($username, $passwd = null, $active = null, $extra = null)
-
UserHandler::replaceUser($username, $passwd = null, $active = null, $extra = null)
-
UserHandler::updateUser($username, $passwd = null, $active = null, $extra = null)
Note that when adding a new user via the addUser()
method, the new user will now be given
access permissions for the current database the PHP driver is connected to.
User permissions can be adjusted manually by using the following new methods of the
UserHandler
class:
- UserHandler::grantPermissions($username, $databaseName)
- UserHandler::revokePermissions($username, $databaseName)
Support for cap constraints has been discontinued on the 3.0 version of ArangoDB. Therefore, the following methods have also been removed from the PHP driver in the 3.0 branch:
- CollectionHandler::createCapConstraint($collectionId, $size)
- CollectionHandler::first($collectionId, $count = null)
- CollectionHandler::last($collectionId, $count = null)
The ArangoDB PHP driver provided PHP wrapper methods for common graph functions that were implemented server-side. When one of these wrapper methods was called, the PHP driver assembled an AQL query that called the equivalent graph AQL functions on the server. The driver has provided some extra post-filtering options for some of the graph functions, but for others it only provided a subset of the features available server-side.
With ArangoDB 3.0, the graph functionality on the server-side has changed: the
previously available AQL graph functions that were called by the PHP driver are
not available anymore in 3.0. This affects the following previously existing
methods of the PHP driver's GraphHandler
class, which are now gone in 3.0:
- GraphHandler::getNeighborVertices($graph, $vertexExample, $options = array())
- GraphHandler::getConnectedEdges($graph, $vertexId, $options = array())
- GraphHandler::getVertices($graph, $options = array())
- GraphHandler::getEdges($graph, $options = array())
- GraphHandler::getPaths($graph, $options = array())
- GraphHandler::getShortestPaths($graph, $startVertexExample = array(), $endVertexExample = array(), $options = array())
- GraphHandler::getDistanceTo($graph, $startVertexExample = null, $endVertexExample = null, $options = array())
- GraphHandler::getCommonNeighborVertices($graph, $vertex1Example = null, $vertex2Example = null, $options1 = array(),$options2 = array())
- GraphHandler::getCommonProperties($graph, $vertex1Example= null, $vertex2Example = null, $options = array())
- GraphHandler::getAbsoluteEccentricity($graph, $vertexExample = null, $options = array())
- GraphHandler::getEccentricity($graph, $options = array())
- GraphHandler::getAbsoluteCloseness($graph, $vertexExample = null, $options = array())
- GraphHandler::getCloseness($graph, $options = array())
- GraphHandler::getAbsoluteBetweenness($graph, $options = array())
- GraphHandler::getBetweenness($graph, $options = array())
- GraphHandler::getRadius($graph, $options = array())
- GraphHandler::getDiameter($graph, $options = array())
Most of these methods can be emulated by issuing an AQL query from the PHP driver. AQL provides provides blocks for computing the vertices, connected edges, and paths in a graph or just dedicated collections. As a bonus, by using AQL queries one is not limited to the subset of the functionality that was available in the "old" graph functions' interfaces, but can use the full functionality and composability of AQL.
"Custom queues" were an undocumented, experimental feature in later versions of the 2.x driver. Its purpose was to send requests to dedicated processing queues on the server. This functionality has been removed from the 3.0 ArangoDB server and the 3.0 driver.
Due to that the following undocumented methods have been removed from the PHP driver:
- Handler::enableCustomQueue($queueName, $count = null)
- Handler::disableCustomQueue()
- Connection::enableCustomQueue($queueName, $count = null)
- Connection::disableCustomQueue()
The client-side versioning feature was also removed from the driver in version
3.0. The versioning feature allowed sending the HTTP header X-Arango-Version
with the desired version number for all requests made from the driver. The
ArangoDB server interpreted the value of this HTTP header at some endpoints and
returned result structures matching the ones from older versions of ArangoDB.
This feature was abandoned on the server-side in 3.0 so the versioning was
removed from the driver as well. This also means the following methods have
been removed from the driver's Connection
class.
- Connection::getVersion()
- Connection::getClientVersion()
When replacing edges via the EdgeHandler::replace()
method, it is now
required to specify both the _from
and _to
values of the replacing edge.
If either attribute is missing or invalid, the replace operation will fail
with an error invalid edge attribute
on the server-side.
That means the following may not work:
$edgeHandler = new EdgeHandler($connection);
$edge = new Edge();
$edge->set("_id", $idOfExistingEdge);
/* set some other edge attributes */
...
$result = $edgeHandler->replace($edge);
until at least _from
and _to
are also set via the setFrom()
and setTo()
methods:
$edgeHandler = new EdgeHandler($connection);
$edge = new Edge();
$edge->set("_id", $idOfExistingEdge);
/* set some other edge attributes */
...
$edge->setFrom($fromHandle);
$edge->setTo($toHandle);
$result = $edgeHandler->replace($edge);
Note that this affects only the replace()
and replaceById()
methods and
not update()
nor updateById()
.