finch-api 0.1.0.pre.alpha.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.
Files changed (479) hide show
  1. checksums.yaml +7 -0
  2. data/README.md +124 -0
  3. data/lib/finch-api/base_client.rb +464 -0
  4. data/lib/finch-api/base_model.rb +1188 -0
  5. data/lib/finch-api/base_page.rb +40 -0
  6. data/lib/finch-api/client.rb +145 -0
  7. data/lib/finch-api/errors.rb +188 -0
  8. data/lib/finch-api/extern.rb +10 -0
  9. data/lib/finch-api/individuals_page.rb +98 -0
  10. data/lib/finch-api/models/access_token_create_params.rb +54 -0
  11. data/lib/finch-api/models/account_disconnect_params.rb +18 -0
  12. data/lib/finch-api/models/account_introspect_params.rb +18 -0
  13. data/lib/finch-api/models/account_update_event.rb +1978 -0
  14. data/lib/finch-api/models/base_webhook_event.rb +41 -0
  15. data/lib/finch-api/models/company_event.rb +49 -0
  16. data/lib/finch-api/models/connect/session_new_params.rb +203 -0
  17. data/lib/finch-api/models/connect/session_new_response.rb +29 -0
  18. data/lib/finch-api/models/connect/session_reauthenticate_params.rb +90 -0
  19. data/lib/finch-api/models/connect/session_reauthenticate_response.rb +29 -0
  20. data/lib/finch-api/models/connection_status_type.rb +40 -0
  21. data/lib/finch-api/models/create_access_token_response.rb +163 -0
  22. data/lib/finch-api/models/directory_event.rb +78 -0
  23. data/lib/finch-api/models/disconnect_response.rb +20 -0
  24. data/lib/finch-api/models/employment_event.rb +78 -0
  25. data/lib/finch-api/models/hris/benefit_contribution.rb +54 -0
  26. data/lib/finch-api/models/hris/benefit_create_params.rb +46 -0
  27. data/lib/finch-api/models/hris/benefit_features_and_operations.rb +199 -0
  28. data/lib/finch-api/models/hris/benefit_frequency.rb +33 -0
  29. data/lib/finch-api/models/hris/benefit_list_params.rb +20 -0
  30. data/lib/finch-api/models/hris/benefit_list_supported_benefits_params.rb +20 -0
  31. data/lib/finch-api/models/hris/benefit_retrieve_params.rb +20 -0
  32. data/lib/finch-api/models/hris/benefit_type.rb +57 -0
  33. data/lib/finch-api/models/hris/benefit_update_params.rb +31 -0
  34. data/lib/finch-api/models/hris/benefits/enrolled_individual.rb +108 -0
  35. data/lib/finch-api/models/hris/benefits/individual_benefit.rb +127 -0
  36. data/lib/finch-api/models/hris/benefits/individual_enroll_many_params.rb +268 -0
  37. data/lib/finch-api/models/hris/benefits/individual_enrolled_ids_params.rb +22 -0
  38. data/lib/finch-api/models/hris/benefits/individual_enrolled_ids_response.rb +29 -0
  39. data/lib/finch-api/models/hris/benefits/individual_retrieve_many_benefits_params.rb +34 -0
  40. data/lib/finch-api/models/hris/benefits/individual_unenroll_many_params.rb +33 -0
  41. data/lib/finch-api/models/hris/benefits/unenrolled_individual.rb +77 -0
  42. data/lib/finch-api/models/hris/benefits_support.rb +106 -0
  43. data/lib/finch-api/models/hris/benfit_contribution.rb +9 -0
  44. data/lib/finch-api/models/hris/company.rb +290 -0
  45. data/lib/finch-api/models/hris/company_benefit.rb +40 -0
  46. data/lib/finch-api/models/hris/company_retrieve_params.rb +20 -0
  47. data/lib/finch-api/models/hris/create_company_benefits_response.rb +21 -0
  48. data/lib/finch-api/models/hris/directory_list_individuals_params.rb +42 -0
  49. data/lib/finch-api/models/hris/directory_list_params.rb +42 -0
  50. data/lib/finch-api/models/hris/document_list_params.rb +89 -0
  51. data/lib/finch-api/models/hris/document_list_response.rb +27 -0
  52. data/lib/finch-api/models/hris/document_response.rb +89 -0
  53. data/lib/finch-api/models/hris/document_retreive_params.rb +20 -0
  54. data/lib/finch-api/models/hris/document_retreive_response.rb +41 -0
  55. data/lib/finch-api/models/hris/employment_data.rb +380 -0
  56. data/lib/finch-api/models/hris/employment_data_response.rb +45 -0
  57. data/lib/finch-api/models/hris/employment_retrieve_many_params.rb +45 -0
  58. data/lib/finch-api/models/hris/individual.rb +290 -0
  59. data/lib/finch-api/models/hris/individual_in_directory.rb +117 -0
  60. data/lib/finch-api/models/hris/individual_response.rb +45 -0
  61. data/lib/finch-api/models/hris/individual_retrieve_many_params.rb +73 -0
  62. data/lib/finch-api/models/hris/pay_statement.rb +587 -0
  63. data/lib/finch-api/models/hris/pay_statement_response.rb +45 -0
  64. data/lib/finch-api/models/hris/pay_statement_response_body.rb +36 -0
  65. data/lib/finch-api/models/hris/pay_statement_retrieve_many_params.rb +65 -0
  66. data/lib/finch-api/models/hris/payment.rb +174 -0
  67. data/lib/finch-api/models/hris/payment_list_params.rb +36 -0
  68. data/lib/finch-api/models/hris/support_per_benefit_type.rb +35 -0
  69. data/lib/finch-api/models/hris/supported_benefit.rb +166 -0
  70. data/lib/finch-api/models/hris/update_company_benefit_response.rb +21 -0
  71. data/lib/finch-api/models/hris/w42005.rb +188 -0
  72. data/lib/finch-api/models/hris/w42020.rb +180 -0
  73. data/lib/finch-api/models/income.rb +87 -0
  74. data/lib/finch-api/models/individual_event.rb +78 -0
  75. data/lib/finch-api/models/introspection.rb +342 -0
  76. data/lib/finch-api/models/job_completion_event.rb +90 -0
  77. data/lib/finch-api/models/jobs/automated_async_job.rb +162 -0
  78. data/lib/finch-api/models/jobs/automated_create_params.rb +70 -0
  79. data/lib/finch-api/models/jobs/automated_create_response.rb +43 -0
  80. data/lib/finch-api/models/jobs/automated_list_params.rb +42 -0
  81. data/lib/finch-api/models/jobs/automated_retrieve_params.rb +20 -0
  82. data/lib/finch-api/models/jobs/manual_async_job.rb +63 -0
  83. data/lib/finch-api/models/jobs/manual_retrieve_params.rb +20 -0
  84. data/lib/finch-api/models/location.rb +79 -0
  85. data/lib/finch-api/models/money.rb +30 -0
  86. data/lib/finch-api/models/operation_support.rb +42 -0
  87. data/lib/finch-api/models/operation_support_matrix.rb +81 -0
  88. data/lib/finch-api/models/paging.rb +35 -0
  89. data/lib/finch-api/models/pay_statement_event.rb +89 -0
  90. data/lib/finch-api/models/payment_event.rb +81 -0
  91. data/lib/finch-api/models/payroll/pay_group_list_params.rb +40 -0
  92. data/lib/finch-api/models/payroll/pay_group_list_response.rb +87 -0
  93. data/lib/finch-api/models/payroll/pay_group_retrieve_params.rb +20 -0
  94. data/lib/finch-api/models/payroll/pay_group_retrieve_response.rb +81 -0
  95. data/lib/finch-api/models/provider.rb +2039 -0
  96. data/lib/finch-api/models/provider_list_params.rb +18 -0
  97. data/lib/finch-api/models/request_forwarding_forward_params.rb +60 -0
  98. data/lib/finch-api/models/request_forwarding_forward_response.rb +97 -0
  99. data/lib/finch-api/models/sandbox/company_update_params.rb +294 -0
  100. data/lib/finch-api/models/sandbox/company_update_response.rb +276 -0
  101. data/lib/finch-api/models/sandbox/connection_create_params.rb +90 -0
  102. data/lib/finch-api/models/sandbox/connection_create_response.rb +113 -0
  103. data/lib/finch-api/models/sandbox/connections/account_create_params.rb +87 -0
  104. data/lib/finch-api/models/sandbox/connections/account_create_response.rb +93 -0
  105. data/lib/finch-api/models/sandbox/connections/account_update_params.rb +32 -0
  106. data/lib/finch-api/models/sandbox/connections/account_update_response.rb +91 -0
  107. data/lib/finch-api/models/sandbox/directory_create_params.rb +642 -0
  108. data/lib/finch-api/models/sandbox/directory_create_response.rb +9 -0
  109. data/lib/finch-api/models/sandbox/employment_update_params.rb +372 -0
  110. data/lib/finch-api/models/sandbox/employment_update_response.rb +378 -0
  111. data/lib/finch-api/models/sandbox/individual_update_params.rb +292 -0
  112. data/lib/finch-api/models/sandbox/individual_update_response.rb +300 -0
  113. data/lib/finch-api/models/sandbox/job_create_params.rb +49 -0
  114. data/lib/finch-api/models/sandbox/job_create_response.rb +43 -0
  115. data/lib/finch-api/models/sandbox/jobs/configuration_retrieve_params.rb +22 -0
  116. data/lib/finch-api/models/sandbox/jobs/configuration_retrieve_response.rb +11 -0
  117. data/lib/finch-api/models/sandbox/jobs/configuration_update_params.rb +22 -0
  118. data/lib/finch-api/models/sandbox/jobs/sandbox_job_configuration.rb +79 -0
  119. data/lib/finch-api/models/sandbox/payment_create_params.rb +646 -0
  120. data/lib/finch-api/models/sandbox/payment_create_response.rb +29 -0
  121. data/lib/finch-api/models/webhook_event.rb +48 -0
  122. data/lib/finch-api/page.rb +98 -0
  123. data/lib/finch-api/pooled_net_requester.rb +175 -0
  124. data/lib/finch-api/request_options.rb +115 -0
  125. data/lib/finch-api/resources/access_tokens.rb +40 -0
  126. data/lib/finch-api/resources/account.rb +47 -0
  127. data/lib/finch-api/resources/connect/sessions.rb +81 -0
  128. data/lib/finch-api/resources/connect.rb +17 -0
  129. data/lib/finch-api/resources/hris/benefits/individuals.rb +112 -0
  130. data/lib/finch-api/resources/hris/benefits.rb +125 -0
  131. data/lib/finch-api/resources/hris/company.rb +32 -0
  132. data/lib/finch-api/resources/hris/directory.rb +65 -0
  133. data/lib/finch-api/resources/hris/documents.rb +65 -0
  134. data/lib/finch-api/resources/hris/employments.rb +37 -0
  135. data/lib/finch-api/resources/hris/individuals.rb +39 -0
  136. data/lib/finch-api/resources/hris/pay_statements.rb +40 -0
  137. data/lib/finch-api/resources/hris/payments.rb +41 -0
  138. data/lib/finch-api/resources/hris.rb +45 -0
  139. data/lib/finch-api/resources/jobs/automated.rb +96 -0
  140. data/lib/finch-api/resources/jobs/manual.rb +35 -0
  141. data/lib/finch-api/resources/jobs.rb +21 -0
  142. data/lib/finch-api/resources/payroll/pay_groups.rb +58 -0
  143. data/lib/finch-api/resources/payroll.rb +17 -0
  144. data/lib/finch-api/resources/providers.rb +31 -0
  145. data/lib/finch-api/resources/request_forwarding.rb +52 -0
  146. data/lib/finch-api/resources/sandbox/company.rb +50 -0
  147. data/lib/finch-api/resources/sandbox/connections/accounts.rb +67 -0
  148. data/lib/finch-api/resources/sandbox/connections.rb +48 -0
  149. data/lib/finch-api/resources/sandbox/directory.rb +37 -0
  150. data/lib/finch-api/resources/sandbox/employment.rb +76 -0
  151. data/lib/finch-api/resources/sandbox/individual.rb +65 -0
  152. data/lib/finch-api/resources/sandbox/jobs/configuration.rb +57 -0
  153. data/lib/finch-api/resources/sandbox/jobs.rb +40 -0
  154. data/lib/finch-api/resources/sandbox/payment.rb +40 -0
  155. data/lib/finch-api/resources/sandbox.rb +41 -0
  156. data/lib/finch-api/resources/webhooks.rb +13 -0
  157. data/lib/finch-api/responses_page.rb +84 -0
  158. data/lib/finch-api/single_page.rb +82 -0
  159. data/lib/finch-api/util.rb +636 -0
  160. data/lib/finch-api/version.rb +5 -0
  161. data/lib/finch-api.rb +178 -0
  162. data/manifest.yaml +13 -0
  163. data/rbi/lib/finch-api/base_client.rbi +173 -0
  164. data/rbi/lib/finch-api/base_model.rbi +476 -0
  165. data/rbi/lib/finch-api/base_page.rbi +39 -0
  166. data/rbi/lib/finch-api/client.rbi +102 -0
  167. data/rbi/lib/finch-api/errors.rbi +146 -0
  168. data/rbi/lib/finch-api/extern.rbi +7 -0
  169. data/rbi/lib/finch-api/individuals_page.rbi +37 -0
  170. data/rbi/lib/finch-api/models/access_token_create_params.rbi +70 -0
  171. data/rbi/lib/finch-api/models/account_disconnect_params.rbi +18 -0
  172. data/rbi/lib/finch-api/models/account_introspect_params.rbi +18 -0
  173. data/rbi/lib/finch-api/models/account_update_event.rbi +2479 -0
  174. data/rbi/lib/finch-api/models/base_webhook_event.rbi +39 -0
  175. data/rbi/lib/finch-api/models/company_event.rbi +43 -0
  176. data/rbi/lib/finch-api/models/connect/session_new_params.rbi +203 -0
  177. data/rbi/lib/finch-api/models/connect/session_new_response.rbi +33 -0
  178. data/rbi/lib/finch-api/models/connect/session_reauthenticate_params.rbi +95 -0
  179. data/rbi/lib/finch-api/models/connect/session_reauthenticate_response.rbi +33 -0
  180. data/rbi/lib/finch-api/models/connection_status_type.rbi +20 -0
  181. data/rbi/lib/finch-api/models/create_access_token_response.rbi +159 -0
  182. data/rbi/lib/finch-api/models/directory_event.rbi +61 -0
  183. data/rbi/lib/finch-api/models/disconnect_response.rbi +23 -0
  184. data/rbi/lib/finch-api/models/employment_event.rbi +61 -0
  185. data/rbi/lib/finch-api/models/hris/benefit_contribution.rbi +44 -0
  186. data/rbi/lib/finch-api/models/hris/benefit_create_params.rbi +62 -0
  187. data/rbi/lib/finch-api/models/hris/benefit_features_and_operations.rbi +190 -0
  188. data/rbi/lib/finch-api/models/hris/benefit_frequency.rbi +19 -0
  189. data/rbi/lib/finch-api/models/hris/benefit_list_params.rbi +20 -0
  190. data/rbi/lib/finch-api/models/hris/benefit_list_supported_benefits_params.rbi +20 -0
  191. data/rbi/lib/finch-api/models/hris/benefit_retrieve_params.rbi +20 -0
  192. data/rbi/lib/finch-api/models/hris/benefit_type.rbi +35 -0
  193. data/rbi/lib/finch-api/models/hris/benefit_update_params.rbi +37 -0
  194. data/rbi/lib/finch-api/models/hris/benefits/enrolled_individual.rbi +115 -0
  195. data/rbi/lib/finch-api/models/hris/benefits/individual_benefit.rbi +153 -0
  196. data/rbi/lib/finch-api/models/hris/benefits/individual_enroll_many_params.rbi +281 -0
  197. data/rbi/lib/finch-api/models/hris/benefits/individual_enrolled_ids_params.rbi +22 -0
  198. data/rbi/lib/finch-api/models/hris/benefits/individual_enrolled_ids_response.rbi +35 -0
  199. data/rbi/lib/finch-api/models/hris/benefits/individual_retrieve_many_benefits_params.rbi +36 -0
  200. data/rbi/lib/finch-api/models/hris/benefits/individual_unenroll_many_params.rbi +38 -0
  201. data/rbi/lib/finch-api/models/hris/benefits/unenrolled_individual.rbi +102 -0
  202. data/rbi/lib/finch-api/models/hris/benefits_support.rbi +196 -0
  203. data/rbi/lib/finch-api/models/hris/benfit_contribution.rbi +9 -0
  204. data/rbi/lib/finch-api/models/hris/company.rbi +338 -0
  205. data/rbi/lib/finch-api/models/hris/company_benefit.rbi +67 -0
  206. data/rbi/lib/finch-api/models/hris/company_retrieve_params.rbi +20 -0
  207. data/rbi/lib/finch-api/models/hris/create_company_benefits_response.rbi +25 -0
  208. data/rbi/lib/finch-api/models/hris/directory_list_individuals_params.rbi +43 -0
  209. data/rbi/lib/finch-api/models/hris/directory_list_params.rbi +43 -0
  210. data/rbi/lib/finch-api/models/hris/document_list_params.rbi +83 -0
  211. data/rbi/lib/finch-api/models/hris/document_list_response.rbi +42 -0
  212. data/rbi/lib/finch-api/models/hris/document_response.rbi +86 -0
  213. data/rbi/lib/finch-api/models/hris/document_retreive_params.rbi +20 -0
  214. data/rbi/lib/finch-api/models/hris/document_retreive_response.rbi +15 -0
  215. data/rbi/lib/finch-api/models/hris/employment_data.rbi +393 -0
  216. data/rbi/lib/finch-api/models/hris/employment_data_response.rbi +41 -0
  217. data/rbi/lib/finch-api/models/hris/employment_retrieve_many_params.rbi +63 -0
  218. data/rbi/lib/finch-api/models/hris/individual.rbi +281 -0
  219. data/rbi/lib/finch-api/models/hris/individual_in_directory.rbi +147 -0
  220. data/rbi/lib/finch-api/models/hris/individual_response.rbi +41 -0
  221. data/rbi/lib/finch-api/models/hris/individual_retrieve_many_params.rbi +94 -0
  222. data/rbi/lib/finch-api/models/hris/pay_statement.rbi +691 -0
  223. data/rbi/lib/finch-api/models/hris/pay_statement_response.rbi +47 -0
  224. data/rbi/lib/finch-api/models/hris/pay_statement_response_body.rbi +44 -0
  225. data/rbi/lib/finch-api/models/hris/pay_statement_retrieve_many_params.rbi +79 -0
  226. data/rbi/lib/finch-api/models/hris/payment.rbi +207 -0
  227. data/rbi/lib/finch-api/models/hris/payment_list_params.rbi +45 -0
  228. data/rbi/lib/finch-api/models/hris/support_per_benefit_type.rbi +47 -0
  229. data/rbi/lib/finch-api/models/hris/supported_benefit.rbi +155 -0
  230. data/rbi/lib/finch-api/models/hris/update_company_benefit_response.rbi +25 -0
  231. data/rbi/lib/finch-api/models/hris/w42005.rbi +150 -0
  232. data/rbi/lib/finch-api/models/hris/w42020.rbi +177 -0
  233. data/rbi/lib/finch-api/models/income.rbi +83 -0
  234. data/rbi/lib/finch-api/models/individual_event.rbi +61 -0
  235. data/rbi/lib/finch-api/models/introspection.rbi +350 -0
  236. data/rbi/lib/finch-api/models/job_completion_event.rbi +72 -0
  237. data/rbi/lib/finch-api/models/jobs/automated_async_job.rbi +174 -0
  238. data/rbi/lib/finch-api/models/jobs/automated_create_params.rbi +83 -0
  239. data/rbi/lib/finch-api/models/jobs/automated_create_response.rbi +64 -0
  240. data/rbi/lib/finch-api/models/jobs/automated_list_params.rbi +43 -0
  241. data/rbi/lib/finch-api/models/jobs/automated_retrieve_params.rbi +20 -0
  242. data/rbi/lib/finch-api/models/jobs/manual_async_job.rbi +54 -0
  243. data/rbi/lib/finch-api/models/jobs/manual_retrieve_params.rbi +20 -0
  244. data/rbi/lib/finch-api/models/location.rbi +114 -0
  245. data/rbi/lib/finch-api/models/money.rbi +31 -0
  246. data/rbi/lib/finch-api/models/operation_support.rbi +18 -0
  247. data/rbi/lib/finch-api/models/operation_support_matrix.rbi +47 -0
  248. data/rbi/lib/finch-api/models/paging.rbi +31 -0
  249. data/rbi/lib/finch-api/models/pay_statement_event.rbi +69 -0
  250. data/rbi/lib/finch-api/models/payment_event.rbi +69 -0
  251. data/rbi/lib/finch-api/models/payroll/pay_group_list_params.rbi +52 -0
  252. data/rbi/lib/finch-api/models/payroll/pay_group_list_response.rbi +59 -0
  253. data/rbi/lib/finch-api/models/payroll/pay_group_retrieve_params.rbi +20 -0
  254. data/rbi/lib/finch-api/models/payroll/pay_group_retrieve_response.rbi +82 -0
  255. data/rbi/lib/finch-api/models/provider.rbi +2369 -0
  256. data/rbi/lib/finch-api/models/provider_list_params.rbi +18 -0
  257. data/rbi/lib/finch-api/models/request_forwarding_forward_params.rbi +80 -0
  258. data/rbi/lib/finch-api/models/request_forwarding_forward_response.rbi +138 -0
  259. data/rbi/lib/finch-api/models/sandbox/company_update_params.rbi +336 -0
  260. data/rbi/lib/finch-api/models/sandbox/company_update_response.rbi +330 -0
  261. data/rbi/lib/finch-api/models/sandbox/connection_create_params.rbi +91 -0
  262. data/rbi/lib/finch-api/models/sandbox/connection_create_response.rbi +129 -0
  263. data/rbi/lib/finch-api/models/sandbox/connections/account_create_params.rbi +93 -0
  264. data/rbi/lib/finch-api/models/sandbox/connections/account_create_response.rbi +120 -0
  265. data/rbi/lib/finch-api/models/sandbox/connections/account_update_params.rbi +36 -0
  266. data/rbi/lib/finch-api/models/sandbox/connections/account_update_response.rbi +109 -0
  267. data/rbi/lib/finch-api/models/sandbox/directory_create_params.rbi +629 -0
  268. data/rbi/lib/finch-api/models/sandbox/directory_create_response.rbi +9 -0
  269. data/rbi/lib/finch-api/models/sandbox/employment_update_params.rbi +377 -0
  270. data/rbi/lib/finch-api/models/sandbox/employment_update_response.rbi +382 -0
  271. data/rbi/lib/finch-api/models/sandbox/individual_update_params.rbi +276 -0
  272. data/rbi/lib/finch-api/models/sandbox/individual_update_response.rbi +283 -0
  273. data/rbi/lib/finch-api/models/sandbox/job_create_params.rbi +46 -0
  274. data/rbi/lib/finch-api/models/sandbox/job_create_response.rbi +64 -0
  275. data/rbi/lib/finch-api/models/sandbox/jobs/configuration_retrieve_params.rbi +22 -0
  276. data/rbi/lib/finch-api/models/sandbox/jobs/configuration_retrieve_response.rbi +11 -0
  277. data/rbi/lib/finch-api/models/sandbox/jobs/configuration_update_params.rbi +22 -0
  278. data/rbi/lib/finch-api/models/sandbox/jobs/sandbox_job_configuration.rbi +58 -0
  279. data/rbi/lib/finch-api/models/sandbox/payment_create_params.rbi +876 -0
  280. data/rbi/lib/finch-api/models/sandbox/payment_create_response.rbi +33 -0
  281. data/rbi/lib/finch-api/models/webhook_event.rbi +18 -0
  282. data/rbi/lib/finch-api/page.rbi +37 -0
  283. data/rbi/lib/finch-api/pooled_net_requester.rbi +36 -0
  284. data/rbi/lib/finch-api/request_options.rbi +84 -0
  285. data/rbi/lib/finch-api/resources/access_tokens.rbi +24 -0
  286. data/rbi/lib/finch-api/resources/account.rbi +25 -0
  287. data/rbi/lib/finch-api/resources/connect/sessions.rbi +61 -0
  288. data/rbi/lib/finch-api/resources/connect.rbi +15 -0
  289. data/rbi/lib/finch-api/resources/hris/benefits/individuals.rbi +58 -0
  290. data/rbi/lib/finch-api/resources/hris/benefits.rbi +64 -0
  291. data/rbi/lib/finch-api/resources/hris/company.rbi +20 -0
  292. data/rbi/lib/finch-api/resources/hris/directory.rbi +35 -0
  293. data/rbi/lib/finch-api/resources/hris/documents.rbi +36 -0
  294. data/rbi/lib/finch-api/resources/hris/employments.rbi +23 -0
  295. data/rbi/lib/finch-api/resources/hris/individuals.rbi +24 -0
  296. data/rbi/lib/finch-api/resources/hris/pay_statements.rbi +23 -0
  297. data/rbi/lib/finch-api/resources/hris/payments.rbi +24 -0
  298. data/rbi/lib/finch-api/resources/hris.rbi +43 -0
  299. data/rbi/lib/finch-api/resources/jobs/automated.rbi +45 -0
  300. data/rbi/lib/finch-api/resources/jobs/manual.rbi +23 -0
  301. data/rbi/lib/finch-api/resources/jobs.rbi +19 -0
  302. data/rbi/lib/finch-api/resources/payroll/pay_groups.rbi +34 -0
  303. data/rbi/lib/finch-api/resources/payroll.rbi +15 -0
  304. data/rbi/lib/finch-api/resources/providers.rbi +18 -0
  305. data/rbi/lib/finch-api/resources/request_forwarding.rbi +25 -0
  306. data/rbi/lib/finch-api/resources/sandbox/company.rbi +40 -0
  307. data/rbi/lib/finch-api/resources/sandbox/connections/accounts.rbi +38 -0
  308. data/rbi/lib/finch-api/resources/sandbox/connections.rbi +36 -0
  309. data/rbi/lib/finch-api/resources/sandbox/directory.rbi +23 -0
  310. data/rbi/lib/finch-api/resources/sandbox/employment.rbi +62 -0
  311. data/rbi/lib/finch-api/resources/sandbox/individual.rbi +50 -0
  312. data/rbi/lib/finch-api/resources/sandbox/jobs/configuration.rbi +33 -0
  313. data/rbi/lib/finch-api/resources/sandbox/jobs.rbi +27 -0
  314. data/rbi/lib/finch-api/resources/sandbox/payment.rbi +25 -0
  315. data/rbi/lib/finch-api/resources/sandbox.rbi +39 -0
  316. data/rbi/lib/finch-api/resources/webhooks.rbi +11 -0
  317. data/rbi/lib/finch-api/responses_page.rbi +29 -0
  318. data/rbi/lib/finch-api/single_page.rbi +33 -0
  319. data/rbi/lib/finch-api/util.rbi +167 -0
  320. data/rbi/lib/finch-api/version.rbi +5 -0
  321. data/sig/finch-api/base_client.rbs +101 -0
  322. data/sig/finch-api/base_model.rbs +242 -0
  323. data/sig/finch-api/base_page.rbs +20 -0
  324. data/sig/finch-api/client.rbs +54 -0
  325. data/sig/finch-api/errors.rbs +99 -0
  326. data/sig/finch-api/extern.rbs +4 -0
  327. data/sig/finch-api/individuals_page.rbs +16 -0
  328. data/sig/finch-api/models/access_token_create_params.rbs +46 -0
  329. data/sig/finch-api/models/account_disconnect_params.rbs +19 -0
  330. data/sig/finch-api/models/account_introspect_params.rbs +19 -0
  331. data/sig/finch-api/models/account_update_event.rbs +1448 -0
  332. data/sig/finch-api/models/base_webhook_event.rbs +24 -0
  333. data/sig/finch-api/models/company_event.rbs +36 -0
  334. data/sig/finch-api/models/connect/session_new_params.rbs +129 -0
  335. data/sig/finch-api/models/connect/session_new_response.rbs +22 -0
  336. data/sig/finch-api/models/connect/session_reauthenticate_params.rbs +65 -0
  337. data/sig/finch-api/models/connect/session_reauthenticate_response.rbs +23 -0
  338. data/sig/finch-api/models/connection_status_type.rbs +22 -0
  339. data/sig/finch-api/models/create_access_token_response.rbs +80 -0
  340. data/sig/finch-api/models/directory_event.rbs +61 -0
  341. data/sig/finch-api/models/disconnect_response.rbs +17 -0
  342. data/sig/finch-api/models/employment_event.rbs +61 -0
  343. data/sig/finch-api/models/hris/benefit_contribution.rbs +38 -0
  344. data/sig/finch-api/models/hris/benefit_create_params.rbs +40 -0
  345. data/sig/finch-api/models/hris/benefit_features_and_operations.rbs +112 -0
  346. data/sig/finch-api/models/hris/benefit_frequency.rbs +15 -0
  347. data/sig/finch-api/models/hris/benefit_list_params.rbs +21 -0
  348. data/sig/finch-api/models/hris/benefit_list_supported_benefits_params.rbs +22 -0
  349. data/sig/finch-api/models/hris/benefit_retrieve_params.rbs +21 -0
  350. data/sig/finch-api/models/hris/benefit_type.rbs +50 -0
  351. data/sig/finch-api/models/hris/benefit_update_params.rbs +26 -0
  352. data/sig/finch-api/models/hris/benefits/enrolled_individual.rbs +75 -0
  353. data/sig/finch-api/models/hris/benefits/individual_benefit.rbs +91 -0
  354. data/sig/finch-api/models/hris/benefits/individual_enroll_many_params.rbs +203 -0
  355. data/sig/finch-api/models/hris/benefits/individual_enrolled_ids_params.rbs +24 -0
  356. data/sig/finch-api/models/hris/benefits/individual_enrolled_ids_response.rbs +25 -0
  357. data/sig/finch-api/models/hris/benefits/individual_retrieve_many_benefits_params.rbs +31 -0
  358. data/sig/finch-api/models/hris/benefits/individual_unenroll_many_params.rbs +31 -0
  359. data/sig/finch-api/models/hris/benefits/unenrolled_individual.rbs +62 -0
  360. data/sig/finch-api/models/hris/benefits_support.rbs +68 -0
  361. data/sig/finch-api/models/hris/benfit_contribution.rbs +8 -0
  362. data/sig/finch-api/models/hris/company.rbs +195 -0
  363. data/sig/finch-api/models/hris/company_benefit.rbs +36 -0
  364. data/sig/finch-api/models/hris/company_retrieve_params.rbs +21 -0
  365. data/sig/finch-api/models/hris/create_company_benefits_response.rbs +20 -0
  366. data/sig/finch-api/models/hris/directory_list_individuals_params.rbs +34 -0
  367. data/sig/finch-api/models/hris/directory_list_params.rbs +34 -0
  368. data/sig/finch-api/models/hris/document_list_params.rbs +61 -0
  369. data/sig/finch-api/models/hris/document_list_response.rbs +29 -0
  370. data/sig/finch-api/models/hris/document_response.rbs +58 -0
  371. data/sig/finch-api/models/hris/document_retreive_params.rbs +21 -0
  372. data/sig/finch-api/models/hris/document_retreive_response.rbs +12 -0
  373. data/sig/finch-api/models/hris/employment_data.rbs +228 -0
  374. data/sig/finch-api/models/hris/employment_data_response.rbs +41 -0
  375. data/sig/finch-api/models/hris/employment_retrieve_many_params.rbs +45 -0
  376. data/sig/finch-api/models/hris/individual.rbs +176 -0
  377. data/sig/finch-api/models/hris/individual_in_directory.rbs +83 -0
  378. data/sig/finch-api/models/hris/individual_response.rbs +41 -0
  379. data/sig/finch-api/models/hris/individual_retrieve_many_params.rbs +72 -0
  380. data/sig/finch-api/models/hris/pay_statement.rbs +445 -0
  381. data/sig/finch-api/models/hris/pay_statement_response.rbs +41 -0
  382. data/sig/finch-api/models/hris/pay_statement_response_body.rbs +35 -0
  383. data/sig/finch-api/models/hris/pay_statement_retrieve_many_params.rbs +53 -0
  384. data/sig/finch-api/models/hris/payment.rbs +112 -0
  385. data/sig/finch-api/models/hris/payment_list_params.rbs +30 -0
  386. data/sig/finch-api/models/hris/support_per_benefit_type.rbs +37 -0
  387. data/sig/finch-api/models/hris/supported_benefit.rbs +84 -0
  388. data/sig/finch-api/models/hris/update_company_benefit_response.rbs +20 -0
  389. data/sig/finch-api/models/hris/w42005.rbs +111 -0
  390. data/sig/finch-api/models/hris/w42020.rbs +108 -0
  391. data/sig/finch-api/models/income.rbs +57 -0
  392. data/sig/finch-api/models/individual_event.rbs +61 -0
  393. data/sig/finch-api/models/introspection.rbs +204 -0
  394. data/sig/finch-api/models/job_completion_event.rbs +70 -0
  395. data/sig/finch-api/models/jobs/automated_async_job.rbs +102 -0
  396. data/sig/finch-api/models/jobs/automated_create_params.rbs +57 -0
  397. data/sig/finch-api/models/jobs/automated_create_response.rbs +37 -0
  398. data/sig/finch-api/models/jobs/automated_list_params.rbs +34 -0
  399. data/sig/finch-api/models/jobs/automated_retrieve_params.rbs +21 -0
  400. data/sig/finch-api/models/jobs/manual_async_job.rbs +43 -0
  401. data/sig/finch-api/models/jobs/manual_retrieve_params.rbs +21 -0
  402. data/sig/finch-api/models/location.rbs +48 -0
  403. data/sig/finch-api/models/money.rbs +19 -0
  404. data/sig/finch-api/models/operation_support.rbs +18 -0
  405. data/sig/finch-api/models/operation_support_matrix.rbs +50 -0
  406. data/sig/finch-api/models/paging.rbs +21 -0
  407. data/sig/finch-api/models/pay_statement_event.rbs +68 -0
  408. data/sig/finch-api/models/payment_event.rbs +59 -0
  409. data/sig/finch-api/models/payroll/pay_group_list_params.rbs +35 -0
  410. data/sig/finch-api/models/payroll/pay_group_list_response.rbs +66 -0
  411. data/sig/finch-api/models/payroll/pay_group_retrieve_params.rbs +21 -0
  412. data/sig/finch-api/models/payroll/pay_group_retrieve_response.rbs +62 -0
  413. data/sig/finch-api/models/provider.rbs +1455 -0
  414. data/sig/finch-api/models/provider_list_params.rbs +18 -0
  415. data/sig/finch-api/models/request_forwarding_forward_params.rbs +44 -0
  416. data/sig/finch-api/models/request_forwarding_forward_response.rbs +71 -0
  417. data/sig/finch-api/models/sandbox/company_update_params.rbs +197 -0
  418. data/sig/finch-api/models/sandbox/company_update_response.rbs +192 -0
  419. data/sig/finch-api/models/sandbox/connection_create_params.rbs +61 -0
  420. data/sig/finch-api/models/sandbox/connection_create_response.rbs +66 -0
  421. data/sig/finch-api/models/sandbox/connections/account_create_params.rbs +62 -0
  422. data/sig/finch-api/models/sandbox/connections/account_create_response.rbs +63 -0
  423. data/sig/finch-api/models/sandbox/connections/account_update_params.rbs +34 -0
  424. data/sig/finch-api/models/sandbox/connections/account_update_response.rbs +61 -0
  425. data/sig/finch-api/models/sandbox/directory_create_params.rbs +392 -0
  426. data/sig/finch-api/models/sandbox/directory_create_response.rbs +9 -0
  427. data/sig/finch-api/models/sandbox/employment_update_params.rbs +228 -0
  428. data/sig/finch-api/models/sandbox/employment_update_response.rbs +229 -0
  429. data/sig/finch-api/models/sandbox/individual_update_params.rbs +178 -0
  430. data/sig/finch-api/models/sandbox/individual_update_response.rbs +179 -0
  431. data/sig/finch-api/models/sandbox/job_create_params.rbs +36 -0
  432. data/sig/finch-api/models/sandbox/job_create_response.rbs +37 -0
  433. data/sig/finch-api/models/sandbox/jobs/configuration_retrieve_params.rbs +23 -0
  434. data/sig/finch-api/models/sandbox/jobs/configuration_retrieve_response.rbs +12 -0
  435. data/sig/finch-api/models/sandbox/jobs/configuration_update_params.rbs +23 -0
  436. data/sig/finch-api/models/sandbox/jobs/sandbox_job_configuration.rbs +51 -0
  437. data/sig/finch-api/models/sandbox/payment_create_params.rbs +487 -0
  438. data/sig/finch-api/models/sandbox/payment_create_response.rbs +22 -0
  439. data/sig/finch-api/models/webhook_event.rbs +17 -0
  440. data/sig/finch-api/page.rbs +16 -0
  441. data/sig/finch-api/pooled_net_requester.rbs +28 -0
  442. data/sig/finch-api/request_options.rbs +40 -0
  443. data/sig/finch-api/resources/access_tokens.rbs +19 -0
  444. data/sig/finch-api/resources/account.rbs +25 -0
  445. data/sig/finch-api/resources/connect/sessions.rbs +40 -0
  446. data/sig/finch-api/resources/connect.rbs +9 -0
  447. data/sig/finch-api/resources/hris/benefits/individuals.rbs +58 -0
  448. data/sig/finch-api/resources/hris/benefits.rbs +64 -0
  449. data/sig/finch-api/resources/hris/company.rbs +18 -0
  450. data/sig/finch-api/resources/hris/directory.rbs +31 -0
  451. data/sig/finch-api/resources/hris/documents.rbs +33 -0
  452. data/sig/finch-api/resources/hris/employments.rbs +19 -0
  453. data/sig/finch-api/resources/hris/individuals.rbs +20 -0
  454. data/sig/finch-api/resources/hris/pay_statements.rbs +19 -0
  455. data/sig/finch-api/resources/hris/payments.rbs +20 -0
  456. data/sig/finch-api/resources/hris.rbs +23 -0
  457. data/sig/finch-api/resources/jobs/automated.rbs +42 -0
  458. data/sig/finch-api/resources/jobs/manual.rbs +20 -0
  459. data/sig/finch-api/resources/jobs.rbs +11 -0
  460. data/sig/finch-api/resources/payroll/pay_groups.rbs +31 -0
  461. data/sig/finch-api/resources/payroll.rbs +9 -0
  462. data/sig/finch-api/resources/providers.rbs +15 -0
  463. data/sig/finch-api/resources/request_forwarding.rbs +21 -0
  464. data/sig/finch-api/resources/sandbox/company.rbs +26 -0
  465. data/sig/finch-api/resources/sandbox/connections/accounts.rbs +34 -0
  466. data/sig/finch-api/resources/sandbox/connections.rbs +24 -0
  467. data/sig/finch-api/resources/sandbox/directory.rbs +19 -0
  468. data/sig/finch-api/resources/sandbox/employment.rbs +38 -0
  469. data/sig/finch-api/resources/sandbox/individual.rbs +32 -0
  470. data/sig/finch-api/resources/sandbox/jobs/configuration.rbs +31 -0
  471. data/sig/finch-api/resources/sandbox/jobs.rbs +21 -0
  472. data/sig/finch-api/resources/sandbox/payment.rbs +21 -0
  473. data/sig/finch-api/resources/sandbox.rbs +21 -0
  474. data/sig/finch-api/resources/webhooks.rbs +7 -0
  475. data/sig/finch-api/responses_page.rbs +14 -0
  476. data/sig/finch-api/single_page.rbs +18 -0
  477. data/sig/finch-api/util.rbs +109 -0
  478. data/sig/finch-api/version.rbs +3 -0
  479. metadata +536 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 260e53c135137f098cf627393777300544df0b1dfd30489389af1b5703ce2acd
4
+ data.tar.gz: 219d07fcc8c72e40aea5bdcc41e3de9eefae11f4dad02c7fa269d55df370276f
5
+ SHA512:
6
+ metadata.gz: 3b4f44ef66f40d2dea1c354c256983ed4749aad16e978cacfee6513cccf895fa0ca8fb9bbb3455ca75c85820772cc92caca029f6578b522d941d742932dd8f32
7
+ data.tar.gz: 342f5568ee0508357aeef589fc05eba8f06b119b3935ef6b4c83a04c16cb686085feacbd8f6083d785e39de6dfb121dcb2d8c6107744e8f828b855100357ca39
data/README.md ADDED
@@ -0,0 +1,124 @@
1
+ # Finch Ruby API library
2
+
3
+ The Finch Ruby library provides convenient access to the Finch REST API from any Ruby 3.0.0+
4
+ application.
5
+
6
+ It is generated with [Stainless](https://www.stainless.com/).
7
+
8
+ ## Documentation
9
+
10
+ Documentation for the most recent release of this gem can be found [on RubyDoc](https://gemdocs.org/gems/finch-api/latest).
11
+
12
+ The underlying REST API documentation can be found on [developer.tryfinch.com](https://developer.tryfinch.com/).
13
+
14
+ ## Installation
15
+
16
+ To use this gem during the beta, install directly from GitHub with Bundler by
17
+ adding the following to your application's `Gemfile`:
18
+
19
+ ```ruby
20
+ gem "finch-api", git: "https://github.com/Finch-API/finch-api-ruby", branch: "main"
21
+ ```
22
+
23
+ To fetch an initial copy of the gem:
24
+
25
+ ```sh
26
+ bundle install
27
+ ```
28
+
29
+ To update the version used by your application when updates are pushed to
30
+ GitHub:
31
+
32
+ ```sh
33
+ bundle update finch-api
34
+ ```
35
+
36
+ ## Usage
37
+
38
+ ```ruby
39
+ require "bundler/setup"
40
+ require "finch-api"
41
+
42
+ finch = FinchAPI::Client.new(access_token: "My Access Token")
43
+
44
+ page = finch.hris.directory.list
45
+
46
+ puts(page.id)
47
+ ```
48
+
49
+ ### Errors
50
+
51
+ When the library is unable to connect to the API, or if the API returns a
52
+ non-success status code (i.e., 4xx or 5xx response), a subclass of
53
+ `FinchAPI::Error` will be thrown:
54
+
55
+ ```ruby
56
+ begin
57
+ company = finch.hris.company.retrieve
58
+ rescue FinchAPI::Error => e
59
+ puts(e.status) # 400
60
+ end
61
+ ```
62
+
63
+ Error codes are as followed:
64
+
65
+ | Cause | Error Type |
66
+ | ---------------- | -------------------------- |
67
+ | HTTP 400 | `BadRequestError` |
68
+ | HTTP 401 | `AuthenticationError` |
69
+ | HTTP 403 | `PermissionDeniedError` |
70
+ | HTTP 404 | `NotFoundError` |
71
+ | HTTP 409 | `ConflictError` |
72
+ | HTTP 422 | `UnprocessableEntityError` |
73
+ | HTTP 429 | `RateLimitError` |
74
+ | HTTP >=500 | `InternalServerError` |
75
+ | Other HTTP error | `APIStatusError` |
76
+ | Timeout | `APITimeoutError` |
77
+ | Network error | `APIConnectionError` |
78
+
79
+ ### Retries
80
+
81
+ Certain errors will be automatically retried 2 times by default, with a short
82
+ exponential backoff. Connection errors (for example, due to a network
83
+ connectivity problem), 408 Request Timeout, 409 Conflict, 429 Rate Limit, >=500 Internal errors,
84
+ and timeouts will all be retried by default.
85
+
86
+ You can use the `max_retries` option to configure or disable this:
87
+
88
+ ```ruby
89
+ # Configure the default for all requests:
90
+ finch = FinchAPI::Client.new(
91
+ max_retries: 0 # default is 2
92
+ )
93
+
94
+ # Or, configure per-request:
95
+ finch.hris.directory.list(request_options: {max_retries: 5})
96
+ ```
97
+
98
+ ### Timeouts
99
+
100
+ By default, requests will time out after 60 seconds.
101
+ Timeouts are applied separately to the initial connection and the overall request time,
102
+ so in some cases a request could wait 2\*timeout seconds before it fails.
103
+
104
+ You can use the `timeout` option to configure or disable this:
105
+
106
+ ```ruby
107
+ # Configure the default for all requests:
108
+ finch = FinchAPI::Client.new(
109
+ timeout: nil # default is 60
110
+ )
111
+
112
+ # Or, configure per-request:
113
+ finch.hris.directory.list(request_options: {timeout: 5})
114
+ ```
115
+
116
+ ## Versioning
117
+
118
+ This package follows [SemVer](https://semver.org/spec/v2.0.0.html) conventions. As the
119
+ library is in initial development and has a major version of `0`, APIs may change
120
+ at any time.
121
+
122
+ ## Requirements
123
+
124
+ Ruby 3.0 or higher.
@@ -0,0 +1,464 @@
1
+ # frozen_string_literal: true
2
+
3
+ module FinchAPI
4
+ # @private
5
+ #
6
+ # @abstract
7
+ #
8
+ class BaseClient
9
+ # from whatwg fetch spec
10
+ MAX_REDIRECTS = 20
11
+
12
+ # rubocop:disable Style/MutableConstant
13
+ PLATFORM_HEADERS = {
14
+ "x-stainless-arch" => FinchAPI::Util.arch,
15
+ "x-stainless-lang" => "ruby",
16
+ "x-stainless-os" => FinchAPI::Util.os,
17
+ "x-stainless-package-version" => FinchAPI::VERSION,
18
+ "x-stainless-runtime" => ::RUBY_ENGINE,
19
+ "x-stainless-runtime-version" => ::RUBY_ENGINE_VERSION
20
+ }
21
+ # rubocop:enable Style/MutableConstant
22
+
23
+ class << self
24
+ # @private
25
+ #
26
+ # @param req [Hash{Symbol=>Object}]
27
+ #
28
+ # @raise [ArgumentError]
29
+ #
30
+ def validate!(req)
31
+ keys = [:method, :path, :query, :headers, :body, :unwrap, :page, :stream, :model, :options]
32
+ case req
33
+ in Hash
34
+ req.each_key do |k|
35
+ unless keys.include?(k)
36
+ raise ArgumentError.new("Request `req` keys must be one of #{keys}, got #{k.inspect}")
37
+ end
38
+ end
39
+ else
40
+ raise ArgumentError.new("Request `req` must be a Hash or RequestOptions, got #{req.inspect}")
41
+ end
42
+ end
43
+
44
+ # @private
45
+ #
46
+ # @param status [Integer]
47
+ # @param headers [Hash{String=>String}, Net::HTTPHeader]
48
+ #
49
+ # @return [Boolean]
50
+ #
51
+ def should_retry?(status, headers:)
52
+ coerced = FinchAPI::Util.coerce_boolean(headers["x-should-retry"])
53
+ case [coerced, status]
54
+ in [true | false, _]
55
+ coerced
56
+ in [_, 408 | 409 | 429 | (500..)]
57
+ # retry on:
58
+ # 408: timeouts
59
+ # 409: locks
60
+ # 429: rate limits
61
+ # 500+: unknown errors
62
+ true
63
+ else
64
+ false
65
+ end
66
+ end
67
+
68
+ # @private
69
+ #
70
+ # @param request [Hash{Symbol=>Object}] .
71
+ #
72
+ # @option request [Symbol] :method
73
+ #
74
+ # @option request [URI::Generic] :url
75
+ #
76
+ # @option request [Hash{String=>String}] :headers
77
+ #
78
+ # @option request [Object] :body
79
+ #
80
+ # @option request [Integer] :max_retries
81
+ #
82
+ # @option request [Float] :timeout
83
+ #
84
+ # @param status [Integer]
85
+ #
86
+ # @param response_headers [Hash{String=>String}, Net::HTTPHeader]
87
+ #
88
+ # @return [Hash{Symbol=>Object}]
89
+ #
90
+ def follow_redirect(request, status:, response_headers:)
91
+ method, url, headers = request.fetch_values(:method, :url, :headers)
92
+ location =
93
+ Kernel.then do
94
+ URI.join(url, response_headers["location"])
95
+ rescue ArgumentError
96
+ message = "Server responded with status #{status} but no valid location header."
97
+ raise FinchAPI::APIConnectionError.new(url: url, message: message)
98
+ end
99
+
100
+ request = {**request, url: location}
101
+
102
+ case [url.scheme, location.scheme]
103
+ in ["https", "http"]
104
+ message = "Tried to redirect to a insecure URL"
105
+ raise FinchAPI::APIConnectionError.new(url: url, message: message)
106
+ else
107
+ nil
108
+ end
109
+
110
+ # from whatwg fetch spec
111
+ case [status, method]
112
+ in [301 | 302, :post] | [303, _]
113
+ drop = %w[content-encoding content-language content-length content-location content-type]
114
+ request = {
115
+ **request,
116
+ method: method == :head ? :head : :get,
117
+ headers: headers.except(*drop),
118
+ body: nil
119
+ }
120
+ else
121
+ end
122
+
123
+ # from undici
124
+ if FinchAPI::Util.uri_origin(url) != FinchAPI::Util.uri_origin(location)
125
+ drop = %w[authorization cookie host proxy-authorization]
126
+ request = {**request, headers: request.fetch(:headers).except(*drop)}
127
+ end
128
+
129
+ request
130
+ end
131
+ end
132
+
133
+ # @private
134
+ #
135
+ # @return [FinchAPI::PooledNetRequester]
136
+ attr_accessor :requester
137
+
138
+ # @private
139
+ #
140
+ # @param base_url [String]
141
+ # @param timeout [Float]
142
+ # @param max_retries [Integer]
143
+ # @param initial_retry_delay [Float]
144
+ # @param max_retry_delay [Float]
145
+ # @param headers [Hash{String=>String, Integer, Array<String, Integer, nil>, nil}]
146
+ # @param idempotency_header [String, nil]
147
+ #
148
+ def initialize(
149
+ base_url:,
150
+ timeout: 0.0,
151
+ max_retries: 0,
152
+ initial_retry_delay: 0.0,
153
+ max_retry_delay: 0.0,
154
+ headers: {},
155
+ idempotency_header: nil
156
+ )
157
+ @requester = FinchAPI::PooledNetRequester.new
158
+ @headers = FinchAPI::Util.normalized_headers(
159
+ self.class::PLATFORM_HEADERS,
160
+ {
161
+ "accept" => "application/json",
162
+ "content-type" => "application/json"
163
+ },
164
+ headers
165
+ )
166
+ @base_url = FinchAPI::Util.parse_uri(base_url)
167
+ @idempotency_header = idempotency_header&.to_s&.downcase
168
+ @max_retries = max_retries
169
+ @timeout = timeout
170
+ @initial_retry_delay = initial_retry_delay
171
+ @max_retry_delay = max_retry_delay
172
+ end
173
+
174
+ # @private
175
+ #
176
+ # @return [Hash{String=>String}]
177
+ #
178
+ private def auth_headers = {}
179
+
180
+ # @private
181
+ #
182
+ # @return [String]
183
+ #
184
+ private def generate_idempotency_key = "stainless-ruby-retry-#{SecureRandom.uuid}"
185
+
186
+ # @private
187
+ #
188
+ # @param req [Hash{Symbol=>Object}] .
189
+ #
190
+ # @option req [Symbol] :method
191
+ #
192
+ # @option req [String, Array<String>] :path
193
+ #
194
+ # @option req [Hash{String=>Array<String>, String, nil}, nil] :query
195
+ #
196
+ # @option req [Hash{String=>String, Integer, Array<String, Integer, nil>, nil}, nil] :headers
197
+ #
198
+ # @option req [Object, nil] :body
199
+ #
200
+ # @option req [Symbol, nil] :unwrap
201
+ #
202
+ # @option req [Class, nil] :page
203
+ #
204
+ # @option req [Class, nil] :stream
205
+ #
206
+ # @option req [FinchAPI::Converter, Class, nil] :model
207
+ #
208
+ # @param opts [Hash{Symbol=>Object}] .
209
+ #
210
+ # @option opts [String, nil] :idempotency_key
211
+ #
212
+ # @option opts [Hash{String=>Array<String>, String, nil}, nil] :extra_query
213
+ #
214
+ # @option opts [Hash{String=>String, nil}, nil] :extra_headers
215
+ #
216
+ # @option opts [Hash{Symbol=>Object}, nil] :extra_body
217
+ #
218
+ # @option opts [Integer, nil] :max_retries
219
+ #
220
+ # @option opts [Float, nil] :timeout
221
+ #
222
+ # @return [Hash{Symbol=>Object}]
223
+ #
224
+ private def build_request(req, opts)
225
+ method, uninterpolated_path = req.fetch_values(:method, :path)
226
+
227
+ path = FinchAPI::Util.interpolate_path(uninterpolated_path)
228
+
229
+ query = FinchAPI::Util.deep_merge(req[:query].to_h, opts[:extra_query].to_h)
230
+
231
+ headers = FinchAPI::Util.normalized_headers(
232
+ @headers,
233
+ auth_headers,
234
+ req[:headers].to_h,
235
+ opts[:extra_headers].to_h
236
+ )
237
+
238
+ if @idempotency_header &&
239
+ !headers.key?(@idempotency_header) &&
240
+ !Net::HTTP::IDEMPOTENT_METHODS_.include?(method.to_s.upcase)
241
+ headers[@idempotency_header] = opts.fetch(:idempotency_key) { generate_idempotency_key }
242
+ end
243
+
244
+ unless headers.key?("x-stainless-retry-count")
245
+ headers["x-stainless-retry-count"] = "0"
246
+ end
247
+
248
+ timeout = opts.fetch(:timeout, @timeout).to_f.clamp((0..))
249
+ unless headers.key?("x-stainless-read-timeout") || timeout.zero?
250
+ headers["x-stainless-read-timeout"] = timeout.to_s
251
+ end
252
+
253
+ headers.reject! { |_, v| v.to_s.empty? }
254
+
255
+ body =
256
+ case method
257
+ in :get | :head | :options | :trace
258
+ nil
259
+ else
260
+ FinchAPI::Util.deep_merge(*[req[:body], opts[:extra_body]].compact)
261
+ end
262
+
263
+ headers, encoded = FinchAPI::Util.encode_content(headers, body)
264
+ {
265
+ method: method,
266
+ url: FinchAPI::Util.join_parsed_uri(@base_url, {**req, path: path, query: query}),
267
+ headers: headers,
268
+ body: encoded,
269
+ max_retries: opts.fetch(:max_retries, @max_retries),
270
+ timeout: timeout
271
+ }
272
+ end
273
+
274
+ # @private
275
+ #
276
+ # @param headers [Hash{String=>String}]
277
+ # @param retry_count [Integer]
278
+ #
279
+ # @return [Float]
280
+ #
281
+ private def retry_delay(headers, retry_count:)
282
+ # Non-standard extension
283
+ span = Float(headers["retry-after-ms"], exception: false)&.then { _1 / 1000 }
284
+ return span if span
285
+
286
+ retry_header = headers["retry-after"]
287
+ return span if (span = Float(retry_header, exception: false))
288
+
289
+ span = retry_header&.then do
290
+ Time.httpdate(_1) - Time.now
291
+ rescue ArgumentError
292
+ nil
293
+ end
294
+ return span if span
295
+
296
+ scale = retry_count**2
297
+ jitter = 1 - (0.25 * rand)
298
+ (@initial_retry_delay * scale * jitter).clamp(0, @max_retry_delay)
299
+ end
300
+
301
+ # @private
302
+ #
303
+ # @param request [Hash{Symbol=>Object}] .
304
+ #
305
+ # @option request [Symbol] :method
306
+ #
307
+ # @option request [URI::Generic] :url
308
+ #
309
+ # @option request [Hash{String=>String}] :headers
310
+ #
311
+ # @option request [Object] :body
312
+ #
313
+ # @option request [Integer] :max_retries
314
+ #
315
+ # @option request [Float] :timeout
316
+ #
317
+ # @param redirect_count [Integer]
318
+ #
319
+ # @param retry_count [Integer]
320
+ #
321
+ # @param send_retry_header [Boolean]
322
+ #
323
+ # @raise [FinchAPI::APIError]
324
+ # @return [Array(Integer, Net::HTTPResponse, Enumerable)]
325
+ #
326
+ private def send_request(request, redirect_count:, retry_count:, send_retry_header:)
327
+ url, headers, max_retries, timeout = request.fetch_values(:url, :headers, :max_retries, :timeout)
328
+ input = {**request.except(:timeout), deadline: FinchAPI::Util.monotonic_secs + timeout}
329
+
330
+ if send_retry_header
331
+ headers["x-stainless-retry-count"] = retry_count.to_s
332
+ end
333
+
334
+ begin
335
+ response, stream = @requester.execute(input)
336
+ status = Integer(response.code)
337
+ rescue FinchAPI::APIConnectionError => e
338
+ status = e
339
+ end
340
+
341
+ # normally we want to drain the response body and reuse the HTTP session by clearing the socket buffers
342
+ # unless we hit a server error
343
+ srv_fault = (500...).include?(status)
344
+
345
+ case status
346
+ in ..299
347
+ [status, response, stream]
348
+ in 300..399 if redirect_count >= self.class::MAX_REDIRECTS
349
+ message = "Failed to complete the request within #{self.class::MAX_REDIRECTS} redirects."
350
+
351
+ stream.each { next }
352
+ raise FinchAPI::APIConnectionError.new(url: url, message: message)
353
+ in 300..399
354
+ request = self.class.follow_redirect(request, status: status, response_headers: response)
355
+
356
+ stream.each { next }
357
+ send_request(
358
+ request,
359
+ redirect_count: redirect_count + 1,
360
+ retry_count: retry_count,
361
+ send_retry_header: send_retry_header
362
+ )
363
+ in FinchAPI::APIConnectionError if retry_count >= max_retries
364
+ raise status
365
+ in (400..) if retry_count >= max_retries || !self.class.should_retry?(status, headers: response)
366
+ decoded = FinchAPI::Util.decode_content(response, stream: stream, suppress_error: true)
367
+
368
+ if srv_fault
369
+ FinchAPI::Util.close_fused!(stream)
370
+ else
371
+ stream.each { next }
372
+ end
373
+
374
+ raise FinchAPI::APIStatusError.for(
375
+ url: url,
376
+ status: status,
377
+ body: decoded,
378
+ request: nil,
379
+ response: response
380
+ )
381
+ in (400..) | FinchAPI::APIConnectionError
382
+ delay = retry_delay(response, retry_count: retry_count)
383
+
384
+ if srv_fault
385
+ FinchAPI::Util.close_fused!(stream)
386
+ else
387
+ stream&.each { next }
388
+ end
389
+ sleep(delay)
390
+
391
+ send_request(
392
+ request,
393
+ redirect_count: redirect_count,
394
+ retry_count: retry_count + 1,
395
+ send_retry_header: send_retry_header
396
+ )
397
+ end
398
+ end
399
+
400
+ # Execute the request specified by `req`. This is the method that all resource
401
+ # methods call into.
402
+ #
403
+ # @param req [Hash{Symbol=>Object}] .
404
+ #
405
+ # @option req [Symbol] :method
406
+ #
407
+ # @option req [String, Array<String>] :path
408
+ #
409
+ # @option req [Hash{String=>Array<String>, String, nil}, nil] :query
410
+ #
411
+ # @option req [Hash{String=>String, Integer, Array<String, Integer, nil>, nil}, nil] :headers
412
+ #
413
+ # @option req [Object, nil] :body
414
+ #
415
+ # @option req [Symbol, nil] :unwrap
416
+ #
417
+ # @option req [Class, nil] :page
418
+ #
419
+ # @option req [Class, nil] :stream
420
+ #
421
+ # @option req [FinchAPI::Converter, Class, nil] :model
422
+ #
423
+ # @option req [FinchAPI::RequestOptions, Hash{Symbol=>Object}, nil] :options
424
+ #
425
+ # @raise [FinchAPI::APIError]
426
+ # @return [Object]
427
+ #
428
+ def request(req)
429
+ self.class.validate!(req)
430
+ model = req.fetch(:model) { FinchAPI::Unknown }
431
+ opts = req[:options].to_h
432
+ FinchAPI::RequestOptions.validate!(opts)
433
+ request = build_request(req.except(:options), opts)
434
+ url = request.fetch(:url)
435
+
436
+ # Don't send the current retry count in the headers if the caller modified the header defaults.
437
+ send_retry_header = request.fetch(:headers)["x-stainless-retry-count"] == "0"
438
+ status, response, stream = send_request(
439
+ request,
440
+ redirect_count: 0,
441
+ retry_count: 0,
442
+ send_retry_header: send_retry_header
443
+ )
444
+
445
+ decoded = FinchAPI::Util.decode_content(response, stream: stream)
446
+ case req
447
+ in { stream: Class => st }
448
+ st.new(model: model, url: url, status: status, response: response, messages: decoded)
449
+ in { page: Class => page }
450
+ page.new(client: self, req: req, headers: response, unwrapped: decoded)
451
+ else
452
+ unwrapped = FinchAPI::Util.dig(decoded, req[:unwrap])
453
+ FinchAPI::Converter.coerce(model, unwrapped)
454
+ end
455
+ end
456
+
457
+ # @return [String]
458
+ #
459
+ def inspect
460
+ base_url = FinchAPI::Util.unparse_uri(@base_url)
461
+ "#<#{self.class.name}:0x#{object_id.to_s(16)} base_url=#{base_url} max_retries=#{@max_retries} timeout=#{@timeout}>"
462
+ end
463
+ end
464
+ end