peoplegroup-connectors 0.1.39 → 0.1.44
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:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6ef4f0521488e5096f42bd67012718940b9713ae411e483704d7773937e1684b
|
4
|
+
data.tar.gz: e811c0a01ac9266e52c39282fb893b41977f172682f9e177215d732d11ec844f
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e2f47aa4459f7b52390cb39277bbcb2f3a89922b38b23bcb206bd75e5137feb186bb97a63626f30cb92bcc1f3c3e4b267c724bfad5201be627b4b014f52e8f35
|
7
|
+
data.tar.gz: a2f1015a792db72d6334478e9e1ea643dee1ac5ebe0d17e90fd4f87023ee1f8b306dad84e9f8abad00d8530f71118b8480829fc35a0a54951e45ea2b33b6653f
|
@@ -5,6 +5,8 @@ require 'bamboozled'
|
|
5
5
|
module PeopleGroup
|
6
6
|
module Connectors
|
7
7
|
class Bamboo
|
8
|
+
EmployeeNotFoundError = Class.new(StandardError)
|
9
|
+
|
8
10
|
def initialize(use_report: false)
|
9
11
|
@use_report = use_report
|
10
12
|
@client = Bamboozled.client(subdomain: 'gitlab', api_key: ENV['BAMBOO_API_KEY'])
|
@@ -14,10 +16,24 @@ module PeopleGroup
|
|
14
16
|
employees.find { |emp| emp['id'] == id.to_s }
|
15
17
|
end
|
16
18
|
|
19
|
+
def get_employee_details!(id)
|
20
|
+
employee_details = get_employee_details(id)
|
21
|
+
raise EmployeeNotFoundError, "No employee found with id #{id}" if employee_details.nil?
|
22
|
+
|
23
|
+
employee_details
|
24
|
+
end
|
25
|
+
|
17
26
|
def get_employee(id)
|
18
27
|
@client.employee.find(id, %w[firstName lastName jobTitle supervisor hireDate country location department division workEmail customCostCenter])
|
19
28
|
end
|
20
29
|
|
30
|
+
def get_employee!(id)
|
31
|
+
employee = get_employee(id)
|
32
|
+
raise EmployeeNotFoundError, "No employee found with id #{id}" if employee.nil?
|
33
|
+
|
34
|
+
employee
|
35
|
+
end
|
36
|
+
|
21
37
|
def search_employee(name)
|
22
38
|
return if name.empty?
|
23
39
|
|
@@ -34,11 +50,27 @@ module PeopleGroup
|
|
34
50
|
end
|
35
51
|
alias_method :search_team_member, :search_employee
|
36
52
|
|
53
|
+
def search_employee!(name)
|
54
|
+
employee = search_employee(name)
|
55
|
+
raise EmployeeNotFoundError, "No employee found with name #{name}" if employee.nil?
|
56
|
+
|
57
|
+
employee
|
58
|
+
end
|
59
|
+
alias_method :search_team_member!, :search_employee!
|
60
|
+
|
37
61
|
def search_employee_by_field(field:, value:)
|
38
62
|
employees.find { |employee| employee[field] == value.to_s }
|
39
63
|
end
|
40
64
|
alias_method :search_team_member_by_field, :search_employee_by_field
|
41
65
|
|
66
|
+
def search_employee_by_field!(field:, value:)
|
67
|
+
employee = search_employee_by_field(field: field, value: value)
|
68
|
+
raise EmployeeNotFoundError, "No employee found with #{field}: #{value}" if employee.nil?
|
69
|
+
|
70
|
+
employee
|
71
|
+
end
|
72
|
+
alias_method :search_team_member_by_field!, :search_employee_by_field!
|
73
|
+
|
42
74
|
def slack_email_lookup_with_fallback(email)
|
43
75
|
file_path = File.join(__dir__, '../../../data/email_mapper.yml')
|
44
76
|
email_mapper = YAML.load_file(file_path)
|
@@ -48,19 +80,47 @@ module PeopleGroup
|
|
48
80
|
employees.find { |employee| employee['workEmail'] == email }
|
49
81
|
end
|
50
82
|
|
83
|
+
def slack_email_lookup_with_fallback!(email)
|
84
|
+
employee = slack_email_lookup_with_fallback(email)
|
85
|
+
raise EmployeeNotFoundError, "No employee found with Slack email #{email}" if employee.nil?
|
86
|
+
|
87
|
+
employee
|
88
|
+
end
|
89
|
+
|
51
90
|
def fetch_manager(team_member)
|
52
91
|
active_team_members.find { |tm| tm['id'] == team_member['supervisorEId'] }
|
53
92
|
end
|
54
93
|
|
94
|
+
def fetch_manager!(team_member)
|
95
|
+
manager = fetch_manager(team_member)
|
96
|
+
raise EmployeeNotFoundError, "Manager not found for employee #{team_member['id']}" if manager.nil?
|
97
|
+
|
98
|
+
manager
|
99
|
+
end
|
100
|
+
|
55
101
|
def fetch_manager_for_id(team_member_id)
|
56
102
|
team_member = get_employee_details(team_member_id)
|
57
103
|
active_team_members.find { |tm| tm['id'] == team_member['supervisorEId'] }
|
58
104
|
end
|
59
105
|
|
106
|
+
def fetch_manager_for_id!(team_member_id)
|
107
|
+
manager = fetch_manager_for_id(team_member_id)
|
108
|
+
raise EmployeeNotFoundError, "No manager found with id #{team_member_id}" if manager.nil?
|
109
|
+
|
110
|
+
manager
|
111
|
+
end
|
112
|
+
|
60
113
|
def fetch_second_level_manager(team_member)
|
61
114
|
fetch_manager(fetch_manager(team_member))
|
62
115
|
end
|
63
116
|
|
117
|
+
def fetch_second_level_manager!(team_member)
|
118
|
+
manager = fetch_second_level_manager(team_member)
|
119
|
+
raise EmployeeNotFoundError, "No second level manager found for employee #{team_member['id']}" if manager.nil?
|
120
|
+
|
121
|
+
manager
|
122
|
+
end
|
123
|
+
|
64
124
|
def create_employee(employee_details_hash)
|
65
125
|
@client.employee.add(employee_details_hash)
|
66
126
|
end
|
@@ -78,7 +138,11 @@ module PeopleGroup
|
|
78
138
|
end
|
79
139
|
|
80
140
|
def fields
|
81
|
-
@fields
|
141
|
+
return @fields if @fields
|
142
|
+
|
143
|
+
@fields = (Bamboozled::API::FieldCollection.all_names + @client.meta.fields.map { |f| f['alias'] }).compact.uniq
|
144
|
+
@fields.delete('flsaCode') # temp fix for problems with BambooHR
|
145
|
+
@fields
|
82
146
|
end
|
83
147
|
|
84
148
|
def employees
|
@@ -49,6 +49,10 @@ module PeopleGroup
|
|
49
49
|
retry_on_error { @client.create_issue_note(project, id, text) }
|
50
50
|
end
|
51
51
|
|
52
|
+
def edit_issue(project, id, options)
|
53
|
+
retry_on_error { @client.edit_issue(project, id, options) }
|
54
|
+
end
|
55
|
+
|
52
56
|
def get_onboarding_issues(project, args)
|
53
57
|
retry_on_error { @client.issues(project, args).auto_paginate }
|
54
58
|
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.
|
4
|
+
version: 0.1.44
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- lien van den steen
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-05-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: gitlab
|