PagarmeOrderResponseData.php 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  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 static function fromArray(array $payload): self
  137. {
  138. return new self(
  139. id: $payload['id'] ?? null,
  140. code: $payload['code'] ?? null,
  141. amount: isset($payload['amount']) ? (int) $payload['amount'] : null,
  142. currency: $payload['currency'] ?? null,
  143. closed: $payload['closed'] ?? null,
  144. status: $payload['status'] ?? null,
  145. items: array_map(
  146. static fn (array $item) => PagarmeOrderItemResponseData::fromArray($item),
  147. $payload['items'] ?? [],
  148. ),
  149. customer: ! empty($payload['customer'])
  150. ? PagarmeCustomerResponseData::fromArray($payload['customer'])
  151. : null,
  152. charges: array_map(
  153. static fn (array $charge) => PagarmeOrderChargeResponseData::fromArray($charge),
  154. $payload['charges'] ?? [],
  155. ),
  156. checkouts: array_map(
  157. static fn (array $checkout) => PagarmeOrderCheckoutResponseData::fromArray($checkout),
  158. $payload['checkouts'] ?? [],
  159. ),
  160. metadata: $payload['metadata'] ?? [],
  161. createdAt: $payload['created_at'] ?? null,
  162. updatedAt: $payload['updated_at'] ?? null,
  163. closedAt: $payload['closed_at'] ?? null,
  164. );
  165. }
  166. public function toArray(): array
  167. {
  168. return [
  169. 'id' => $this->id,
  170. 'code' => $this->code,
  171. 'amount' => $this->amount,
  172. 'currency' => $this->currency,
  173. 'closed' => $this->closed,
  174. 'items' => array_map(
  175. static fn (PagarmeOrderItemResponseData $item) => $item->toArray(),
  176. $this->items,
  177. ),
  178. 'customer' => $this->customer?->toArray(),
  179. 'status' => $this->status,
  180. 'created_at' => $this->createdAt,
  181. 'updated_at' => $this->updatedAt,
  182. 'closed_at' => $this->closedAt,
  183. 'charges' => array_map(
  184. static fn (PagarmeOrderChargeResponseData $charge) => $charge->toArray(),
  185. $this->charges,
  186. ),
  187. 'checkouts' => array_map(
  188. static fn (PagarmeOrderCheckoutResponseData $checkout) => $checkout->toArray(),
  189. $this->checkouts,
  190. ),
  191. 'metadata' => $this->metadata,
  192. ];
  193. }
  194. //
  195. private function filledValue(mixed $value): ?string
  196. {
  197. if ($value === null || $value === '' || $value === []) {
  198. return null;
  199. }
  200. return (string) $value;
  201. }
  202. }