mirror of
https://github.com/anikeen-com/id.git
synced 2026-03-14 06:06:18 +00:00
115 lines
3.8 KiB
PHP
115 lines
3.8 KiB
PHP
<?php
|
|
|
|
namespace Anikeen\Id\Resources;
|
|
|
|
use Anikeen\Id\Concerns\HasBillable;
|
|
use Anikeen\Id\Exceptions\RequestRequiresClientIdException;
|
|
use GuzzleHttp\Exception\GuzzleException;
|
|
|
|
/**
|
|
* @property string $id
|
|
*/
|
|
class Order extends BaseResource
|
|
{
|
|
use HasBillable;
|
|
|
|
/**
|
|
* Update given order from the current user.
|
|
*
|
|
* VAT is calculated based on the billing address and shown in the order response.
|
|
*
|
|
* The billing and shipping addresses are each persisted as standalone Address entities
|
|
* in the database, but are also embedded (deep-copied) into the Order object itself
|
|
* rather than merely referenced. This guarantees that the order retains its own snapshot
|
|
* of both addresses for future reference.
|
|
*
|
|
* @param array{
|
|
* billing_address: array{
|
|
* company_name: null|string,
|
|
* first_name: null|string,
|
|
* last_name: null|string,
|
|
* address: null|string,
|
|
* address_2: null|string,
|
|
* house_number: null|string,
|
|
* city: null|string,
|
|
* state: null|string,
|
|
* postal_code: null|string,
|
|
* country_iso: string,
|
|
* phone_number: null|string,
|
|
* email: null|string
|
|
* },
|
|
* shipping_address: null|array{
|
|
* company_name: null|string,
|
|
* first_name: string,
|
|
* last_name: string,
|
|
* address: null|string,
|
|
* address_2: string,
|
|
* house_number: null|string,
|
|
* city: string,
|
|
* state: string,
|
|
* postal_code: string,
|
|
* country_iso: string,
|
|
* phone_number: null|string,
|
|
* email: null|string
|
|
* }
|
|
* } $attributes The order data:
|
|
* - billing_address: Billing address (ISO 3166-1 alpha-2 country code)
|
|
* - shipping_address: Shipping address (first name, last name, ISO 3166-1 alpha-2 country code)
|
|
* @throws RequestRequiresClientIdException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function update(array $attributes = []): self
|
|
{
|
|
return (new self($this->billable->request('PUT', sprintf('v1/orders/%s', $this->id), $attributes)))
|
|
->setBillable($this->billable);
|
|
}
|
|
|
|
/**
|
|
* Checkout given order from the current user.
|
|
*
|
|
* @throws RequestRequiresClientIdException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function checkout(string $orderId): self
|
|
{
|
|
return (new self($this->billable->request('PUT', sprintf('v1/orders/%s/checkout', $this->id))))
|
|
->setBillable($this->billable);
|
|
}
|
|
|
|
/**
|
|
* Revoke given order from the current user.
|
|
*
|
|
* @throws RequestRequiresClientIdException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function revoke(string $orderId): self
|
|
{
|
|
return (new self($this->billable->request('PUT', sprintf('v1/orders/%s/revoke', $this->id))))
|
|
->setBillable($this->billable);
|
|
}
|
|
|
|
/**
|
|
* Delete given order from the current user.
|
|
*
|
|
* @throws RequestRequiresClientIdException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function delete(): bool
|
|
{
|
|
return $this->billable->request('DELETE', sprintf('v1/orders/%s', $this->id))->success();
|
|
}
|
|
|
|
/**
|
|
* Get order items from given order.
|
|
*
|
|
* @param string $orderId The order ID.
|
|
* @throws RequestRequiresClientIdException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function orderItems(string $orderId): OrderItems
|
|
{
|
|
return (new OrderItems($this->billable->request('GET', sprintf('v1/orders/%s/items', $this->id))))
|
|
->setBillable($this->billable)
|
|
->setParent($this);
|
|
}
|
|
} |