File "Subscription.php"
Full Path: /home/cananyalcin/public_html/core/lib/mollie/src/Resources/Subscription.php
File size: 4.83 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace Mollie\Api\Resources;
use Mollie\Api\MollieApiClient;
use Mollie\Api\Types\SubscriptionStatus;
class Subscription extends \Mollie\Api\Resources\BaseResource
{
/**
* @var string
*/
public $resource;
/**
* @var string
*/
public $id;
/**
* @var string
*/
public $customerId;
/**
* Either "live" or "test" depending on the customer's mode.
*
* @var string
*/
public $mode;
/**
* UTC datetime the subscription created in ISO-8601 format.
*
* @var string
*/
public $createdAt;
/**
* @var string
*/
public $status;
/**
* @var \stdClass
*/
public $amount;
/**
* @var int|null
*/
public $times;
/**
* @var int|null
*/
public $timesRemaining;
/**
* @var string
*/
public $interval;
/**
* @var string
*/
public $description;
/**
* @var string|null
*/
public $method;
/**
* @var string|null
*/
public $mandateId;
/**
* @var \stdClass|null
*/
public $metadata;
/**
* UTC datetime the subscription canceled in ISO-8601 format.
*
* @var string|null
*/
public $canceledAt;
/**
* Date the subscription started. For example: 2018-04-24
*
* @var string|null
*/
public $startDate;
/**
* Contains an optional 'webhookUrl'.
*
* @var \stdClass|null
*/
public $webhookUrl;
/**
* Date the next subscription payment will take place. For example: 2018-04-24
*
* @var string|null
*/
public $nextPaymentDate;
/**
* @var \stdClass
*/
public $_links;
/**
* @return BaseResource|Subscription
* @throws \Mollie\Api\Exceptions\ApiException
*/
public function update()
{
$body = ["amount" => $this->amount, "times" => $this->times, "startDate" => $this->startDate, "webhookUrl" => $this->webhookUrl, "description" => $this->description, "mandateId" => $this->mandateId, "metadata" => $this->metadata, "interval" => $this->interval];
$result = $this->client->subscriptions->update($this->customerId, $this->id, $body);
return \Mollie\Api\Resources\ResourceFactory::createFromApiResult($result, new \Mollie\Api\Resources\Subscription($this->client));
}
/**
* Returns whether the Subscription is active or not.
*
* @return bool
*/
public function isActive()
{
return $this->status === \Mollie\Api\Types\SubscriptionStatus::STATUS_ACTIVE;
}
/**
* Returns whether the Subscription is pending or not.
*
* @return bool
*/
public function isPending()
{
return $this->status === \Mollie\Api\Types\SubscriptionStatus::STATUS_PENDING;
}
/**
* Returns whether the Subscription is canceled or not.
*
* @return bool
*/
public function isCanceled()
{
return $this->status === \Mollie\Api\Types\SubscriptionStatus::STATUS_CANCELED;
}
/**
* Returns whether the Subscription is suspended or not.
*
* @return bool
*/
public function isSuspended()
{
return $this->status === \Mollie\Api\Types\SubscriptionStatus::STATUS_SUSPENDED;
}
/**
* Returns whether the Subscription is completed or not.
*
* @return bool
*/
public function isCompleted()
{
return $this->status === \Mollie\Api\Types\SubscriptionStatus::STATUS_COMPLETED;
}
/**
* Cancels this subscription
*
* @return Subscription
* @throws \Mollie\Api\Exceptions\ApiException
*/
public function cancel()
{
if (!isset($this->_links->self->href)) {
return $this;
}
$body = null;
if ($this->client->usesOAuth()) {
$body = \json_encode(["testmode" => $this->mode === "test" ? \true : \false]);
}
$result = $this->client->performHttpCallToFullUrl(\Mollie\Api\MollieApiClient::HTTP_DELETE, $this->_links->self->href, $body);
return \Mollie\Api\Resources\ResourceFactory::createFromApiResult($result, new \Mollie\Api\Resources\Subscription($this->client));
}
/**
* Get subscription payments
*
* @return \Mollie\Api\Resources\PaymentCollection
* @throws \Mollie\Api\Exceptions\ApiException
*/
public function payments()
{
if (!isset($this->_links->payments->href)) {
return new \Mollie\Api\Resources\PaymentCollection($this->client, 0, null);
}
$result = $this->client->performHttpCallToFullUrl(\Mollie\Api\MollieApiClient::HTTP_GET, $this->_links->payments->href);
return \Mollie\Api\Resources\ResourceFactory::createCursorResourceCollection($this->client, $result->_embedded->payments, \Mollie\Api\Resources\Payment::class, $result->_links);
}
}