brynq-sdk-bob 2.9.1__py3-none-any.whl → 2.9.3__py3-none-any.whl

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.
brynq_sdk_bob/payments.py CHANGED
@@ -1,7 +1,11 @@
1
+ import time
2
+ from typing import List, Optional
3
+
1
4
  import pandas as pd
2
- from typing import Optional, List
5
+
3
6
  from brynq_sdk_functions import Functions
4
- from .schemas.payments import VariablePaymentSchema, ActualPaymentsSchema
7
+
8
+ from .schemas.payments import ActualPaymentsSchema, VariablePaymentSchema
5
9
 
6
10
 
7
11
  class Payments:
@@ -10,18 +14,30 @@ class Payments:
10
14
  self.schema = VariablePaymentSchema
11
15
 
12
16
  def get(self, person_ids: List[str]) -> (pd.DataFrame, pd.DataFrame):
13
- df = pd.DataFrame()
17
+ records = []
18
+
14
19
  for person_id in person_ids:
15
- resp = self.bob.session.get(url=f"{self.bob.base_url}people/{person_id}/variable", timeout=self.bob.timeout)
20
+ # Throttle requests to respect API rate limits
21
+ time.sleep(0.2)
22
+
23
+ resp = self.bob.session.get(
24
+ url=f"{self.bob.base_url}people/{person_id}/variable",
25
+ timeout=self.bob.timeout
26
+ )
16
27
  resp.raise_for_status()
28
+
17
29
  data = resp.json()
18
- df = pd.concat([df, pd.json_normalize(
19
- data,
20
- record_path='values'
21
- )])
22
- df['employee_id'] = person_id
23
- df = df.reset_index(drop=True)
30
+
31
+ # Normalize nested json and assign ID before appending to list
32
+ df_temp = pd.json_normalize(data, record_path='values')
33
+ df_temp['employee_id'] = person_id
34
+ records.append(df_temp)
35
+
36
+ # Concatenate once to improve performance
37
+ df = pd.concat(records, ignore_index=True) if records else pd.DataFrame()
38
+
24
39
  valid_payments, invalid_payments = Functions.validate_data(df=df, schema=self.schema, debug=True)
40
+
25
41
  return valid_payments, invalid_payments
26
42
 
27
43
  def get_actual_payments(
@@ -1,9 +1,13 @@
1
+ from datetime import datetime
2
+ from typing import Optional
3
+
4
+ import pandas as pd
1
5
  import pandera as pa
2
6
  from pandera.typing import Series
3
- import pandas as pd
4
- from datetime import datetime
7
+
5
8
  from brynq_sdk_functions import BrynQPanderaDataFrameModel
6
9
 
10
+
7
11
  class WorkSchema(BrynQPanderaDataFrameModel):
8
12
  can_be_deleted: Series[pa.Bool] = pa.Field(coerce=True, description="Can Be Deleted", alias="canBeDeleted")
9
13
  work_change_type: Series[str] = pa.Field(coerce=True, description="Work Change Type", alias="workChangeType")
@@ -21,12 +25,12 @@ class WorkSchema(BrynQPanderaDataFrameModel):
21
25
  change_reason: Series[str] = pa.Field(coerce=True, nullable=True, description="Change Reason", alias="change.reason")
22
26
  change_changed_by: Series[str] = pa.Field(coerce=True, nullable=True, description="Change Changed By", alias="change.changedBy")
23
27
  change_changed_by_id: Series[str] = pa.Field(coerce=True, nullable=True, description="Change Changed By ID", alias="change.changedById")
24
- reports_to_id: Series[str] = pa.Field(coerce=True, nullable=True, description="Reports To ID", alias="reportsTo.id")
25
- reports_to_first_name: Series[str] = pa.Field(coerce=True, nullable=True, description="Reports To First Name", alias="reportsTo.firstName")
26
- reports_to_surname: Series[str] = pa.Field(coerce=True, nullable=True, description="Reports To Surname", alias="reportsTo.surname")
27
- reports_to_email: Series[str] = pa.Field(coerce=True, nullable=True, description="Reports To Email", alias="reportsTo.email")
28
- reports_to_display_name: Series[str] = pa.Field(coerce=True, nullable=True, description="Reports To Display Name", alias="reportsTo.displayName")
29
- reports_to: Series[pd.Int64Dtype] = pa.Field(coerce=True, nullable=True, description="Reports To", alias="reportsTo")
28
+ reports_to_id: Optional[Series[str]] = pa.Field(coerce=True, nullable=True, description="Reports To ID", alias="reportsTo.id")
29
+ reports_to_first_name: Optional[Series[str]] = pa.Field(coerce=True, nullable=True, description="Reports To First Name", alias="reportsTo.firstName")
30
+ reports_to_surname: Optional[Series[str]] = pa.Field(coerce=True, nullable=True, description="Reports To Surname", alias="reportsTo.surname")
31
+ reports_to_email: Optional[Series[str]] = pa.Field(coerce=True, nullable=True, description="Reports To Email", alias="reportsTo.email")
32
+ reports_to_display_name: Optional[Series[str]] = pa.Field(coerce=True, nullable=True, description="Reports To Display Name", alias="reportsTo.displayName")
33
+ reports_to: Optional[Series[pd.Int64Dtype]] = pa.Field(coerce=True, nullable=True, description="Reports To", alias="reportsTo")
30
34
  employee_id: Series[str] = pa.Field(coerce=True, description="Employee ID", alias="employeeId")
31
35
 
32
36
  class Config:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: brynq_sdk_bob
3
- Version: 2.9.1
3
+ Version: 2.9.3
4
4
  Summary: Bob wrapper from BrynQ
5
5
  Author: BrynQ
6
6
  Author-email: support@brynq.com
@@ -5,7 +5,7 @@ brynq_sdk_bob/custom_tables.py,sha256=MvnR2mIcyK0rpwd0P7xV3BPIvCYQVEClBvo901GttP
5
5
  brynq_sdk_bob/documents.py,sha256=ww101owiBGARCxOANdDtmWrNedSBe9V-BEed6QspQPg,1756
6
6
  brynq_sdk_bob/employment.py,sha256=uNllQrIBbo8yPG_2-ln1PWeWUFU672T289PpWWvL-V8,763
7
7
  brynq_sdk_bob/named_lists.py,sha256=ksLXV2ysBFegq4gZiiaC56gjkgdnPzL7WajZTGvjYIM,1069
8
- brynq_sdk_bob/payments.py,sha256=HVXoMyA0Jyhyk5EcgCU2OQfdbMtElhdLfdBKgI9xC4Q,3922
8
+ brynq_sdk_bob/payments.py,sha256=43Ctdt5T8gtpCud67dm75xa90W8m6FyMrU2hAWKrzMc,4221
9
9
  brynq_sdk_bob/payroll_history.py,sha256=wHo6da7kLDe1ViL4egyMdyJBMZnWVhwjNjmh4cTCTeY,3972
10
10
  brynq_sdk_bob/people.py,sha256=t1A1dABX6UZ0pyLTGOL-Sp5pHY630KWIyIO3JQ_Pjdk,5970
11
11
  brynq_sdk_bob/reports.py,sha256=Tawmqm_ZmQ487loyk-29-A_fTCrgImbWCEf6zfwuaq4,1245
@@ -22,8 +22,8 @@ brynq_sdk_bob/schemas/payroll_history.py,sha256=JdAq0XaArHHEw8EsXo3GD0EhSAyBhPtY
22
22
  brynq_sdk_bob/schemas/people.py,sha256=42BJVgJmT-h5kzuQl6iI7wZDSGNA0KTQQVIAqeeyHNk,40149
23
23
  brynq_sdk_bob/schemas/salary.py,sha256=TSaM1g92y3oiDcUrfJW7ushgKZenI9xB6XW3kKuU0dE,4540
24
24
  brynq_sdk_bob/schemas/timeoff.py,sha256=gTYu_bNcfHrkTz4eIHCZ4WzgMTj2U4nI3X6JTzDovhk,12817
25
- brynq_sdk_bob/schemas/work.py,sha256=YgtBJ0WXJOq55bFlT_kY_IbHh0SlQEtaa0W8vms-xA4,3048
26
- brynq_sdk_bob-2.9.1.dist-info/METADATA,sha256=ke9A20p-pjUdeeLT9kDSkoLXDMXBPaEFFtN7ig_Wv5Y,371
27
- brynq_sdk_bob-2.9.1.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
28
- brynq_sdk_bob-2.9.1.dist-info/top_level.txt,sha256=oGiWqOuAAiVoLIzGe6F-Lo4IJBYz5ftOwBft7HtPuoY,14
29
- brynq_sdk_bob-2.9.1.dist-info/RECORD,,
25
+ brynq_sdk_bob/schemas/work.py,sha256=SvP7FrF1AygHhe12QT6dDxFzmLYs6HScAov5K6FsNvI,3139
26
+ brynq_sdk_bob-2.9.3.dist-info/METADATA,sha256=22KCffoyrlMZiWe7hUzwBHzTXX-ZN473ARSYNzwKjrA,371
27
+ brynq_sdk_bob-2.9.3.dist-info/WHEEL,sha256=qELbo2s1Yzl39ZmrAibXA2jjPLUYfnVhUNTlyF1rq0Y,92
28
+ brynq_sdk_bob-2.9.3.dist-info/top_level.txt,sha256=oGiWqOuAAiVoLIzGe6F-Lo4IJBYz5ftOwBft7HtPuoY,14
29
+ brynq_sdk_bob-2.9.3.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: setuptools (80.9.0)
2
+ Generator: setuptools (80.10.1)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5