Skip to content

Commit 9a8db77

Browse files
committed
[API] Adds security.bulk_delete_role
1 parent 1751868 commit 9a8db77

File tree

2 files changed

+89
-0
lines changed

2 files changed

+89
-0
lines changed
Lines changed: 54 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
# Licensed to Elasticsearch B.V. under one or more contributor
2+
# license agreements. See the NOTICE file distributed with
3+
# this work for additional information regarding copyright
4+
# ownership. Elasticsearch B.V. licenses this file to you under
5+
# the Apache License, Version 2.0 (the "License"); you may
6+
# not use this file except in compliance with the License.
7+
# You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
#
18+
# Auto generated from build hash f284cc16f4d4b4289bc679aa1529bb504190fe80
19+
# @see https://github.com/elastic/elasticsearch/tree/main/rest-api-spec
20+
#
21+
module Elasticsearch
22+
module API
23+
module Security
24+
module Actions
25+
# Bulk delete roles in the native realm.
26+
#
27+
# @option arguments [String] :refresh If `true` (the default) then refresh the affected shards to make this operation visible to search, if `wait_for` then wait for a refresh to make this operation visible to search, if `false` then do nothing with refreshes. (options: true, false, wait_for)
28+
# @option arguments [Hash] :headers Custom HTTP headers
29+
# @option arguments [Hash] :body The roles to delete (*Required*)
30+
#
31+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-bulk-delete-role.html
32+
#
33+
def bulk_delete_role(arguments = {})
34+
request_opts = { endpoint: arguments[:endpoint] || 'security.bulk_delete_role' }
35+
36+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
37+
38+
arguments = arguments.clone
39+
headers = arguments.delete(:headers) || {}
40+
41+
body = arguments.delete(:body)
42+
43+
method = Elasticsearch::API::HTTP_DELETE
44+
path = '_security/role'
45+
params = Utils.process_params(arguments)
46+
47+
Elasticsearch::API::Response.new(
48+
perform_request(method, path, params, body, headers, request_opts)
49+
)
50+
end
51+
end
52+
end
53+
end
54+
end
Lines changed: 35 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
# Licensed to Elasticsearch B.V. under one or more contributor
2+
# license agreements. See the NOTICE file distributed with
3+
# this work for additional information regarding copyright
4+
# ownership. Elasticsearch B.V. licenses this file to you under
5+
# the Apache License, Version 2.0 (the "License"); you may
6+
# not use this file except in compliance with the License.
7+
# You may obtain a copy of the License at
8+
#
9+
# http://www.apache.org/licenses/LICENSE-2.0
10+
#
11+
# Unless required by applicable law or agreed to in writing,
12+
# software distributed under the License is distributed on an
13+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14+
# KIND, either express or implied. See the License for the
15+
# specific language governing permissions and limitations
16+
# under the License.
17+
18+
require 'spec_helper'
19+
20+
describe 'client#security.bulk_delete_role' do
21+
let(:expected_args) do
22+
[
23+
'DELETE',
24+
'_security/role',
25+
{},
26+
{},
27+
{},
28+
{ endpoint: 'security.bulk_delete_role' }
29+
]
30+
end
31+
32+
it 'performs the request' do
33+
expect(client_double.security.bulk_delete_role(body: {})).to be_a Elasticsearch::API::Response
34+
end
35+
end

0 commit comments

Comments
 (0)