PagarmeOrderResponseData.php 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. <?php
  2. namespace App\Data\Pagarme\Response\PagarmeOrderResponseData;
  3. use App\Data\Pagarme\Response\PagarmeCustomerResponseData\PagarmeCustomerResponseData;
  4. use App\Data\Pagarme\Response\PagarmeOrderResponseData\PagarmeOrderChargeResponseData\PagarmeOrderChargeResponseData;
  5. use App\Data\Pagarme\Response\PagarmeOrderResponseData\PagarmeOrderChargeResponseData\PagarmeOrderTransactionResponseData;
  6. use App\Enums\PaymentStatusEnum;
  7. /**
  8. * @param PagarmeOrderItemResponseData[] $items
  9. * @param PagarmeOrderChargeResponseData[] $charges
  10. * @param PagarmeOrderCheckoutResponseData[] $checkouts
  11. */
  12. final readonly class PagarmeOrderResponseData
  13. {
  14. public function __construct(
  15. public ?string $id,
  16. public ?string $code,
  17. public ?int $amount,
  18. public ?string $currency,
  19. public ?bool $closed,
  20. public ?string $status,
  21. public array $items,
  22. public ?PagarmeCustomerResponseData $customer,
  23. public array $charges,
  24. public array $checkouts,
  25. public array $metadata,
  26. public ?string $createdAt = null,
  27. public ?string $updatedAt = null,
  28. public ?string $closedAt = null,
  29. ) {}
  30. public function authorizedAt(): ?string
  31. {
  32. $transaction = $this->lastTransaction();
  33. if (! $transaction) {
  34. return null;
  35. }
  36. if (in_array($transaction->status, ['authorized_pending_capture', 'captured', 'partial_capture'], true)) {
  37. return $transaction->createdAt;
  38. }
  39. return null;
  40. }
  41. public function failureCode(): ?string
  42. {
  43. $transaction = $this->lastTransaction();
  44. if (! $transaction) {
  45. return null;
  46. }
  47. return $this->filledValue($transaction->gatewayResponse['code'] ?? null);
  48. }
  49. public function failureMessage(): ?string
  50. {
  51. $transaction = $this->lastTransaction();
  52. if (! $transaction) {
  53. return null;
  54. }
  55. $acquirerMessage = $this->filledValue($transaction->acquirerMessage);
  56. if ($acquirerMessage) {
  57. return $acquirerMessage;
  58. }
  59. $gatewayErrors = $transaction->gatewayResponse['errors'] ?? [];
  60. if (! is_array($gatewayErrors) || empty($gatewayErrors)) {
  61. return null;
  62. }
  63. $message = collect($gatewayErrors)
  64. ->pluck('message')
  65. ->filter()
  66. ->implode('; ') ?: null;
  67. if ($message && str_contains($message, 'Sem ambiente configurado')) {
  68. return 'Pix não esta habilitado ou configurado neste ambiente do Pagar.me.';
  69. }
  70. return $message;
  71. }
  72. public function firstCharge(): ?PagarmeOrderChargeResponseData
  73. {
  74. return $this->charges[0] ?? null;
  75. }
  76. public function gatewayEntityLabel(): string
  77. {
  78. $charge = $this->firstCharge();
  79. return $charge?->id ? 'charge' : 'order';
  80. }
  81. public function gatewayEntityReference(): ?string
  82. {
  83. $charge = $this->firstCharge();
  84. return $charge?->id ?? $this->id;
  85. }
  86. public function gatewayOperationLabel(): string
  87. {
  88. $charge = $this->firstCharge();
  89. $transaction = $this->lastTransaction();
  90. return $transaction?->id ? 'transaction' : ($charge?->id ? 'charge' : 'order');
  91. }
  92. public function gatewayOperationReference(): ?string
  93. {
  94. $charge = $this->firstCharge();
  95. $transaction = $this->lastTransaction();
  96. return $transaction?->id ?? $charge?->id ?? $this->id;
  97. }
  98. public function id(): ?string
  99. {
  100. return $this->id;
  101. }
  102. public function lastTransaction(): ?PagarmeOrderTransactionResponseData
  103. {
  104. return $this->firstCharge()?->transaction();
  105. }
  106. public function paymentStatus(): PaymentStatusEnum
  107. {
  108. $charge = $this->firstCharge();
  109. $transaction = $this->lastTransaction();
  110. $status = strtolower((string) ($transaction?->status ?: $charge?->status));
  111. return match ($status) {
  112. 'captured', 'paid', 'overpaid' => PaymentStatusEnum::PAID,
  113. 'authorized_pending_capture', 'waiting_capture' => PaymentStatusEnum::AUTHORIZED,
  114. 'pending', 'waiting_payment' => PaymentStatusEnum::PENDING,
  115. 'processing' => PaymentStatusEnum::PROCESSING,
  116. 'not_authorized', 'with_error', 'failed',
  117. 'underpaid', 'chargedback' => PaymentStatusEnum::FAILED,
  118. 'voided', 'partial_void', 'canceled',
  119. 'cancelled', 'refunded', 'partial_refunded',
  120. 'partial_canceled' => PaymentStatusEnum::CANCELLED,
  121. default => PaymentStatusEnum::PENDING,
  122. };
  123. }
  124. public function paidAt(): ?string
  125. {
  126. return $this->firstCharge()?->paidAt;
  127. }
  128. public function requireId(): string
  129. {
  130. if (! $this->id) {
  131. throw new \RuntimeException('Pagar.me order creation returned an empty id.');
  132. }
  133. return $this->id;
  134. }
  135. //
  136. public function toArray(): array
  137. {
  138. return [
  139. 'id' => $this->id,
  140. 'code' => $this->code,
  141. 'amount' => $this->amount,
  142. 'currency' => $this->currency,
  143. 'closed' => $this->closed,
  144. 'items' => array_map(
  145. static fn (PagarmeOrderItemResponseData $item) => $item->toArray(),
  146. $this->items,
  147. ),
  148. 'customer' => $this->customer?->toArray(),
  149. 'status' => $this->status,
  150. 'created_at' => $this->createdAt,
  151. 'updated_at' => $this->updatedAt,
  152. 'closed_at' => $this->closedAt,
  153. 'charges' => array_map(
  154. static fn (PagarmeOrderChargeResponseData $charge) => $charge->toArray(),
  155. $this->charges,
  156. ),
  157. 'checkouts' => array_map(
  158. static fn (PagarmeOrderCheckoutResponseData $checkout) => $checkout->toArray(),
  159. $this->checkouts,
  160. ),
  161. 'metadata' => $this->metadata,
  162. ];
  163. }
  164. //
  165. private function filledValue(mixed $value): ?string
  166. {
  167. if ($value === null || $value === '' || $value === []) {
  168. return null;
  169. }
  170. return (string) $value;
  171. }
  172. }