PagarmeRecipientService.php 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. <?php
  2. namespace App\Services\Pagarme;
  3. use App\Data\Pagarme\Request\BankAccountUpdateRequestData;
  4. use App\Data\Pagarme\Request\RecipientRequestData\RecipientAutomaticAnticipationSettingsData;
  5. use App\Data\Pagarme\Request\RecipientRequestData\RecipientBankAccountData;
  6. use App\Data\Pagarme\Request\RecipientRequestData\RecipientRegisterInformationData\RecipientAddressData;
  7. use App\Data\Pagarme\Request\RecipientRequestData\RecipientRegisterInformationData\RecipientPhoneNumbersData\RecipientPhoneData;
  8. use App\Data\Pagarme\Request\RecipientRequestData\RecipientRegisterInformationData\RecipientPhoneNumbersData\RecipientPhoneNumbersData;
  9. use App\Data\Pagarme\Request\RecipientRequestData\RecipientRegisterInformationData\RecipientRegisterInformationData;
  10. use App\Data\Pagarme\Request\RecipientRequestData\RecipientRequestData;
  11. use App\Data\Pagarme\Request\RecipientRequestData\RecipientTransferSettingsData;
  12. use App\Data\Pagarme\Response\RecipientResponseData\RecipientResponseData;
  13. use App\Models\Provider;
  14. use App\Services\Pagarme\Concerns\FormatsPagarmeData;
  15. use App\Services\Pagarme\Concerns\SendsPagarmeRequests;
  16. class PagarmeRecipientService
  17. {
  18. use FormatsPagarmeData;
  19. use SendsPagarmeRequests;
  20. public function createRecipientForProvider(Provider $provider, array $data): string
  21. {
  22. if (! empty($provider->recipient_id)) {
  23. return $provider->recipient_id;
  24. }
  25. $metadata = $data['recipient_metadata'] ?? [];
  26. $paymentMode = $data['recipient_payment_mode'];
  27. $recipientCode = $provider->ensureGatewayCode();
  28. $addressParts = $this->extractAddressParts($data);
  29. $registerInformation = new RecipientRegisterInformationData(
  30. name: $data['recipient_name'],
  31. email: $data['recipient_email'],
  32. document: $this->digits($data['recipient_document'] ?? null),
  33. type: $data['recipient_type'] ?? 'individual',
  34. birthdate: $this->formatBirthdate($data['birth_date'] ?? null),
  35. monthlyIncome: isset($data['monthly_income']) ? (int) $data['monthly_income'] : 1000,
  36. professionalOccupation: $data['professional_occupation'] ?? 'autonomo',
  37. phoneNumbers: new RecipientPhoneNumbersData(
  38. $this->buildRecipientPhone($data['phone'] ?? null),
  39. ),
  40. address: new RecipientAddressData(
  41. street: $data['address'],
  42. complementary: $addressParts['complementary'],
  43. streetNumber: $addressParts['street_number'],
  44. neighborhood: $addressParts['neighborhood'],
  45. city: $data['city'] ?? null,
  46. state: $data['state'] ?? null,
  47. zipCode: $this->digits($data['zip_code'] ?? null),
  48. referencePoint: $addressParts['reference_point'],
  49. ),
  50. );
  51. $defaultBankAccount = $this->buildRecipientBankAccount(
  52. $data['recipient_default_bank_account'],
  53. );
  54. $payload = new RecipientRequestData(
  55. code: $recipientCode,
  56. registerInformation: $registerInformation,
  57. defaultBankAccount: $defaultBankAccount,
  58. transferSettings: new RecipientTransferSettingsData(
  59. transferEnabled: false,
  60. transferInterval: 'Daily',
  61. transferDay: 0,
  62. ),
  63. automaticAnticipationSettings: new RecipientAutomaticAnticipationSettingsData(
  64. enabled: false,
  65. ),
  66. );
  67. $bankAccountData = $payload->defaultBankAccount->toArray();
  68. $raw = $this->pagarmeRequest(
  69. method: 'POST',
  70. path: '/recipients',
  71. payload: $payload,
  72. idempotencyKey: $this->idempotencyKey($provider->id),
  73. errorMessage: 'Erro ao criar recebedor no Pagar.me.',
  74. );
  75. $recipientData = RecipientResponseData::fromArray($raw);
  76. $recipientId = $recipientData->requireId();
  77. $provider->forceFill([
  78. 'recipient_id' => $recipientId,
  79. 'recipient_name' => $data['recipient_name'],
  80. 'recipient_email' => $data['recipient_email'],
  81. 'recipient_description' => $data['recipient_description'],
  82. 'recipient_document' => $data['recipient_document'],
  83. 'recipient_type' => $payload->registerInformation->type,
  84. 'recipient_code' => $recipientCode,
  85. 'recipient_payment_mode' => $paymentMode,
  86. 'recipient_default_bank_account' => $bankAccountData,
  87. 'recipient_transfer_settings' => [
  88. 'transfer_enabled' => false,
  89. 'transfer_interval' => 'daily',
  90. 'transfer_day' => 0,
  91. ],
  92. 'recipient_automatic_anticipation_settings' => [
  93. 'enabled' => false,
  94. ],
  95. 'recipient_metadata' => $metadata,
  96. ])->save();
  97. return $recipientId;
  98. }
  99. public function updateDefaultBankAccount(Provider $provider, array $bankAccountData): Provider
  100. {
  101. $payload = new BankAccountUpdateRequestData(
  102. holderName: $this->normalizeHolderName($bankAccountData['holder_name']),
  103. holderType: $bankAccountData['holder_type'],
  104. holderDocument: $this->digits($bankAccountData['holder_document']),
  105. bank: $bankAccountData['bank'],
  106. branchNumber: $bankAccountData['branch_number'],
  107. branchCheckDigit: $bankAccountData['branch_check_digit'] ?? null,
  108. accountNumber: $bankAccountData['account_number'],
  109. accountCheckDigit: $bankAccountData['account_check_digit'],
  110. type: $bankAccountData['type'],
  111. );
  112. $raw = $this->pagarmeRequest(
  113. method: 'PATCH',
  114. path: "/recipients/{$provider->recipient_id}/default-bank-account",
  115. payload: $payload,
  116. idempotencyKey: $this->idempotencyKey($provider->id, 'default-bank-account-'.sha1(json_encode($payload->toArray()))),
  117. errorMessage: 'Erro ao atualizar conta bancaria do recebedor no Pagar.me.',
  118. );
  119. $recipientData = RecipientResponseData::fromArray($raw);
  120. $provider->forceFill([
  121. 'recipient_default_bank_account' => $recipientData->defaultBankAccount?->toArray() ?: $payload->toArray()['bank_account'],
  122. ])->save();
  123. return $provider->fresh();
  124. }
  125. //
  126. private function buildRecipientBankAccount(array $data): RecipientBankAccountData
  127. {
  128. return new RecipientBankAccountData(
  129. holderName: $this->normalizeHolderName($data['holder_name']),
  130. holderType: $data['holder_type'],
  131. holderDocument: $this->digits($data['holder_document']),
  132. bank: $data['bank'],
  133. branchNumber: $data['branch_number'],
  134. branchCheckDigit: $data['branch_check_digit'] ?? null,
  135. accountNumber: $data['account_number'],
  136. accountCheckDigit: $data['account_check_digit'],
  137. type: $data['type'],
  138. );
  139. }
  140. private function buildRecipientPhone(?string $phone): RecipientPhoneData
  141. {
  142. $digits = $this->digits($phone);
  143. if (strlen($digits) < 10) {
  144. return new RecipientPhoneData(
  145. ddd: '11',
  146. number: '999999999',
  147. type: 'mobile',
  148. );
  149. }
  150. if (str_starts_with($digits, '55')) {
  151. $digits = substr($digits, 2);
  152. }
  153. return new RecipientPhoneData(
  154. ddd: substr($digits, 0, 2),
  155. number: substr($digits, 2),
  156. type: 'mobile',
  157. );
  158. }
  159. // evita criacao duplica de recipient
  160. private function idempotencyKey(int $providerId, string $suffix = 'recipient'): string
  161. {
  162. return "provider-{$providerId}-{$suffix}";
  163. }
  164. }