Skip to content

Commit 8b07efc

Browse files
committed
[API] Adds security user_profile APIs and oidc
1 parent 4c85356 commit 8b07efc

12 files changed

+556
-0
lines changed
Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Creates or updates the user profile on behalf of another user.
23+
# This functionality is Experimental and may be changed or removed
24+
# completely in a future release. Elastic will take a best effort approach
25+
# to fix any issues, but experimental features are not subject to the
26+
# support SLA of official GA features.
27+
#
28+
# @option arguments [Hash] :headers Custom HTTP headers
29+
# @option arguments [Hash] :body The grant type and user's credential (*Required*)
30+
#
31+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-activate-user-profile.html
32+
#
33+
def activate_user_profile(arguments = {})
34+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
35+
36+
headers = arguments.delete(:headers) || {}
37+
38+
body = arguments.delete(:body)
39+
40+
arguments = arguments.clone
41+
42+
method = Elasticsearch::API::HTTP_POST
43+
path = "_security/profile/_activate"
44+
params = {}
45+
46+
Elasticsearch::API::Response.new(
47+
perform_request(method, path, params, body, headers)
48+
)
49+
end
50+
end
51+
end
52+
end
53+
end
Lines changed: 56 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,56 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Retrieves user profile for the given unique ID.
23+
# This functionality is Experimental and may be changed or removed
24+
# completely in a future release. Elastic will take a best effort approach
25+
# to fix any issues, but experimental features are not subject to the
26+
# support SLA of official GA features.
27+
#
28+
# @option arguments [String] :uid An unique identifier of the user profile
29+
# @option arguments [List] :data A comma-separated list of keys for which the corresponding application data are retrieved.
30+
# @option arguments [Hash] :headers Custom HTTP headers
31+
#
32+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-get-user-profile.html
33+
#
34+
def get_user_profile(arguments = {})
35+
raise ArgumentError, "Required argument 'uid' missing" unless arguments[:uid]
36+
37+
headers = arguments.delete(:headers) || {}
38+
39+
body = nil
40+
41+
arguments = arguments.clone
42+
43+
_uid = arguments.delete(:uid)
44+
45+
method = Elasticsearch::API::HTTP_GET
46+
path = "_security/profile/#{Utils.__listify(_uid)}"
47+
params = Utils.process_params(arguments)
48+
49+
Elasticsearch::API::Response.new(
50+
perform_request(method, path, params, body, headers)
51+
)
52+
end
53+
end
54+
end
55+
end
56+
end
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Exchanges an OpenID Connection authentication response message for an Elasticsearch access token and refresh token pair
23+
#
24+
# @option arguments [Hash] :headers Custom HTTP headers
25+
# @option arguments [Hash] :body The OpenID Connect response to authenticate (*Required*)
26+
#
27+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-oidc-authenticate.html
28+
#
29+
def oidc_authenticate(arguments = {})
30+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
31+
32+
headers = arguments.delete(:headers) || {}
33+
34+
body = arguments.delete(:body)
35+
36+
arguments = arguments.clone
37+
38+
method = Elasticsearch::API::HTTP_POST
39+
path = "_security/oidc/authenticate"
40+
params = {}
41+
42+
Elasticsearch::API::Response.new(
43+
perform_request(method, path, params, body, headers)
44+
)
45+
end
46+
end
47+
end
48+
end
49+
end
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Invalidates a refresh token and access token that was generated from the OpenID Connect Authenticate API
23+
#
24+
# @option arguments [Hash] :headers Custom HTTP headers
25+
# @option arguments [Hash] :body Access token and refresh token to invalidate (*Required*)
26+
#
27+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-oidc-logout.html
28+
#
29+
def oidc_logout(arguments = {})
30+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
31+
32+
headers = arguments.delete(:headers) || {}
33+
34+
body = arguments.delete(:body)
35+
36+
arguments = arguments.clone
37+
38+
method = Elasticsearch::API::HTTP_POST
39+
path = "_security/oidc/logout"
40+
params = {}
41+
42+
Elasticsearch::API::Response.new(
43+
perform_request(method, path, params, body, headers)
44+
)
45+
end
46+
end
47+
end
48+
end
49+
end
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Creates an OAuth 2.0 authentication request as a URL string
23+
#
24+
# @option arguments [Hash] :headers Custom HTTP headers
25+
# @option arguments [Hash] :body The OpenID Connect authentication realm configuration (*Required*)
26+
#
27+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-oidc-prepare-authentication.html
28+
#
29+
def oidc_prepare_authentication(arguments = {})
30+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
31+
32+
headers = arguments.delete(:headers) || {}
33+
34+
body = arguments.delete(:body)
35+
36+
arguments = arguments.clone
37+
38+
method = Elasticsearch::API::HTTP_POST
39+
path = "_security/oidc/prepare"
40+
params = {}
41+
42+
Elasticsearch::API::Response.new(
43+
perform_request(method, path, params, body, headers)
44+
)
45+
end
46+
end
47+
end
48+
end
49+
end
Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
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+
module Elasticsearch
19+
module API
20+
module Security
21+
module Actions
22+
# Update application specific data for the user profile of the given unique ID.
23+
# This functionality is Experimental and may be changed or removed
24+
# completely in a future release. Elastic will take a best effort approach
25+
# to fix any issues, but experimental features are not subject to the
26+
# support SLA of official GA features.
27+
#
28+
# @option arguments [String] :uid An unique identifier of the user profile
29+
# @option arguments [Number] :if_seq_no only perform the update operation if the last operation that has changed the document has the specified sequence number
30+
# @option arguments [Number] :if_primary_term only perform the update operation if the last operation that has changed the document has the specified primary term
31+
# @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)
32+
# @option arguments [Hash] :headers Custom HTTP headers
33+
# @option arguments [Hash] :body The application data to update (*Required*)
34+
#
35+
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/security-api-update-user-profile-data.html
36+
#
37+
def update_user_profile_data(arguments = {})
38+
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
39+
raise ArgumentError, "Required argument 'uid' missing" unless arguments[:uid]
40+
41+
headers = arguments.delete(:headers) || {}
42+
43+
body = arguments.delete(:body)
44+
45+
arguments = arguments.clone
46+
47+
_uid = arguments.delete(:uid)
48+
49+
method = Elasticsearch::API::HTTP_POST
50+
path = "_security/profile/_data/#{Utils.__listify(_uid)}"
51+
params = Utils.process_params(arguments)
52+
53+
Elasticsearch::API::Response.new(
54+
perform_request(method, path, params, body, headers)
55+
)
56+
end
57+
end
58+
end
59+
end
60+
end
Lines changed: 40 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,40 @@
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 'test_helper'
19+
20+
module Elasticsearch
21+
module Test
22+
class SecurityAuthenticateTest < Minitest::Test
23+
context 'Security: Activate User Profile' do
24+
subject { FakeClient.new }
25+
26+
should 'perform correct request' do
27+
subject.expects(:perform_request).with do |method, url, params, body|
28+
assert_equal('POST', method)
29+
assert_equal('_security/profile/_activate', url)
30+
assert_equal({}, params)
31+
assert_equal(body, {})
32+
true
33+
end.returns(FakeResponse.new)
34+
35+
subject.security.activate_user_profile(body: {})
36+
end
37+
end
38+
end
39+
end
40+
end

0 commit comments

Comments
 (0)