Last active
October 20, 2016 09:58
-
-
Save martinsam/3ba4b4b099bd890d595c05341eec2dbd to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
// https://github.com/drewm/mailchimp-api/ | |
include('MailChimp.php'); | |
$MailChimp = new MailChimp('Api-key'); | |
$list_id = "list_id_here"; | |
$result = $MailChimp->post("lists/$list_id/members", [ | |
'email_address' => '[email protected]', | |
'status' => 'pending', | |
'merge_fields' => [ | |
'FNAME' => 'Urist', | |
'LNAME' =>'McVankab', | |
], | |
]); | |
if ($MailChimp->success()) { | |
print_r($result); | |
} else { | |
echo $MailChimp->getLastError(); | |
} | |
?> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
/** | |
* Super-simple, minimum abstraction MailChimp API v3 wrapper | |
* MailChimp API v3: http://developer.mailchimp.com | |
* This wrapper: https://github.com/drewm/mailchimp-api | |
* | |
* @author Drew McLellan <[email protected]> | |
* @version 2.2 | |
*/ | |
class MailChimp | |
{ | |
private $api_key; | |
private $api_endpoint = 'https://<dc>.api.mailchimp.com/3.0'; | |
/* SSL Verification | |
Read before disabling: | |
http://snippets.webaware.com.au/howto/stop-turning-off-curlopt_ssl_verifypeer-and-fix-your-php-config/ | |
*/ | |
public $verify_ssl = true; | |
private $request_successful = false; | |
private $last_error = ''; | |
private $last_response = array(); | |
private $last_request = array(); | |
/** | |
* Create a new instance | |
* @param string $api_key Your MailChimp API key | |
* @throws \Exception | |
*/ | |
public function __construct($api_key) | |
{ | |
$this->api_key = $api_key; | |
if (strpos($this->api_key, '-') === false) { | |
throw new \Exception("Invalid MailChimp API key `{$api_key}` supplied."); | |
} | |
list(, $data_center) = explode('-', $this->api_key); | |
$this->api_endpoint = str_replace('<dc>', $data_center, $this->api_endpoint); | |
$this->last_response = array('headers' => null, 'body' => null); | |
} | |
/** | |
* Create a new instance of a Batch request. Optionally with the ID of an existing batch. | |
* @param string $batch_id Optional ID of an existing batch, if you need to check its status for example. | |
* @return Batch New Batch object. | |
*/ | |
public function new_batch($batch_id = null) | |
{ | |
return new Batch($this, $batch_id); | |
} | |
/** | |
* Convert an email address into a 'subscriber hash' for identifying the subscriber in a method URL | |
* @param string $email The subscriber's email address | |
* @return string Hashed version of the input | |
*/ | |
public function subscriberHash($email) | |
{ | |
return md5(strtolower($email)); | |
} | |
/** | |
* Was the last request successful? | |
* @return bool True for success, false for failure | |
*/ | |
public function success() | |
{ | |
return $this->request_successful; | |
} | |
/** | |
* Get the last error returned by either the network transport, or by the API. | |
* If something didn't work, this should contain the string describing the problem. | |
* @return array|false describing the error | |
*/ | |
public function getLastError() | |
{ | |
return $this->last_error ?: false; | |
} | |
/** | |
* Get an array containing the HTTP headers and the body of the API response. | |
* @return array Assoc array with keys 'headers' and 'body' | |
*/ | |
public function getLastResponse() | |
{ | |
return $this->last_response; | |
} | |
/** | |
* Get an array containing the HTTP headers and the body of the API request. | |
* @return array Assoc array | |
*/ | |
public function getLastRequest() | |
{ | |
return $this->last_request; | |
} | |
/** | |
* Make an HTTP DELETE request - for deleting data | |
* @param string $method URL of the API request method | |
* @param array $args Assoc array of arguments (if any) | |
* @param int $timeout Timeout limit for request in seconds | |
* @return array|false Assoc array of API response, decoded from JSON | |
*/ | |
public function delete($method, $args = array(), $timeout = 10) | |
{ | |
return $this->makeRequest('delete', $method, $args, $timeout); | |
} | |
/** | |
* Make an HTTP GET request - for retrieving data | |
* @param string $method URL of the API request method | |
* @param array $args Assoc array of arguments (usually your data) | |
* @param int $timeout Timeout limit for request in seconds | |
* @return array|false Assoc array of API response, decoded from JSON | |
*/ | |
public function get($method, $args = array(), $timeout = 10) | |
{ | |
return $this->makeRequest('get', $method, $args, $timeout); | |
} | |
/** | |
* Make an HTTP PATCH request - for performing partial updates | |
* @param string $method URL of the API request method | |
* @param array $args Assoc array of arguments (usually your data) | |
* @param int $timeout Timeout limit for request in seconds | |
* @return array|false Assoc array of API response, decoded from JSON | |
*/ | |
public function patch($method, $args = array(), $timeout = 10) | |
{ | |
return $this->makeRequest('patch', $method, $args, $timeout); | |
} | |
/** | |
* Make an HTTP POST request - for creating and updating items | |
* @param string $method URL of the API request method | |
* @param array $args Assoc array of arguments (usually your data) | |
* @param int $timeout Timeout limit for request in seconds | |
* @return array|false Assoc array of API response, decoded from JSON | |
*/ | |
public function post($method, $args = array(), $timeout = 10) | |
{ | |
return $this->makeRequest('post', $method, $args, $timeout); | |
} | |
/** | |
* Make an HTTP PUT request - for creating new items | |
* @param string $method URL of the API request method | |
* @param array $args Assoc array of arguments (usually your data) | |
* @param int $timeout Timeout limit for request in seconds | |
* @return array|false Assoc array of API response, decoded from JSON | |
*/ | |
public function put($method, $args = array(), $timeout = 10) | |
{ | |
return $this->makeRequest('put', $method, $args, $timeout); | |
} | |
/** | |
* Performs the underlying HTTP request. Not very exciting. | |
* @param string $http_verb The HTTP verb to use: get, post, put, patch, delete | |
* @param string $method The API method to be called | |
* @param array $args Assoc array of parameters to be passed | |
* @param int $timeout | |
* @return array|false Assoc array of decoded result | |
* @throws \Exception | |
*/ | |
private function makeRequest($http_verb, $method, $args = array(), $timeout = 10) | |
{ | |
if (!function_exists('curl_init') || !function_exists('curl_setopt')) { | |
throw new \Exception("cURL support is required, but can't be found."); | |
} | |
$url = $this->api_endpoint . '/' . $method; | |
$this->last_error = ''; | |
$this->request_successful = false; | |
$response = array('headers' => null, 'body' => null); | |
$this->last_response = $response; | |
$this->last_request = array( | |
'method' => $http_verb, | |
'path' => $method, | |
'url' => $url, | |
'body' => '', | |
'timeout' => $timeout, | |
); | |
$ch = curl_init(); | |
curl_setopt($ch, CURLOPT_URL, $url); | |
curl_setopt($ch, CURLOPT_HTTPHEADER, array( | |
'Accept: application/vnd.api+json', | |
'Content-Type: application/vnd.api+json', | |
'Authorization: apikey ' . $this->api_key | |
)); | |
curl_setopt($ch, CURLOPT_USERAGENT, 'DrewM/MailChimp-API/3.0 (github.com/drewm/mailchimp-api)'); | |
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); | |
curl_setopt($ch, CURLOPT_TIMEOUT, $timeout); | |
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, $this->verify_ssl); | |
curl_setopt($ch, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_1_0); | |
curl_setopt($ch, CURLOPT_ENCODING, ''); | |
curl_setopt($ch, CURLINFO_HEADER_OUT, true); | |
switch ($http_verb) { | |
case 'post': | |
curl_setopt($ch, CURLOPT_POST, true); | |
$this->attachRequestPayload($ch, $args); | |
break; | |
case 'get': | |
$query = http_build_query($args, '', '&'); | |
curl_setopt($ch, CURLOPT_URL, $url . '?' . $query); | |
break; | |
case 'delete': | |
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'DELETE'); | |
break; | |
case 'patch': | |
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PATCH'); | |
$this->attachRequestPayload($ch, $args); | |
break; | |
case 'put': | |
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, 'PUT'); | |
$this->attachRequestPayload($ch, $args); | |
break; | |
} | |
$response['body'] = curl_exec($ch); | |
$response['headers'] = curl_getinfo($ch); | |
if (isset($response['headers']['request_header'])) { | |
$this->last_request['headers'] = $response['headers']['request_header']; | |
} | |
if ($response['body'] === false) { | |
$this->last_error = curl_error($ch); | |
} | |
curl_close($ch); | |
$formattedResponse = $this->formatResponse($response); | |
$this->determineSuccess($response, $formattedResponse); | |
return $formattedResponse; | |
} | |
/** | |
* Encode the data and attach it to the request | |
* @param resource $ch cURL session handle, used by reference | |
* @param array $data Assoc array of data to attach | |
*/ | |
private function attachRequestPayload(&$ch, $data) | |
{ | |
$encoded = json_encode($data); | |
$this->last_request['body'] = $encoded; | |
curl_setopt($ch, CURLOPT_POSTFIELDS, $encoded); | |
} | |
/** | |
* Decode the response and format any error messages for debugging | |
* @param array $response The response from the curl request | |
* @return array|false The JSON decoded into an array | |
*/ | |
private function formatResponse($response) | |
{ | |
$this->last_response = $response; | |
if (!empty($response['body'])) { | |
return json_decode($response['body'], true); | |
} | |
return false; | |
} | |
/** | |
* Check if the response was successful or a failure. If it failed, store the error. | |
* @param array $response The response from the curl request | |
* @param array|false $formattedResponse The response body payload from the curl request | |
* @return bool If the request was successful | |
*/ | |
private function determineSuccess($response, $formattedResponse) | |
{ | |
$status = $this->findHTTPStatus($response, $formattedResponse); | |
if ($status >= 200 && $status <= 299) { | |
$this->request_successful = true; | |
return true; | |
} | |
if (isset($formattedResponse['detail'])) { | |
$this->last_error = sprintf('%d: %s', $formattedResponse['status'], $formattedResponse['detail']); | |
return false; | |
} | |
$this->last_error = 'Unknown error, call getLastResponse() to find out what happened.'; | |
return false; | |
} | |
/** | |
* Find the HTTP status code from the headers or API response body | |
* @param array $response The response from the curl request | |
* @param array|false $formattedResponse The response body payload from the curl request | |
* @return int HTTP status code | |
*/ | |
private function findHTTPStatus($response, $formattedResponse) | |
{ | |
if (!empty($response['headers']) && isset($response['headers']['http_code'])) { | |
return (int) $response['headers']['http_code']; | |
} | |
if (!empty($response['body']) && isset($formattedResponse['status'])) { | |
return (int) $formattedResponse['status']; | |
} | |
return 418; | |
} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment