-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathApiClient.php
More file actions
114 lines (91 loc) · 3.35 KB
/
ApiClient.php
File metadata and controls
114 lines (91 loc) · 3.35 KB
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
<?php
/**
* Simple client class for consuming the Email & Apps REST API
* (http://api-wiki.apps.rackspace.com/api-wiki/index.php/Main_Page)
*
* Pre-requisites:
*
* - PHP's curl extension (apt-get install php5-curl)
* - CA cert files at /etc/ssl/certs (apt-get install ca-certificates)
*
* Contributors:
*
* - Rackspace Email & Apps REST API Team
* - Josh Shilling
*/
class ApiClient
{
const USER_KEY = 'xxxxxxxxxxxxxxxxxx';
const SECRET_KEY = 'xxxxxxxxxxxxxxxxxx';
const USER_AGENT = 'PHP Demo Client';
const VERSION = 'v1';
const SERVER_HOST = 'api.emailsrvr.com';
public function get($url_string, $format)
{
$headers = array("Accept: $format");
$curl_session = self::construct_session($url_string, $headers);
$http_message = self::send_request($curl_session);
return $http_message;
}
public function post($url_string, $fields, $format)
{
$headers = array("Accept: $format");
$curl_session = self::construct_session($url_string, $headers);
curl_setopt($curl_session, CURLOPT_POST, true);
curl_setopt($curl_session, CURLOPT_POSTFIELDS, $fields);
$http_message = self::send_request($curl_session);
return $http_message;
}
public function put($url_string, $fields)
{
$curl_session = self::construct_session($url_string, array());
curl_setopt($curl_session, CURLOPT_CUSTOMREQUEST, 'PUT');
curl_setopt($curl_session, CURLOPT_POSTFIELDS, $fields);
$http_message = self::send_request($curl_session);
return $http_message;
}
public function delete($url_string)
{
$curl_session = self::construct_session($url_string, array());
curl_setopt($curl_session, CURLOPT_CUSTOMREQUEST, 'DELETE');
$http_message = self::send_request($curl_session);
return $http_message;
}
private function send_request($curl_session)
{
$response = curl_exec($curl_session);
curl_close($curl_session);
return $response;
}
private function construct_session($url_string, $existing_headers)
{
$headers = array_merge(
self::authorization_headers(), $existing_headers);
$url = self::construct_uri($url_string);
$curl_session = curl_init($url);
curl_setopt($curl_session, CURLOPT_VERBOSE, false); //set to true for debug
curl_setopt($curl_session, CURLOPT_HTTPHEADER, $headers);
curl_setopt($curl_session, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl_session, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($curl_session, CURLOPT_SSL_VERIFYPEER, true);
curl_setopt($curl_session, CURLOPT_CAPATH, "/etc/ssl/certs");
return $curl_session;
}
private function authorization_headers()
{
$time_stamp = date('YmdHis');
$data_to_sign = self::USER_KEY . self::USER_AGENT .
$time_stamp. self::SECRET_KEY;
$signature = base64_encode(sha1($data_to_sign, true));
$headers = array();
$headers[] = "User-Agent: " . self::USER_AGENT;
$headers[] = 'X-Api-Signature: ' .
self::USER_KEY . ":$time_stamp:$signature";
return $headers;
}
private function construct_uri($url_string)
{
$url = 'https://' . self::SERVER_HOST . '/' . self::VERSION . $url_string;
return $url;
}
}