OrderResponseData.php 7.5 KB

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