Skip to content

Commit 60ec3b1

Browse files
committed
[API] Adds back inference.inference endpoint
1 parent b181431 commit 60ec3b1

File tree

2 files changed

+109
-0
lines changed

2 files changed

+109
-0
lines changed
Lines changed: 73 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,73 @@
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+
# This code was automatically generated from the Elasticsearch Specification
19+
# See https://github.com/elastic/elasticsearch-specification
20+
# See Elasticsearch::ES_SPECIFICATION_COMMIT for commit hash.
21+
module Elasticsearch
22+
module API
23+
module Inference
24+
module Actions
25+
# Perform inference on the service.
26+
# This API enables you to use machine learning models to perform specific tasks on data that you provide as an input.
27+
# It returns a response with the results of the tasks.
28+
# The inference endpoint you use can perform one specific task that has been defined when the endpoint was created with the create inference API.
29+
# For details about using this API with a service, such as Amazon Bedrock, Anthropic, or HuggingFace, refer to the service-specific documentation.
30+
#
31+
# @option arguments [String] :task_type The type of inference task that the model performs.
32+
# @option arguments [String] :inference_id The unique identifier for the inference endpoint. (*Required*)
33+
# @option arguments [Time] :timeout The amount of time to wait for the inference request to complete. Server default: 30s.
34+
# @option arguments [Hash] :headers Custom HTTP headers
35+
# @option arguments [Hash] :body request body
36+
#
37+
# @see https://www.elastic.co/docs/api/doc/elasticsearch/operation/operation-inference-inference
38+
#
39+
def inference(arguments = {})
40+
request_opts = { endpoint: arguments[:endpoint] || 'inference.inference' }
41+
42+
defined_params = [:inference_id, :task_type].each_with_object({}) do |variable, set_variables|
43+
set_variables[variable] = arguments[variable] if arguments.key?(variable)
44+
end
45+
request_opts[:defined_params] = defined_params unless defined_params.empty?
46+
47+
raise ArgumentError, "Required argument 'inference_id' missing" unless arguments[:inference_id]
48+
49+
arguments = arguments.clone
50+
headers = arguments.delete(:headers) || {}
51+
52+
body = arguments.delete(:body)
53+
54+
_task_type = arguments.delete(:task_type)
55+
56+
_inference_id = arguments.delete(:inference_id)
57+
58+
method = Elasticsearch::API::HTTP_POST
59+
path = if _task_type && _inference_id
60+
"_inference/#{Utils.listify(_task_type)}/#{Utils.listify(_inference_id)}"
61+
else
62+
"_inference/#{Utils.listify(_inference_id)}"
63+
end
64+
params = Utils.process_params(arguments)
65+
66+
Elasticsearch::API::Response.new(
67+
perform_request(method, path, params, body, headers, request_opts)
68+
)
69+
end
70+
end
71+
end
72+
end
73+
end
Lines changed: 36 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
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#inference.inference' do
21+
let(:expected_args) do
22+
[
23+
'POST',
24+
'_inference/bar',
25+
{},
26+
nil,
27+
{},
28+
{ defined_params: { inference_id: 'bar' },
29+
endpoint: 'inference.inference' }
30+
]
31+
end
32+
33+
it 'performs the request' do
34+
expect(client_double.inference.inference(inference_id: 'bar')).to be_a Elasticsearch::API::Response
35+
end
36+
end

0 commit comments

Comments
 (0)