<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"
        integrity="sha384-GLhlTQ8iRABdZLl6O3oVMWSktQOp6b7In1Zl3/Jr59b6EGGoI1aFkw7cmDA6j6gD" crossorigin="anonymous">
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.3.0/css/all.min.css"
        integrity="sha512-SzlrxWUlpfuzQ+pcUCosxcglQRNAq/DZjVsC0lE40xsADsfeQoEypE+enwcOiGjk/bSuGGKHEyjSoQ1zVisanQ=="
        crossorigin="anonymous" referrerpolicy="no-referrer" />
</head>
</html>
<?php

declare(strict_types=1);

namespace Automattic\WooCommerce\Api;

/**
 * Exception for API errors with error codes and extensions.
 */
class ApiException extends \RuntimeException {
	/**
	 * Constructor.
	 *
	 * @param string      $message    The error message.
	 * @param string      $error_code The machine-readable error code.
	 * @param array       $extensions Additional error metadata.
	 * @param int         $status_code The HTTP status code.
	 * @param ?\Throwable $previous   The previous throwable for chaining.
	 */
	public function __construct(
		string $message,
		private readonly string $error_code = 'INTERNAL_ERROR',
		private readonly array $extensions = array(),
		int $status_code = 500,
		?\Throwable $previous = null,
	) {
		parent::__construct( $message, $status_code, $previous );
	}

	/**
	 * Get the machine-readable error code.
	 *
	 * @return string
	 */
	public function getErrorCode(): string {
		return $this->error_code;
	}

	/**
	 * Get the additional error metadata.
	 *
	 * @return array
	 */
	public function getExtensions(): array {
		return $this->extensions;
	}

	/**
	 * Get the HTTP status code.
	 *
	 * @return int
	 */
	public function getStatusCode(): int {
		return $this->getCode();
	}
}
