-
Notifications
You must be signed in to change notification settings - Fork 13
/
Subscriptions.php
109 lines (97 loc) · 3.46 KB
/
Subscriptions.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<?php
/**
* User: Joe Linn
* Date: 3/21/2014
* Time: 2:43 PM
*/
namespace Stripe\Api;
use Stripe\Request\ListRequest;
use Stripe\Request\Subscriptions\CreateSubscriptionRequest;
use Stripe\Request\Subscriptions\UpdateSubscriptionRequest;
use Stripe\Response\Subscriptions\ListSubscriptionsResponse;
use Stripe\Response\Subscriptions\SubscriptionResponse;
class Subscriptions extends AbstractApi
{
const SUBSCRIPTION_RESPONSE_CLASS = 'Stripe\Response\Subscriptions\SubscriptionResponse';
const LIST_SUBSCRIPTIONS_RESPONSE_CLASS = 'Stripe\Response\Subscriptions\ListSubscriptionsResponse';
/**
* @param string $customerId
* @param CreateSubscriptionRequest $request
* @return SubscriptionResponse
* @link https://stripe.com/docs/api/curl#create_subscription
*/
public function createSubscription($customerId, CreateSubscriptionRequest $request)
{
return $this->client->post($this->buildUrl($customerId), self::SUBSCRIPTION_RESPONSE_CLASS, $request);
}
/**
* @param string $customerId
* @param string $subscriptionId
* @return SubscriptionResponse
* @link https://stripe.com/docs/api/curl#retrieve_subscription
*/
public function getSubscription($customerId, $subscriptionId)
{
return $this->client->get($this->buildUrl($customerId, $subscriptionId), self::SUBSCRIPTION_RESPONSE_CLASS);
}
/**
* @param string $customerId
* @param string $subscriptionId
* @param UpdateSubscriptionRequest $request
* @return SubscriptionResponse
* @link https://stripe.com/docs/api/curl#update_subscription
*/
public function updateSubscription($customerId, $subscriptionId, UpdateSubscriptionRequest $request)
{
return $this->client->post($this->buildUrl($customerId, $subscriptionId), self::SUBSCRIPTION_RESPONSE_CLASS, $request);
}
/**
* @param string $customerId
* @param string $subscriptionId
* @param bool $atPeriodEnd
* @return SubscriptionResponse
* @link https://stripe.com/docs/api/curl#cancel_subscription
*/
public function cancelSubscription($customerId, $subscriptionId, $atPeriodEnd = false)
{
return $this->client->delete($this->buildUrl($customerId, $subscriptionId), self::SUBSCRIPTION_RESPONSE_CLASS, null, array('at_period_end' => $atPeriodEnd));
}
/**
* @param string $customerId
* @param ListRequest $request
* @return ListSubscriptionsResponse
* @link https://stripe.com/docs/api/curl#list_subscriptions
*/
public function listSubscriptions($customerId, ListRequest $request = null)
{
return $this->client->get($this->buildUrl($customerId), self::LIST_SUBSCRIPTIONS_RESPONSE_CLASS, null, $this->listRequestToParams($request));
}
/**
* @param string $plan
* @return CreateSubscriptionRequest
*/
public function createSubscriptionRequest($plan)
{
return new CreateSubscriptionRequest($plan);
}
/**
* @return UpdateSubscriptionRequest
*/
public function updateSubscriptionRequest()
{
return new UpdateSubscriptionRequest();
}
/**
* @param string $customerId
* @param string $subscriptionId
* @return string
*/
protected function buildUrl($customerId, $subscriptionId = null)
{
$url = 'customers/' . $customerId . '/subscriptions';
if (!is_null($subscriptionId)) {
$url .= '/' . $subscriptionId;
}
return $url;
}
}