talk_api 0.1.0 → 0.1.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/talk_api.rb +2 -1
- data/lib/talk_api/error.rb +9 -0
- data/lib/talk_api/request.rb +11 -6
- data/lib/talk_api/response.rb +4 -8
- data/lib/talk_api/version.rb +1 -1
- metadata +2 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 481d0c159cc909a65f6607790ccebc54bfd162b76664223f5578dd2797b4ad1e
|
4
|
+
data.tar.gz: 469f736d710749edbbe32071cb658f5087e72af5c6245833bea7c98034b03494
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 99172dfaf4d6b191bb237d97301fba42f065fd5bbcb8c86366170c8473b485b822e1a4dc376420b9f4a297c31215d1cddad13c669e343578a2f0070b40a1276b
|
7
|
+
data.tar.gz: 571871da3d4a8dec932f0e667ce6ad8967950e4e96abdb3e0c273ccfa8af3e2ee75f2738101b201341756aaa8e77a077924dff9ff0ce0d49c1ac7127a7085c19
|
data/lib/talk_api.rb
CHANGED
data/lib/talk_api/request.rb
CHANGED
@@ -1,21 +1,26 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
require 'httpclient'
|
4
|
+
require 'json'
|
4
5
|
|
5
6
|
module TalkApi
|
6
7
|
# API request class
|
7
8
|
class Request
|
8
|
-
ENDPOINT_URL = 'https://api.a3rt.recruit-tech.co.jp/talk/v1/smalltalk'
|
9
|
-
USER_AGENT = "#{self} #{VERSION}".freeze
|
9
|
+
ENDPOINT_URL = 'https://api.a3rt.recruit-tech.co.jp/talk/v1/smalltalk'
|
10
10
|
HEADERS = [
|
11
|
-
['User-Agent',
|
11
|
+
['User-Agent', "#{self}/#{VERSION}"]
|
12
12
|
].freeze
|
13
13
|
|
14
14
|
def call(api_key, message)
|
15
15
|
query = message.byteslice(0, 2048).scrub('')
|
16
|
-
|
17
|
-
|
18
|
-
|
16
|
+
begin
|
17
|
+
client = HTTPClient.new
|
18
|
+
response = client.post(ENDPOINT_URL, { apikey: api_key, query: query }, header: HEADERS)
|
19
|
+
rescue StandardError => e
|
20
|
+
raise HTTPError, e.message
|
21
|
+
end
|
22
|
+
json = JSON.parse(response.body, symbolize_names: true)
|
23
|
+
Response.new(json[:status], json[:message], json[:results])
|
19
24
|
end
|
20
25
|
end
|
21
26
|
end
|
data/lib/talk_api/response.rb
CHANGED
@@ -1,18 +1,14 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
|
-
require 'json'
|
4
|
-
|
5
3
|
module TalkApi
|
6
4
|
# Response class
|
7
5
|
class Response
|
8
6
|
attr_reader :status, :message, :results
|
9
7
|
|
10
|
-
def initialize(
|
11
|
-
|
12
|
-
|
13
|
-
@
|
14
|
-
@message = json.key?(:message) ? json[:message] : nil
|
15
|
-
@results = json[:results].map { |result| Result.new(result[:perplexity], result[:reply]) } if success?
|
8
|
+
def initialize(status, message, results = [])
|
9
|
+
@status = status
|
10
|
+
@message = message
|
11
|
+
@results = results.map { |result| Result.new(result[:perplexity], result[:reply]) } if success?
|
16
12
|
end
|
17
13
|
|
18
14
|
def success?
|
data/lib/talk_api/version.rb
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: talk_api
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ryo Nakano
|
@@ -42,6 +42,7 @@ files:
|
|
42
42
|
- bin/setup
|
43
43
|
- lib/talk_api.rb
|
44
44
|
- lib/talk_api/client.rb
|
45
|
+
- lib/talk_api/error.rb
|
45
46
|
- lib/talk_api/request.rb
|
46
47
|
- lib/talk_api/response.rb
|
47
48
|
- lib/talk_api/result.rb
|