diff --git a/config/elasticsearch.php b/config/elasticsearch.php index 9a4a1dd9..58c3a91b 100644 --- a/config/elasticsearch.php +++ b/config/elasticsearch.php @@ -2,6 +2,10 @@ return [ 'host' => env('ELASTICSEARCH_HOST'), + 'user' => env('ELASTICSEARCH_USER'), + 'password' => env('ELASTICSEARCH_PASSWORD'), + 'cloud_id' => env('ELASTICSEARCH_CLOUD_ID'), + 'api_key' => env('ELASTICSEARCH_API_KEY'), 'indices' => [ 'mappings' => [ 'default' => [ diff --git a/src/ElasticSearch/Config/Config.php b/src/ElasticSearch/Config/Config.php index cb2de016..f892eefd 100644 --- a/src/ElasticSearch/Config/Config.php +++ b/src/ElasticSearch/Config/Config.php @@ -4,6 +4,10 @@ /** * @method static array hosts() + * @method static user() + * @method static password() + * @method static elasticCloudId() + * @method static apiKey() */ class Config { diff --git a/src/ElasticSearch/Config/Storage.php b/src/ElasticSearch/Config/Storage.php index ef10cd6a..d583c5c9 100644 --- a/src/ElasticSearch/Config/Storage.php +++ b/src/ElasticSearch/Config/Storage.php @@ -31,6 +31,38 @@ public function hosts(): array return explode(',', $this->loadConfig('host')); } + /** + * @return ?string + */ + public function user(): ?string + { + return $this->loadConfig('user'); + } + + /** + * @return ?string + */ + public function password(): ?string + { + return $this->loadConfig('password'); + } + + /** + * @return ?string + */ + public function elasticCloudId(): ?string + { + return $this->loadConfig('cloud_id'); + } + + /** + * @return ?string + */ + public function apiKey(): ?string + { + return $this->loadConfig('api_key'); + } + /** * @param string $path * @return mixed diff --git a/src/ElasticSearchServiceProvider.php b/src/ElasticSearchServiceProvider.php index ddee3e7e..6fb5dd87 100644 --- a/src/ElasticSearchServiceProvider.php +++ b/src/ElasticSearchServiceProvider.php @@ -8,6 +8,8 @@ use Elastic\Elasticsearch\ClientBuilder; use Illuminate\Support\ServiceProvider; use Matchish\ScoutElasticSearch\ElasticSearch\Config\Config; +use Matchish\ScoutElasticSearch\ElasticSearch\EloquentHitsIteratorAggregate; +use Matchish\ScoutElasticSearch\ElasticSearch\HitsIteratorAggregate; final class ElasticSearchServiceProvider extends ServiceProvider { @@ -19,12 +21,22 @@ public function register(): void $this->mergeConfigFrom(__DIR__.'/../config/elasticsearch.php', 'elasticsearch'); $this->app->bind(Client::class, function () { - return ClientBuilder::create()->setHosts(Config::hosts())->build(); + $clientBuilder = ClientBuilder::create()->setHosts(Config::hosts()); + if ($user = Config::user()) { + $clientBuilder->setBasicAuthentication($user, Config::password()); + } + + if ($cloudId = Config::elasticCloudId()) { + $clientBuilder->setElasticCloudId($cloudId) + ->setApiKey(Config::apiKey()); + } + + return $clientBuilder->build(); }); $this->app->bind( - 'Matchish\ScoutElasticSearch\ElasticSearch\HitsIteratorAggregate', - 'Matchish\ScoutElasticSearch\ElasticSearch\EloquentHitsIteratorAggregate' + HitsIteratorAggregate::class, + EloquentHitsIteratorAggregate::class ); } diff --git a/tests/Unit/ElasticSearch/Config/ConfigTest.php b/tests/Unit/ElasticSearch/Config/ConfigTest.php new file mode 100644 index 00000000..d45ce9e7 --- /dev/null +++ b/tests/Unit/ElasticSearch/Config/ConfigTest.php @@ -0,0 +1,48 @@ +assertEquals(['http://localhost:9200'], $config::hosts()); + } + + public function test_parse_multihost(): void + { + Config::set('elasticsearch.host', 'http://localhost:9200,http://localhost:9201'); + + $config = new ScoutConfig(); + $this->assertEquals(['http://localhost:9200', 'http://localhost:9201'], $config::hosts()); + } + + public function test_parse_username_password(): void + { + Config::set('elasticsearch.host', 'http://localhost:9200,http://localhost:9201'); + Config::set('elasticsearch.user', 'elastic'); + Config::set('elasticsearch.password', 'pass'); + + $config = new ScoutConfig(); + $this->assertEquals('elastic', $config::user()); + $this->assertEquals('pass', $config::password()); + } + + public function test_parse_elastic_cloud_id(): void + { + Config::set('elasticsearch.host', 'http://localhost:9200,http://localhost:9201'); + Config::set('elasticsearch.cloud_id', 'cloud-id'); + Config::set('elasticsearch.api_key', '123456'); + + $config = new ScoutConfig(); + $this->assertEquals('cloud-id', $config::elasticCloudId()); + $this->assertEquals('123456', $config::apiKey()); + } +}