1<?php
2/**
3 * Elasticsearch PHP client
4 *
5 * @link      https://github.com/elastic/elasticsearch-php/
6 * @copyright Copyright (c) Elasticsearch B.V (https://www.elastic.co)
7 * @license   http://www.apache.org/licenses/LICENSE-2.0 Apache License, Version 2.0
8 * @license   https://www.gnu.org/licenses/lgpl-2.1.html GNU Lesser General Public License, Version 2.1
9 *
10 * Licensed to Elasticsearch B.V under one or more agreements.
11 * Elasticsearch B.V licenses this file to you under the Apache 2.0 License or
12 * the GNU Lesser General Public License, Version 2.1, at your option.
13 * See the LICENSE file in the project root for more information.
14 */
15declare(strict_types = 1);
16
17namespace Elasticsearch\Namespaces;
18
19use Elasticsearch\Namespaces\AbstractNamespace;
20
21/**
22 * Class LogstashNamespace
23 *
24 * NOTE: this file is autogenerated using util/GenerateEndpoints.php
25 * and Elasticsearch 7.16.0-SNAPSHOT (dfc9a8e7563ed5f24b5210ed21ed92ae182cd0ee)
26 */
27class LogstashNamespace extends AbstractNamespace
28{
29
30    /**
31     * Deletes Logstash Pipelines used by Central Management
32     *
33     * $params['id'] = (string) The ID of the Pipeline
34     *
35     * @param array $params Associative array of parameters
36     * @return array
37     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current/logstash-api-delete-pipeline.html
38     */
39    public function deletePipeline(array $params = [])
40    {
41        $id = $this->extractArgument($params, 'id');
42
43        $endpointBuilder = $this->endpoints;
44        $endpoint = $endpointBuilder('Logstash\DeletePipeline');
45        $endpoint->setParams($params);
46        $endpoint->setId($id);
47
48        return $this->performRequest($endpoint);
49    }
50    /**
51     * Retrieves Logstash Pipelines used by Central Management
52     *
53     * $params['id'] = (string) A comma-separated list of Pipeline IDs
54     *
55     * @param array $params Associative array of parameters
56     * @return array
57     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current/logstash-api-get-pipeline.html
58     */
59    public function getPipeline(array $params = [])
60    {
61        $id = $this->extractArgument($params, 'id');
62
63        $endpointBuilder = $this->endpoints;
64        $endpoint = $endpointBuilder('Logstash\GetPipeline');
65        $endpoint->setParams($params);
66        $endpoint->setId($id);
67
68        return $this->performRequest($endpoint);
69    }
70    /**
71     * Adds and updates Logstash Pipelines used for Central Management
72     *
73     * $params['id']   = (string) The ID of the Pipeline
74     * $params['body'] = (array) The Pipeline to add or update (Required)
75     *
76     * @param array $params Associative array of parameters
77     * @return array
78     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current/logstash-api-put-pipeline.html
79     */
80    public function putPipeline(array $params = [])
81    {
82        $id = $this->extractArgument($params, 'id');
83        $body = $this->extractArgument($params, 'body');
84
85        $endpointBuilder = $this->endpoints;
86        $endpoint = $endpointBuilder('Logstash\PutPipeline');
87        $endpoint->setParams($params);
88        $endpoint->setId($id);
89        $endpoint->setBody($body);
90
91        return $this->performRequest($endpoint);
92    }
93}
94