peoplegroup-connectors 0.1.32 → 0.1.37

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 24fc0303d37aaf2d6aa63b3babcf36ff18b086e084de6ac323440428c53926d4
4
- data.tar.gz: 7974b2b210a74ab0236eb23cac227eb788332ddf0412609437139d0dc4a04ac4
3
+ metadata.gz: 5ee402cbc096def361f487eda8ef9992ff459ab63a606f0ad94d4735d41bc365
4
+ data.tar.gz: a79c17d291849c27a2996da26c814dbf70e7ad1c27a2782ba502492407010c1a
5
5
  SHA512:
6
- metadata.gz: a26c436c53c04da6889f179cad06c13f6a1b7d3f9fa6e12cfbfa2436d6df8e24311b3eebeabbaae5bb8cd2cc289b009635b64c0d581c212b5d3a518a4ce1ad5c
7
- data.tar.gz: 80eb3e35a56dae8b36a4c50a05b6f052275f135435b2ca0821a9e275ddcce7941bfbb520a56652e9f035e5071f7e13e0a616d2e59e20d0930731b550110318ee
6
+ metadata.gz: 18b42324f2bb9db2c8e158df26d8ca5b35efa869fc3358afd4c94a44dd810487cb0138a80b7c977b274c43e4a3e86c9a15301528b2b465c8a1fd9e245fdde53a
7
+ data.tar.gz: 68c8545dbb12e870978a589872fdabcd2ff5fa9ea93e1dcd7c3fe90a3f758bd5cdf7b78edfee2ab9d57292a8a903eea6495974d5559e7c4b59e56cdc70d31778
@@ -6,6 +6,7 @@ require_relative 'connectors/slack'
6
6
  require_relative 'connectors/pto_roots'
7
7
  require_relative 'connectors/bamboo'
8
8
  require_relative 'connectors/greenhouse'
9
+ require_relative 'utils'
9
10
 
10
11
  module PeopleGroup
11
12
  module Connectors
@@ -5,9 +5,8 @@ require 'bamboozled'
5
5
  module PeopleGroup
6
6
  module Connectors
7
7
  class Bamboo
8
- MAX_RETRIES = 3
9
-
10
- def initialize
8
+ def initialize(use_report: false)
9
+ @use_report = use_report
11
10
  @client = Bamboozled.client(subdomain: 'gitlab', api_key: ENV['BAMBOO_API_KEY'])
12
11
  end
13
12
 
@@ -43,7 +42,7 @@ module PeopleGroup
43
42
  file_path = File.join(__dir__, '../../../data/email_mapper.yml')
44
43
  email_mapper = YAML.load_file(file_path)
45
44
  email_hit = email_mapper.find { |mapping| mapping['slack_email'] == email.delete_suffix('@gitlab.com') }
46
- email = email_hit['bamboo_email'] if email_hit
45
+ email = "#{email_hit['bamboo_email']}@gitlab.com" if email_hit
47
46
 
48
47
  employees.find { |employee| employee['workEmail'] == email }
49
48
  end
@@ -52,6 +51,11 @@ module PeopleGroup
52
51
  active_team_members.find { |tm| tm['id'] == team_member['supervisorEId'] }
53
52
  end
54
53
 
54
+ def fetch_manager_for_id(team_member_id)
55
+ team_member = get_employee_details(team_member_id)
56
+ active_team_members.find { |tm| tm['id'] == team_member['supervisorEId'] }
57
+ end
58
+
55
59
  def fetch_second_level_manager(team_member)
56
60
  fetch_manager(fetch_manager(team_member))
57
61
  end
@@ -77,12 +81,12 @@ module PeopleGroup
77
81
  end
78
82
 
79
83
  def employees
80
- retries = 0
81
-
82
- begin
83
- @employees ||= @client.report.custom(fields, 'JSON').reject { |employee| employee['lastName'] == 'Test-Gitlab' }
84
- rescue Net::ReadTimeout, Bamboozled::GatewayError
85
- retry if (retries += 1) < MAX_RETRIES
84
+ Utils.retry_on_error(errors: [Net::ReadTimeout, Bamboozled::GatewayError]) do
85
+ if @use_report
86
+ @employees ||= @client.report.find(@use_report, 'JSON', true).reject { |employee| employee['lastName'] == 'Test-Gitlab' }
87
+ else
88
+ @employees ||= @client.report.custom(fields, 'JSON').reject { |employee| employee['lastName'] == 'Test-Gitlab' }
89
+ end
86
90
  end
87
91
  end
88
92
 
@@ -171,6 +175,14 @@ module PeopleGroup
171
175
  @client.employee.add_table_row(employee_id, 'customAdditionalInformation1', data)
172
176
  end
173
177
 
178
+ def additional_data(employee_id)
179
+ @client.employee.table_data(employee_id, 'employmentStatus')
180
+ end
181
+
182
+ def currency_conversion(employee_id)
183
+ @client.employee.table_data(employee_id, 'customCurrencyConversion')
184
+ end
185
+
174
186
  def add_bonus(team_member_id, comment)
175
187
  data = {
176
188
  customBonusdate: Date.today.to_s,
@@ -182,6 +194,10 @@ module PeopleGroup
182
194
  @client.employee.add_table_row(team_member_id, 'customBonus', data)
183
195
  end
184
196
 
197
+ def has_direct_reports?(id)
198
+ active_team_members.any? { |team_member| team_member['supervisorEId'] == id.to_s }
199
+ end
200
+
185
201
  private
186
202
 
187
203
  def meta_fields
@@ -7,8 +7,6 @@ module PeopleGroup
7
7
  class GitLab
8
8
  attr_accessor :client
9
9
 
10
- MAX_RETRIES = 3
11
-
12
10
  API_URL = ENV['GITLAB_API_V4_URL'] || 'https://gitlab.com/api/v4'
13
11
 
14
12
  def initialize(token: ENV['GITLAB_API_TOKEN'])
@@ -144,14 +142,8 @@ module PeopleGroup
144
142
 
145
143
  private
146
144
 
147
- def retry_on_error
148
- retries = 0
149
-
150
- begin
151
- yield
152
- rescue Gitlab::Error::InternalServerError
153
- retry if (retries += 1) < MAX_RETRIES
154
- end
145
+ def retry_on_error(&block)
146
+ Utils.retry_on_error(errors: [Gitlab::Error::InternalServerError], &block)
155
147
  end
156
148
 
157
149
  def find_epic(group_id, title)
@@ -19,20 +19,19 @@ module PeopleGroup
19
19
  def hired_candidates(updated_since)
20
20
  page = 1
21
21
  candidates = []
22
- retries = 0
22
+ on_error = -> { p [updated_since, page] }
23
23
 
24
24
  loop do
25
- begin
26
- results = @client.candidates(nil, updated_after: updated_since, page: page)
27
- break if results.empty?
28
-
29
- results.each do |candidate|
30
- candidates << candidate if hired_non_active?(candidate)
31
- end
32
- rescue GreenhouseIo::Error
33
- p [updated_since, page]
34
- retry if (retries += 1) < MAX_RETRIES
25
+ results = Utils.retry_on_error(errors: [GreenhouseIo::Error], on_error: on_error) do
26
+ @client.candidates(nil, updated_after: updated_since, page: page)
35
27
  end
28
+
29
+ break if results.empty?
30
+
31
+ results.each do |candidate|
32
+ candidates << candidate if hired_non_active?(candidate)
33
+ end
34
+
36
35
  page += 1
37
36
  end
38
37
 
@@ -22,7 +22,7 @@ module PeopleGroup
22
22
  file_path = File.join(__dir__, '../../../data/email_mapper.yml')
23
23
  email_mapper = YAML.load_file(file_path)
24
24
  email_hit = email_mapper.find { |mapping| mapping['bamboo_email'] == email.delete_suffix('@gitlab.com') }
25
- email = email_hit['slack_email'] if email_hit
25
+ email = "#{email_hit['slack_email']}@gitlab.com" if email_hit
26
26
 
27
27
  @client.users_lookupByEmail(email: email)
28
28
  rescue ::Slack::Web::Api::Errors::SlackError
@@ -2,6 +2,6 @@
2
2
 
3
3
  module PeopleGroup
4
4
  module Connectors
5
- VERSION = '0.1.32'
5
+ VERSION = '0.1.37'
6
6
  end
7
7
  end
@@ -0,0 +1,20 @@
1
+ # frozen_string_literal: true
2
+
3
+ module PeopleGroup
4
+ class Utils
5
+ class << self
6
+ def retry_on_error(max_attempts: 3, delay: 0, errors: [StandardError], on_error: -> {})
7
+ attempts = 0
8
+
9
+ begin
10
+ yield
11
+ rescue *errors => e
12
+ on_error.call
13
+ sleep delay
14
+ retry if (attempts += 1) < max_attempts
15
+ raise e
16
+ end
17
+ end
18
+ end
19
+ end
20
+ end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: peoplegroup-connectors
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.32
4
+ version: 0.1.37
5
5
  platform: ruby
6
6
  authors:
7
7
  - lien van den steen
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-03-29 00:00:00.000000000 Z
11
+ date: 2021-04-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: gitlab
@@ -167,6 +167,7 @@ files:
167
167
  - lib/peoplegroup/connectors/pto_roots.rb
168
168
  - lib/peoplegroup/connectors/slack.rb
169
169
  - lib/peoplegroup/connectors/version.rb
170
+ - lib/peoplegroup/utils.rb
170
171
  homepage: https://gitlab.com/gitlab-com/people-group/peopleops-eng/connectors-gem
171
172
  licenses:
172
173
  - MIT
@@ -174,7 +175,7 @@ metadata:
174
175
  homepage_uri: https://gitlab.com/gitlab-com/people-group/peopleops-eng/connectors-gem
175
176
  source_code_uri: https://gitlab.com/gitlab-com/people-group/peopleops-eng/connectors-gem
176
177
  changelog_uri: https://gitlab.com/gitlab-com/people-group/peopleops-eng/connectors-gem
177
- post_install_message:
178
+ post_install_message:
178
179
  rdoc_options: []
179
180
  require_paths:
180
181
  - lib
@@ -190,7 +191,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
190
191
  version: '0'
191
192
  requirements: []
192
193
  rubygems_version: 3.1.4
193
- signing_key:
194
+ signing_key:
194
195
  specification_version: 4
195
196
  summary: Library for our shared connectors.
196
197
  test_files: []