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 ShutdownNamespace
23 *
24 * NOTE: this file is autogenerated using util/GenerateEndpoints.php
25 * and Elasticsearch 7.16.0-SNAPSHOT (dfc9a8e7563ed5f24b5210ed21ed92ae182cd0ee)
26 */
27class ShutdownNamespace extends AbstractNamespace
28{
29
30    /**
31     * Removes a node from the shutdown list
32     *
33     * $params['node_id'] = (string) The node id of node to be removed from the shutdown state
34     *
35     * @param array $params Associative array of parameters
36     * @return array
37     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current
38     *
39     * @note This API is EXPERIMENTAL and may be changed or removed completely in a future release
40     *
41     */
42    public function deleteNode(array $params = [])
43    {
44        $node_id = $this->extractArgument($params, 'node_id');
45
46        $endpointBuilder = $this->endpoints;
47        $endpoint = $endpointBuilder('Shutdown\DeleteNode');
48        $endpoint->setParams($params);
49        $endpoint->setNodeId($node_id);
50
51        return $this->performRequest($endpoint);
52    }
53    /**
54     * Retrieve status of a node or nodes that are currently marked as shutting down
55     *
56     * $params['node_id'] = (string) Which node for which to retrieve the shutdown status
57     *
58     * @param array $params Associative array of parameters
59     * @return array
60     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current
61     *
62     * @note This API is EXPERIMENTAL and may be changed or removed completely in a future release
63     *
64     */
65    public function getNode(array $params = [])
66    {
67        $node_id = $this->extractArgument($params, 'node_id');
68
69        $endpointBuilder = $this->endpoints;
70        $endpoint = $endpointBuilder('Shutdown\GetNode');
71        $endpoint->setParams($params);
72        $endpoint->setNodeId($node_id);
73
74        return $this->performRequest($endpoint);
75    }
76    /**
77     * Adds a node to be shut down
78     *
79     * $params['node_id'] = (string) The node id of node to be shut down
80     * $params['body']    = (array) The shutdown type definition to register (Required)
81     *
82     * @param array $params Associative array of parameters
83     * @return array
84     * @see https://www.elastic.co/guide/en/elasticsearch/reference/current
85     *
86     * @note This API is EXPERIMENTAL and may be changed or removed completely in a future release
87     *
88     */
89    public function putNode(array $params = [])
90    {
91        $node_id = $this->extractArgument($params, 'node_id');
92        $body = $this->extractArgument($params, 'body');
93
94        $endpointBuilder = $this->endpoints;
95        $endpoint = $endpointBuilder('Shutdown\PutNode');
96        $endpoint->setParams($params);
97        $endpoint->setNodeId($node_id);
98        $endpoint->setBody($body);
99
100        return $this->performRequest($endpoint);
101    }
102}
103