lark-sdk 1.0.16 → 1.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/README.md +9 -8
- data/Rakefile +4 -0
- data/lark.gemspec +3 -3
- data/lib/lark.rb +0 -2
- data/lib/lark/api.rb +15 -14
- data/lib/lark/apis/application.rb +1 -1
- data/lib/lark/apis/authen.rb +3 -3
- data/lib/lark/apis/image.rb +2 -2
- data/lib/lark/apis/pay.rb +2 -2
- data/lib/lark/apis/search.rb +16 -0
- data/lib/lark/config.rb +8 -2
- data/lib/lark/request.rb +17 -11
- data/lib/lark/version.rb +1 -1
- metadata +7 -6
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 7f85b0fe40fd06b6433cc6e3d5d2dfb324fc8587054e3e5338a0bcc255eae20d
|
|
4
|
+
data.tar.gz: 978dffe16def339df6de1459bb8a7ea21adea598cee7b864b649c21a051549f1
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 5379f843398ca53a26fdd905bbff9a4f1a98872c8f655ca574881da048c56334832965424d8339986ec96718de0ab6f3e8b8b3581deee32ff2c27604be72e499
|
|
7
|
+
data.tar.gz: b23e6499d47d352caa05eeef4de1baa1943347fce24b65143c369eff59b274a472e5f966b0a2ac0c4e2770aef6f2b45b1fd433af6a2d7650ef94b999f5f30a48
|
data/README.md
CHANGED
|
@@ -12,13 +12,13 @@ gem 'lark-sdk'
|
|
|
12
12
|
|
|
13
13
|
And then execute:
|
|
14
14
|
|
|
15
|
-
|
|
15
|
+
$ bundle install
|
|
16
16
|
|
|
17
17
|
Or install it yourself as:
|
|
18
18
|
|
|
19
|
-
|
|
19
|
+
$ gem install lark-sdk
|
|
20
20
|
|
|
21
|
-
|
|
21
|
+
require 'lark/sdk'
|
|
22
22
|
|
|
23
23
|
## 使用
|
|
24
24
|
|
|
@@ -32,6 +32,7 @@ Lark.configure do |config|
|
|
|
32
32
|
config.default_app_id = 'xxx' # 应用 app ID
|
|
33
33
|
config.default_app_secret = 'xxx' # 应用 app secret
|
|
34
34
|
config.default_isv = true # 自建应用: false, 应用商店应用: true
|
|
35
|
+
config.api_base_url = 'https://open.feishu.cn/open-apis/' # API 地址,默认:https://open.feishu.cn/open-apis/
|
|
35
36
|
# ...
|
|
36
37
|
end
|
|
37
38
|
```
|
|
@@ -40,10 +41,10 @@ end
|
|
|
40
41
|
|
|
41
42
|
```ruby
|
|
42
43
|
api = Lark::Api.new(
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
44
|
+
app_id: 'xxx', # default: Lark.config.default_app_id
|
|
45
|
+
app_secret: 'xxx', # default: Lark.config.default_app_secret
|
|
46
|
+
isv: false/true, # default: Lark.config.default_app_secret
|
|
47
|
+
tenant_key: 'xxx' # required while internal app
|
|
47
48
|
)
|
|
48
49
|
```
|
|
49
50
|
|
|
@@ -60,7 +61,7 @@ cipher.decrypt(message)
|
|
|
60
61
|
cipher.encrypt(message)
|
|
61
62
|
```
|
|
62
63
|
|
|
63
|
-
[Api 列表](https://github.com/
|
|
64
|
+
[Api 列表](https://github.com/seandong/lark-ruby-sdk/wiki/apis)
|
|
64
65
|
|
|
65
66
|
|
|
66
67
|
## 贡献
|
data/Rakefile
CHANGED
data/lark.gemspec
CHANGED
|
@@ -8,15 +8,15 @@ Gem::Specification.new do |spec|
|
|
|
8
8
|
|
|
9
9
|
spec.summary = %q{Lark(飞书) API SDKs for ruby}
|
|
10
10
|
spec.description = %q{Lark(飞书) API SDKs for ruby https://open.feishu.cn}
|
|
11
|
-
spec.homepage = "https://github.com/
|
|
11
|
+
spec.homepage = "https://github.com/seandong/lark-ruby-sdk"
|
|
12
12
|
spec.license = "MIT"
|
|
13
13
|
spec.required_ruby_version = Gem::Requirement.new(">= 2.3.0")
|
|
14
14
|
|
|
15
15
|
spec.metadata["allowed_push_host"] = "https://rubygems.org/"
|
|
16
16
|
|
|
17
17
|
spec.metadata["homepage_uri"] = spec.homepage
|
|
18
|
-
spec.metadata["source_code_uri"] = "https://github.com/
|
|
19
|
-
spec.metadata["changelog_uri"] = "https://github.com/
|
|
18
|
+
spec.metadata["source_code_uri"] = "https://github.com/seandong/lark-ruby-sdk"
|
|
19
|
+
spec.metadata["changelog_uri"] = "https://github.com/seandong/lark-ruby-sdk"
|
|
20
20
|
|
|
21
21
|
# Specify which files should be added to the gem when it is released.
|
|
22
22
|
# The `git ls-files -z` loads the files in the RubyGem that have been added into git.
|
data/lib/lark.rb
CHANGED
|
@@ -11,8 +11,6 @@ Dir["#{lib_path}/apis/**/*.rb", "#{lib_path}/token_store/*.rb"].each { |path| r
|
|
|
11
11
|
require 'lark/api'
|
|
12
12
|
|
|
13
13
|
module Lark
|
|
14
|
-
API_BASE_URL = 'https://open.feishu.cn/open-apis/'.freeze
|
|
15
|
-
|
|
16
14
|
# Exceptions
|
|
17
15
|
class RedisNotConfigException < RuntimeError; end
|
|
18
16
|
class AppNotConfigException < RuntimeError; end
|
data/lib/lark/api.rb
CHANGED
|
@@ -8,6 +8,7 @@ module Lark
|
|
|
8
8
|
api_mount :authen
|
|
9
9
|
api_mount :contact
|
|
10
10
|
api_mount :user
|
|
11
|
+
api_mount :search
|
|
11
12
|
api_mount :application
|
|
12
13
|
api_mount :pay
|
|
13
14
|
api_mount :chat
|
|
@@ -23,7 +24,7 @@ module Lark
|
|
|
23
24
|
|
|
24
25
|
attr_reader :app_id, :app_secret, :tenant_key, :isv, :options
|
|
25
26
|
|
|
26
|
-
def initialize
|
|
27
|
+
def initialize(options = {})
|
|
27
28
|
@app_id = options.delete(:app_id) || Lark.config.default_app_id
|
|
28
29
|
@app_secret = options.delete(:app_secret) || Lark.config.default_app_secret
|
|
29
30
|
raise AppNotConfigException if @app_id.nil? || @app_id.empty?
|
|
@@ -38,29 +39,29 @@ module Lark
|
|
|
38
39
|
end
|
|
39
40
|
|
|
40
41
|
def request
|
|
41
|
-
@request ||= Lark::Request.new
|
|
42
|
+
@request ||= Lark::Request.new
|
|
42
43
|
end
|
|
43
44
|
|
|
44
|
-
def get(path, headers={})
|
|
45
|
-
with_token(headers) do |
|
|
46
|
-
request.get path,
|
|
45
|
+
def get(path, headers = {})
|
|
46
|
+
with_token(headers) do |headers_with_token|
|
|
47
|
+
request.get path, headers_with_token
|
|
47
48
|
end
|
|
48
49
|
end
|
|
49
50
|
|
|
50
|
-
def post(path, payload, headers={})
|
|
51
|
-
with_token(headers) do |
|
|
52
|
-
request.post path, payload,
|
|
51
|
+
def post(path, payload, headers = {})
|
|
52
|
+
with_token(headers) do |headers_with_token|
|
|
53
|
+
request.post path, payload, headers_with_token
|
|
53
54
|
end
|
|
54
55
|
end
|
|
55
56
|
|
|
56
|
-
def post_file(path, file, headers={})
|
|
57
|
-
with_token(headers) do |
|
|
58
|
-
request.post_file path, file,
|
|
57
|
+
def post_file(path, file, headers = {})
|
|
58
|
+
with_token(headers) do |headers_with_token|
|
|
59
|
+
request.post_file path, file, headers_with_token
|
|
59
60
|
end
|
|
60
61
|
end
|
|
61
62
|
|
|
62
|
-
def app_ticket=
|
|
63
|
-
Lark.redis.set "APP_TICKET_#{app_id}",
|
|
63
|
+
def app_ticket=(new_ticket)
|
|
64
|
+
Lark.redis.set "APP_TICKET_#{app_id}", new_ticket
|
|
64
65
|
end
|
|
65
66
|
|
|
66
67
|
def app_ticket
|
|
@@ -91,7 +92,7 @@ module Lark
|
|
|
91
92
|
@tenant_token_store = klass.new(self)
|
|
92
93
|
end
|
|
93
94
|
|
|
94
|
-
def with_token(headers, tries=2)
|
|
95
|
+
def with_token(headers, tries = 2)
|
|
95
96
|
token = headers[:access_token]
|
|
96
97
|
if token.nil?
|
|
97
98
|
via = headers[:via] || 'tenant'
|
data/lib/lark/apis/authen.rb
CHANGED
|
@@ -5,7 +5,7 @@ module Lark
|
|
|
5
5
|
module Authen
|
|
6
6
|
def index(redirect_uri, state)
|
|
7
7
|
uri = ERB::Util.url_encode(redirect_uri)
|
|
8
|
-
"#{URI
|
|
8
|
+
"#{URI.join(Lark.api_base_url, 'authen/v1/index')}?redirect_uri=#{uri}&app_id=#{app_id}&state=#{state}"
|
|
9
9
|
end
|
|
10
10
|
|
|
11
11
|
def access_token(code)
|
|
@@ -25,8 +25,8 @@ module Lark
|
|
|
25
25
|
end
|
|
26
26
|
|
|
27
27
|
def user_info(user_access_token)
|
|
28
|
-
request.get 'authen/v1/user_info', {access_token: user_access_token}
|
|
28
|
+
request.get 'authen/v1/user_info', { access_token: user_access_token }
|
|
29
29
|
end
|
|
30
30
|
end
|
|
31
31
|
end
|
|
32
|
-
end
|
|
32
|
+
end
|
data/lib/lark/apis/image.rb
CHANGED
|
@@ -5,8 +5,8 @@ module Lark
|
|
|
5
5
|
post_file 'image/v4/put/', image, params: { image_type: image_type }
|
|
6
6
|
end
|
|
7
7
|
|
|
8
|
-
def download(image_key)
|
|
9
|
-
get 'image/v4/get', params:
|
|
8
|
+
def download(image_key, params = {})
|
|
9
|
+
get 'image/v4/get', params: params.merge(image_key: image_key), as: :file
|
|
10
10
|
end
|
|
11
11
|
end
|
|
12
12
|
end
|
data/lib/lark/apis/pay.rb
CHANGED
|
@@ -9,11 +9,11 @@ module Lark
|
|
|
9
9
|
end
|
|
10
10
|
|
|
11
11
|
def order_list(params={})
|
|
12
|
-
get 'pay/v1/order/list',
|
|
12
|
+
get 'pay/v1/order/list', params: params
|
|
13
13
|
end
|
|
14
14
|
|
|
15
15
|
def order_get(order_id)
|
|
16
|
-
get 'pay/v1/order/get',
|
|
16
|
+
get 'pay/v1/order/get', params: {order_id: order_id}
|
|
17
17
|
end
|
|
18
18
|
end
|
|
19
19
|
end
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
module Lark
|
|
2
|
+
module Apis
|
|
3
|
+
module Search
|
|
4
|
+
def user(query:, user_access_token:, page_size: 20, page_token: nil)
|
|
5
|
+
get 'search/v1/user', {
|
|
6
|
+
access_token: user_access_token,
|
|
7
|
+
params: {
|
|
8
|
+
query: query,
|
|
9
|
+
page_size: page_size,
|
|
10
|
+
page_token: page_token
|
|
11
|
+
}.compact
|
|
12
|
+
}
|
|
13
|
+
end
|
|
14
|
+
end
|
|
15
|
+
end
|
|
16
|
+
end
|
data/lib/lark/config.rb
CHANGED
|
@@ -23,11 +23,17 @@ module Lark
|
|
|
23
23
|
end
|
|
24
24
|
|
|
25
25
|
def http_timeout_options
|
|
26
|
-
config.http_timeout_options || {write: 2, connect: 5, read: 10}
|
|
26
|
+
config.http_timeout_options || { write: 2, connect: 5, read: 10 }
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def api_base_url
|
|
30
|
+
return @api_base_url if defined?(@api_base_url)
|
|
31
|
+
|
|
32
|
+
@api_base_url = config.api_base_url || 'https://open.feishu.cn/open-apis/'.freeze
|
|
27
33
|
end
|
|
28
34
|
end
|
|
29
35
|
|
|
30
36
|
class Config
|
|
31
|
-
attr_accessor :default_app_id, :default_app_secret, :default_isv, :redis, :http_timeout_options, :logger
|
|
37
|
+
attr_accessor :default_app_id, :default_app_secret, :default_isv, :redis, :http_timeout_options, :logger, :api_base_url
|
|
32
38
|
end
|
|
33
39
|
end
|
data/lib/lark/request.rb
CHANGED
|
@@ -4,14 +4,14 @@ module Lark
|
|
|
4
4
|
class Request
|
|
5
5
|
attr_reader :ssl_context, :http
|
|
6
6
|
|
|
7
|
-
def initialize(skip_verify_ssl=true)
|
|
7
|
+
def initialize(skip_verify_ssl = true)
|
|
8
8
|
@http = HTTP.timeout(**Lark.http_timeout_options)
|
|
9
9
|
@ssl_context = OpenSSL::SSL::SSLContext.new
|
|
10
|
-
|
|
10
|
+
#@ssl_context.ssl_version = :TLSv1_2
|
|
11
11
|
@ssl_context.verify_mode = OpenSSL::SSL::VERIFY_NONE if skip_verify_ssl
|
|
12
12
|
end
|
|
13
13
|
|
|
14
|
-
def get(path, get_header={})
|
|
14
|
+
def get(path, get_header = {})
|
|
15
15
|
request(path, get_header) do |url, header|
|
|
16
16
|
params = header.delete(:params)
|
|
17
17
|
http.headers(header).get(url, params: params, ssl_context: ssl_context)
|
|
@@ -19,7 +19,7 @@ module Lark
|
|
|
19
19
|
end
|
|
20
20
|
alias delete get
|
|
21
21
|
|
|
22
|
-
def post(path, post_body, post_header={})
|
|
22
|
+
def post(path, post_body, post_header = {})
|
|
23
23
|
request(path, post_header) do |url, header|
|
|
24
24
|
Lark.logger.info "payload: #{post_body}"
|
|
25
25
|
params = header.delete(:params)
|
|
@@ -27,7 +27,7 @@ module Lark
|
|
|
27
27
|
end
|
|
28
28
|
end
|
|
29
29
|
|
|
30
|
-
def post_file(path, file, post_header={})
|
|
30
|
+
def post_file(path, file, post_header = {})
|
|
31
31
|
request(path, post_header) do |url, header|
|
|
32
32
|
params = header.delete(:params)
|
|
33
33
|
http.headers(header).post(
|
|
@@ -44,13 +44,18 @@ module Lark
|
|
|
44
44
|
|
|
45
45
|
private
|
|
46
46
|
|
|
47
|
-
def request(path, header={}, &_block)
|
|
48
|
-
url = URI
|
|
49
|
-
|
|
47
|
+
def request(path, header = {}, &_block)
|
|
48
|
+
url = URI.join(Lark.api_base_url, path)
|
|
49
|
+
request_uuid = SecureRandom.uuid
|
|
50
|
+
Lark.logger.info "[#{request_uuid}] request url(#{url}) with headers: #{header}"
|
|
50
51
|
as = header.delete(:as)
|
|
51
52
|
header['Accept'] = 'application/json'
|
|
53
|
+
header['X-Request-ID'] = request_uuid
|
|
52
54
|
response = yield(url, header)
|
|
53
|
-
|
|
55
|
+
unless response.status.success?
|
|
56
|
+
Lark.logger.error "request #{url} happen error: #{response.body}"
|
|
57
|
+
raise ResponseError.new(response.status, response.body)
|
|
58
|
+
end
|
|
54
59
|
handle_response(response, as || :json)
|
|
55
60
|
end
|
|
56
61
|
|
|
@@ -76,7 +81,8 @@ module Lark
|
|
|
76
81
|
Lark.logger.info "response body: #{body}"
|
|
77
82
|
data = JSON.parse body.to_s
|
|
78
83
|
result = Result.new(data)
|
|
79
|
-
raise ::Lark::AccessTokenExpiredError if [
|
|
84
|
+
raise ::Lark::AccessTokenExpiredError if [99_991_663, 99_991_664].include?(result.code)
|
|
85
|
+
|
|
80
86
|
result
|
|
81
87
|
end
|
|
82
88
|
|
|
@@ -99,7 +105,7 @@ module Lark
|
|
|
99
105
|
end
|
|
100
106
|
|
|
101
107
|
def success?
|
|
102
|
-
code
|
|
108
|
+
code.zero?
|
|
103
109
|
end
|
|
104
110
|
end
|
|
105
111
|
end
|
data/lib/lark/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: lark-sdk
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 1.
|
|
4
|
+
version: 1.2.1
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Sean Dong
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: exe
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date:
|
|
11
|
+
date: 2021-03-18 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: http
|
|
@@ -128,6 +128,7 @@ files:
|
|
|
128
128
|
- lib/lark/apis/mina.rb
|
|
129
129
|
- lib/lark/apis/notify.rb
|
|
130
130
|
- lib/lark/apis/pay.rb
|
|
131
|
+
- lib/lark/apis/search.rb
|
|
131
132
|
- lib/lark/apis/user.rb
|
|
132
133
|
- lib/lark/cipher.rb
|
|
133
134
|
- lib/lark/config.rb
|
|
@@ -140,14 +141,14 @@ files:
|
|
|
140
141
|
- lib/lark/token_store/isv_tenant_token.rb
|
|
141
142
|
- lib/lark/token_store/tenant_token.rb
|
|
142
143
|
- lib/lark/version.rb
|
|
143
|
-
homepage: https://github.com/
|
|
144
|
+
homepage: https://github.com/seandong/lark-ruby-sdk
|
|
144
145
|
licenses:
|
|
145
146
|
- MIT
|
|
146
147
|
metadata:
|
|
147
148
|
allowed_push_host: https://rubygems.org/
|
|
148
|
-
homepage_uri: https://github.com/
|
|
149
|
-
source_code_uri: https://github.com/
|
|
150
|
-
changelog_uri: https://github.com/
|
|
149
|
+
homepage_uri: https://github.com/seandong/lark-ruby-sdk
|
|
150
|
+
source_code_uri: https://github.com/seandong/lark-ruby-sdk
|
|
151
|
+
changelog_uri: https://github.com/seandong/lark-ruby-sdk
|
|
151
152
|
post_install_message:
|
|
152
153
|
rdoc_options: []
|
|
153
154
|
require_paths:
|