This repository has been archived on 2022-06-23. You can view files and clone it, but cannot push or open issues or pull requests.
divi/core/components/api/email/CampaignMonitor.php

272 lines
6.2 KiB
PHP
Raw Normal View History

2021-12-07 11:08:05 +00:00
<?php
/**
* Wrapper for Campaign Monitor's API.
*
* @since 1.1.0
*
* @package ET\Core\API\Email
*/
class ET_Core_API_Email_CampaignMonitor extends ET_Core_API_Email_Provider {
/**
* @inheritDoc
*/
public $BASE_URL = 'https://api.createsend.com/api/v3.1';
/**
* @inheritDoc
*/
public $http_auth = array(
'username' => 'api_key',
'password' => '-',
);
/**
* @inheritDoc
*/
public $name = 'CampaignMonitor';
/**
* @inheritDoc
*/
public $name_field_only = true;
/**
* @inheritDoc
*/
public $slug = 'campaign_monitor';
/**
* @inheritDoc
* @internal If true, oauth endpoints properties must also be defined.
*/
public $uses_oauth = false;
public function __construct( $owner, $account_name, $api_key = '' ) {
parent::__construct( $owner, $account_name, $api_key );
$this->http_auth['password'] = $owner;
}
protected function _fetch_custom_fields( $list_id = '', $list = array() ) {
$this->prepare_request( "{$this->BASE_URL}/lists/{$list_id}/customfields.json" );
$this->make_remote_request();
$result = array();
if ( $this->response->ERROR ) {
et_debug( $this->get_error_message() );
return $result;
}
foreach ( $this->response->DATA as &$custom_field ) {
$custom_field = $this->transform_data_to_our_format( $custom_field, 'custom_field' );
$custom_field['field_id'] = ltrim( rtrim( $custom_field['field_id'], ']' ), '[' );
}
$fields = array();
foreach ( $this->response->DATA as $field ) {
$field_id = $field['field_id'];
$type = self::$_->array_get( $field, 'type', 'any' );
$field['type'] = self::$_->array_get( $this->data_keys, "custom_field_type.{$type}", 'any' );
$fields[ $field_id ] = $field;
}
return $fields;
}
protected function _get_clients() {
$url = "{$this->BASE_URL}/clients.json";
$this->prepare_request( $url );
$this->make_remote_request();
if ( $this->response->ERROR ) {
return $this->get_error_message();
}
return (array) $this->response->DATA;
}
protected function _get_subscriber_counts() {
$subscriber_lists = $this->_process_subscriber_lists( $this->response->DATA );
$with_counts = array();
foreach ( $subscriber_lists as $subscriber_list ) {
$list_id = $subscriber_list['list_id'];
$with_counts[ $list_id ] = $subscriber_list;
$url = "{$this->BASE_URL}/lists/{$list_id}/stats.json";
$this->prepare_request( $url );
$this->make_remote_request();
if ( $this->response->ERROR ) {
continue;
}
if ( isset( $this->response->DATA['TotalActiveSubscribers'] ) ) {
$with_counts[ $list_id ]['subscribers_count'] = $this->response->DATA['TotalActiveSubscribers'];
} else {
$with_counts[ $list_id ]['subscribers_count'] = 0;
}
usleep( 500000 ); // 0.5 seconds
}
return $with_counts;
}
protected function _process_custom_fields( $args ) {
if ( ! isset( $args['custom_fields'] ) ) {
return $args;
}
$fields_unprocessed = $args['custom_fields'];
unset( $args['custom_fields'] );
$fields = array();
foreach ( $fields_unprocessed as $field_id => $value ) {
if ( is_array( $value ) && $value ) {
// This is a multiple choice field (eg. checkbox)
foreach ( $value as $selected_option ) {
$fields[] = array(
'Key' => $field_id,
'Value' => $selected_option,
);
}
} else {
$fields[] = array(
'Key' => $field_id,
'Value' => $value,
);
}
}
$args['CustomFields'] = $fields;
return $args;
}
/**
* @inheritDoc
*/
public function get_account_fields() {
return array(
'api_key' => array(
'label' => esc_html__( 'API Key', 'et_core' ),
),
);
}
/**
* @inheritDoc
*/
public function get_data_keymap( $keymap = array() ) {
$keymap = array(
'list' => array(
'list_id' => 'ListID',
'name' => 'Name',
'subscribers_count' => 'TotalActiveSubscribers',
),
'subscriber' => array(
'name' => 'Name',
'email' => 'EmailAddress',
'custom_fields' => 'custom_fields',
),
'error' => array(
'error_message' => 'Message',
),
'custom_field' => array(
'field_id' => 'Key',
'name' => 'FieldName',
'type' => 'DataType',
'options' => 'FieldOptions',
),
'custom_field_type' => array(
// Us => Them
'input' => 'Text',
'select' => 'MultiSelectOne',
'checkbox' => 'MultiSelectMany',
// Them => Us
'Text' => 'input',
'Number' => 'input',
'Date' => 'input',
'MultiSelectOne' => 'select',
'MultiSelectMany' => 'checkbox',
),
);
return parent::get_data_keymap( $keymap );
}
/**
* @inheritDoc
*/
public function fetch_subscriber_lists() {
if ( empty( $this->data['api_key'] ) ) {
return $this->API_KEY_REQUIRED;
}
$clients = $this->_get_clients();
$lists = array();
if ( ! is_array( $clients ) ) {
// Request failed with an error, return the error message.
return $clients;
}
foreach ( $clients as $client_info ) {
if ( empty( $client_info['ClientID'] ) ) {
continue;
}
$url = "{$this->BASE_URL}/clients/{$client_info['ClientID']}/lists.json";
$this->prepare_request( $url );
parent::fetch_subscriber_lists();
if ( $this->response->ERROR ) {
return $this->get_error_message();
}
if ( isset( $this->response->DATA ) ) {
$with_counts = $this->_get_subscriber_counts();
$lists = $lists + $with_counts;
$this->data['is_authorized'] = true;
$this->save_data();
}
}
if ( empty( $this->data['lists'] ) || ! empty( $lists ) ) {
$this->data['lists'] = $lists;
$this->save_data();
}
return $this->is_authenticated() ? 'success' : $this->FAILURE_MESSAGE;
}
/**
* @inheritDoc
*/
public function subscribe( $args, $url = '' ) {
$url = "{$this->BASE_URL}/subscribers/{$args['list_id']}.json";
$params = $this->transform_data_to_provider_format( $args, 'subscriber' );
$params = $this->_process_custom_fields( $params );
$params['CustomFields'][] = array( 'Key' => 'Note', 'Value' => $this->SUBSCRIBED_VIA );
$this->prepare_request( $url, 'POST', false, $params, true );
return parent::subscribe( $params, $url );
}
}