forked from campaignmonitor/createsend-php
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcsrest_transactional_timeline.php
161 lines (151 loc) · 6.88 KB
/
csrest_transactional_timeline.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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
<?php
require_once dirname(__FILE__).'/class/base_classes.php';
/**
* Class to access transactional from the create send API.
* @author philoye
*
*/
if (!class_exists('CS_REST_Transactional_Timeline')) {
class CS_REST_Transactional_Timeline extends CS_REST_Wrapper_Base {
/**
* The client id to use for the timeline. Optional if using a client api key
* @var array
* @access private
*/
var $_client_id_param;
/**
* Constructor.
* @param $client_id string The client id to send email on behalf of
* Optional if using a client api key
* @param $auth_details array Authentication details to use for API calls.
* This array must take one of the following forms:
* If using OAuth to authenticate:
* array(
* 'access_token' => 'your access token',
* 'refresh_token' => 'your refresh token')
*
* Or if using an API key:
* array('api_key' => 'your api key')
* @param $protocol string The protocol to use for requests (http|https)
* @param $debug_level int The level of debugging required CS_REST_LOG_NONE | CS_REST_LOG_ERROR | CS_REST_LOG_WARNING | CS_REST_LOG_VERBOSE
* @param $host string The host to send API requests to. There is no need to change this
* @param $log CS_REST_Log The logger to use. Used for dependency injection
* @param $serialiser The serialiser to use. Used for dependency injection
* @param $transport The transport to use. Used for dependency injection
* @access public
*/
function __construct (
$auth_details,
$client_id = NULL,
$protocol = 'https',
$debug_level = CS_REST_LOG_NONE,
$host = 'api.createsend.com',
$log = NULL,
$serialiser = NULL,
$transport = NULL) {
parent::__construct($auth_details, $protocol, $debug_level, $host, $log, $serialiser, $transport);
$this->set_client($client_id);
}
/**
* Change the client id used for calls after construction
* Only required if using OAuth or an Account level API Key
* @param $client_id
* @access public
*/
function set_client($client_id) {
$this->_client_id_param = array("clientID" => $client_id);
}
/**
* Gets the list of sent messages
* @access public
* @param $params, array Parameters used to filter results
* This should be an array of the form
* array(
* "status" => string delivered|bounced|spam|all
* "count" => integer optional, maximum number of results to return in a single request (default: 50, max: 200)
* "sentBeforeID" => string optional, messageID used for pagination, returns emails sent before the specified message
* "sentAfterID" => string optional, messageID used for pagination, returns emails sent after the specified message
* "smartEmaiLID" => string optional, smart email to filter by
* "group" => string optional, classic group name to filter by
* )
* @return CS_REST_Wrapper_Result A successful response will be an array of the form
* array(
* array(
* "MessageID" => string
* "Status" => string
* "SentAt" => string
* "Recipient" => string
* "From" => string
* "Subject" => string
* "TotalOpens" => integer
* "TotalClicks" => integer
* "CanBeResent" => boolean
* "Group" => string, optional
* "SmartEmailID" => string, optional
* )
* )
*/
function messages($query = array()) {
$params = array_merge($this->_client_id_param, $query);
return $this->get_request_with_params($this->_base_route . 'transactional/messages', $params);
}
/**
* Gets the list of details of a sent message
* @access public
* @param $message_id, string Message ID to get the details for
* @return CS_REST_Wrapper_Result The details of the message
*/
function details($message_id, $show_details = false) {
$params = array_merge($this->_client_id_param, array("statistics" => $show_details));
return $this->get_request_with_params($this->_base_route . 'transactional/messages/' . $message_id, $params);
}
/**
* Resend a sent message
* @access public
* @param $message_id, string Message ID to resend
* @return CS_REST_Wrapper_Result The details of the message
* array(
* "MessageID" => string
* "Recipient" => string
* "Status" => string
* )
*/
function resend($message_id) {
$data = array_merge($this->_client_id_param);
return $this->post_request($this->_base_route.'transactional/messages/' . $message_id . '/resend', $data);
}
/**
* Gets statistics for sends/bounces/opens/clicks
* @access public
* @param $params, array Parameters used to filter results
* This should be an array of the form
* array(
* "from" => iso-8601 date, optional, default 30 days ago
* "to" => iso-8601 date, optional, default today
* "timezone" => client|utc, optional, how to handle date boundaries
* "group" => string optional, classic group name to filter by
* "smartEmailID" => string optional. smart email to filter results by
* )
* @return CS_REST_Wrapper_Result A successful response will be an array of the form
* array(
* array(
* "MessageID" => string
* "Status" => string
* "SentAt" => string
* "Recipient" => string
* "From" => string
* "Subject" => string
* "TotalOpens" => integer
* "TotalClicks" => integer
* "CanBeResent" => boolean
* "Group" => string, optional
* "SmartEmailID" => string, optional
* )
* )
*/
function statistics($query = array()) {
$params = array_merge($this->_client_id_param, $query);
return $this->get_request_with_params($this->_base_route.'transactional/statistics', $params);
}
}
}