Explorer connects to ElasticSearch through the PHP ElasticSearch client and has several options to configure a connection.
The connection configuration is defined config/explorer.php
.
The most basic connection is with http without authorization.
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
],
];
Another connection option is to use an elastic cloud id as shown below
return [
'connection' => [
'elasticCloudId' => 'staging:dXMtZWFzdC0xLmF3cy5mb3VuZC5pbyRjZWM2ZjI2MWE3NGJmMjRjZTMzYmI4ODExYjg0Mjk0ZiRjNmMyY2E2ZDA0MjI0OWFmMGNjN2Q3YTllOTYyNTc0Mw',
],
];
To specify a username and password use the auth
key with a username
and a password
.
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
'auth' => [
'username' => 'myName',
'password' => 'myPassword'
],
],
];
Replace the auth part with API and give it your key and id.
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
'api' => [
'id' => 'myId',
'key' => 'myKey'
],
],
];
From Elastic 8 and upwards TLS is becoming the default, even in development. This means you will need to verify the CA. You can set the ssl.verify
config key to the path of the CA, or to false
to disable verification altogether.
Warning Disabling CA verification on production is not recommended.
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
'ssl' => [
'verify' => './path/to/ca.crt',
],
],
];
To disable TLS verification set it to false
. NOT recommended for production.
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
'ssl' => [
'verify' => false,
],
],
];
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'https',
'ssl' => [
'cert' => ['path/to/cert.pem', 'passphrase'],
'key' => ['path/to/key.pem', 'passphrase'],
],
],
];
Elastic can also have multiple possible connections
use Elasticsearch\ConnectionPool\Selectors\RoundRobinSelector;
return [
'connection' => [
'host' => 'localhost',
'port' => '9200',
'scheme' => 'http',
'ssl' => [
'verify' => false,
],
'selector' => RoundRobinSelector::class
],
'additionalConnections' => [
[
'host' => 'localhost',
'port' => '9201',
'scheme' => 'http',
],
[
'host' => 'localhost',
'port' => '9202',
'scheme' => 'http',
]
],
];