ci_toolkit 1.3.21 → 1.4.0
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/Gemfile.lock +1 -1
- data/lib/ci_toolkit/github_bot.rb +62 -0
- data/lib/ci_toolkit/github_pr.rb +2 -2
- data/lib/ci_toolkit.rb +1 -1
- metadata +2 -2
- data/lib/ci_toolkit/github_access.rb +0 -51
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7c3a2dc78e17b33a1f5cec89d973abd60bc9c972ec8d5d99c7547fd1ec0591f1
|
4
|
+
data.tar.gz: 1ac3f0583f2e9acb470dde9ecc5154003350c444a9e86e5a113722df38cfdc50
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 37dfe3cb4c7f72b0489f0dbdc792ba6f7b5cc79af67b45d8b3256c1ed83dbef1cb3eb7597304015738e33cb80ee5a1138a501d46872640a7013088c5c6c04320
|
7
|
+
data.tar.gz: 7e6cd2c35898d510f419c6b915d29fdf0a6fcfd252b6bd34dd3d17f74dc411241a7547a839c809b9c8d1d2a1a8c20dbbe0dbc757b3aeff85a5a75a6b8254e3be
|
data/Gemfile.lock
CHANGED
@@ -0,0 +1,62 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "octokit"
|
4
|
+
require "jwt"
|
5
|
+
|
6
|
+
module CiToolkit
|
7
|
+
# Utility class that provides an access token that can be used with the Github API
|
8
|
+
class GithubBot
|
9
|
+
# Provides a jwt token for authentication. Sores the private key and app id for the bot
|
10
|
+
class Credentials
|
11
|
+
attr_reader :app_id
|
12
|
+
|
13
|
+
def initialize(app_id = ENV["CRVSH_BOT_GITHUB_APP_ID"], private_key = ENV["CRVSH_BOT_GITHUB_APP_PRIVATE_KEY"])
|
14
|
+
@app_id = app_id.to_i
|
15
|
+
@private_key = private_key
|
16
|
+
end
|
17
|
+
|
18
|
+
def jwt_token
|
19
|
+
JWT.encode(
|
20
|
+
{
|
21
|
+
iat: Time.now.to_i,
|
22
|
+
exp: Time.now.to_i + (9 * 60),
|
23
|
+
iss: @app_id
|
24
|
+
},
|
25
|
+
OpenSSL::PKey::RSA.new(@private_key),
|
26
|
+
"RS256"
|
27
|
+
)
|
28
|
+
end
|
29
|
+
end
|
30
|
+
# stack = Faraday::RackBuilder.new do |builder|
|
31
|
+
# builder.response :logger
|
32
|
+
# builder.use Octokit::Response::RaiseError
|
33
|
+
# builder.adapter Faraday.default_adapter
|
34
|
+
# end
|
35
|
+
# Octokit.middleware = stack
|
36
|
+
|
37
|
+
def initialize(
|
38
|
+
credentials = CiToolkit::GithubBot::Credentials.new,
|
39
|
+
client = Octokit::Client.new(bearer_token: credentials.jwt_token, auto_paginate: true)
|
40
|
+
)
|
41
|
+
@app_id = credentials.app_id
|
42
|
+
@client = client
|
43
|
+
end
|
44
|
+
|
45
|
+
def create_token
|
46
|
+
return unless (installation_id = find_app_installation)
|
47
|
+
|
48
|
+
@client.create_app_installation_access_token(
|
49
|
+
installation_id,
|
50
|
+
{ accept: Octokit::Preview::PREVIEW_TYPES[:integrations] }
|
51
|
+
)[:token]
|
52
|
+
end
|
53
|
+
|
54
|
+
private
|
55
|
+
|
56
|
+
def find_app_installation
|
57
|
+
@client.find_app_installations(
|
58
|
+
{ accept: Octokit::Preview::PREVIEW_TYPES[:integrations] }
|
59
|
+
).select { |installation| @app_id.equal?(installation[:app_id]) }.first[:id]
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
data/lib/ci_toolkit/github_pr.rb
CHANGED
@@ -16,7 +16,7 @@ module CiToolkit
|
|
16
16
|
@commit_sha = env.git_commit
|
17
17
|
@_client = client
|
18
18
|
@build_types = build_types
|
19
|
-
@
|
19
|
+
@bot = CiToolkit::GithubBot.new
|
20
20
|
end
|
21
21
|
|
22
22
|
def title
|
@@ -110,7 +110,7 @@ module CiToolkit
|
|
110
110
|
|
111
111
|
def client
|
112
112
|
@_client = Octokit::Client.new if @_client.nil?
|
113
|
-
@_client.access_token = @
|
113
|
+
@_client.access_token = @bot.create_token if @_client.access_token.nil?
|
114
114
|
|
115
115
|
@_client
|
116
116
|
end
|
data/lib/ci_toolkit.rb
CHANGED
@@ -4,7 +4,7 @@ require "ci_toolkit/bitrise_env"
|
|
4
4
|
require "ci_toolkit/build"
|
5
5
|
require "ci_toolkit/build_status"
|
6
6
|
require "ci_toolkit/duplicate_files_finder"
|
7
|
-
require "ci_toolkit/
|
7
|
+
require "ci_toolkit/github_bot"
|
8
8
|
require "ci_toolkit/github_pr"
|
9
9
|
require "ci_toolkit/git"
|
10
10
|
require "ci_toolkit/jira"
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ci_toolkit
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.4.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Gero Keller
|
@@ -209,7 +209,7 @@ files:
|
|
209
209
|
- lib/ci_toolkit/build_status.rb
|
210
210
|
- lib/ci_toolkit/duplicate_files_finder.rb
|
211
211
|
- lib/ci_toolkit/git.rb
|
212
|
-
- lib/ci_toolkit/
|
212
|
+
- lib/ci_toolkit/github_bot.rb
|
213
213
|
- lib/ci_toolkit/github_pr.rb
|
214
214
|
- lib/ci_toolkit/jira.rb
|
215
215
|
- lib/ci_toolkit/pr_messenger.rb
|
@@ -1,51 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
|
3
|
-
require "octokit"
|
4
|
-
require "jwt"
|
5
|
-
|
6
|
-
module CiToolkit
|
7
|
-
# Utility class that provides an access token that can be used with the Github API
|
8
|
-
class GithubAccess
|
9
|
-
# stack = Faraday::RackBuilder.new do |builder|
|
10
|
-
# builder.response :logger
|
11
|
-
# builder.use Octokit::Response::RaiseError
|
12
|
-
# builder.adapter Faraday.default_adapter
|
13
|
-
# end
|
14
|
-
# Octokit.middleware = stack
|
15
|
-
|
16
|
-
def initialize(app_id = ENV["CRVSH_BOT_GITHUB_APP_ID"], private_key = ENV["CRVSH_BOT_GITHUB_APP_PRIVATE_KEY"])
|
17
|
-
@app_id = app_id.to_i
|
18
|
-
@private_key = private_key
|
19
|
-
@client = Octokit::Client.new(bearer_token: jwt_token, auto_paginate: true)
|
20
|
-
end
|
21
|
-
|
22
|
-
def create_token
|
23
|
-
return unless (installation_id = find_app_installation)
|
24
|
-
|
25
|
-
@client.create_app_installation_access_token(
|
26
|
-
installation_id,
|
27
|
-
{ accept: Octokit::Preview::PREVIEW_TYPES[:integrations] }
|
28
|
-
)[:token]
|
29
|
-
end
|
30
|
-
|
31
|
-
private
|
32
|
-
|
33
|
-
def find_app_installation
|
34
|
-
@client.find_app_installations(
|
35
|
-
{ accept: Octokit::Preview::PREVIEW_TYPES[:integrations] }
|
36
|
-
).select { |installation| installation[:app_id] == @app_id }.first[:id]
|
37
|
-
end
|
38
|
-
|
39
|
-
def jwt_token
|
40
|
-
JWT.encode(
|
41
|
-
{
|
42
|
-
iat: Time.now.to_i,
|
43
|
-
exp: Time.now.to_i + (9 * 60),
|
44
|
-
iss: @app_id
|
45
|
-
},
|
46
|
-
OpenSSL::PKey::RSA.new(@private_key),
|
47
|
-
"RS256"
|
48
|
-
)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|