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/SendinBlue.php
2021-12-07 11:08:05 +00:00

275 lines
7.8 KiB
PHP

<?php
/**
* Wrapper for SendinBlue's API.
*
* @since 1.1.0
*
* @package ET\Core\API\Email
*/
class ET_Core_API_Email_SendinBlue extends ET_Core_API_Email_Provider {
/**
* @inheritDoc
*/
public $BASE_URL = 'https://api.sendinblue.com/v3'; // @phpcs:ignore ET.Sniffs.ValidVariableName.PropertyNotSnakeCase -- Keep the variable name.
/**
* @inheritDoc
*/
public $FIELDS_URL = 'https://api.sendinblue.com/v3/contacts/attributes'; // @phpcs:ignore ET.Sniffs.ValidVariableName.PropertyNotSnakeCase -- Keep the variable name.
/**
* @inheritDoc
*/
public $LISTS_URL = 'https://api.sendinblue.com/v3/contacts/lists/'; // @phpcs:ignore ET.Sniffs.ValidVariableName.PropertyNotSnakeCase -- Keep the variable name.
/**
* The URL to which new subscribers can be posted.
*
* @var string
*/
public $SUBSCRIBE_URL = 'https://api.sendinblue.com/v3/contacts'; // @phpcs:ignore ET.Sniffs.ValidVariableName.PropertyNotSnakeCase -- Keep the variable name.
/**
* The URL to get the subscriber information.
* Only used by legacy mode (v2) to check whether we should create or update subscription.
*
* @var string
*/
public $USERS_URL = 'https://api.sendinblue.com/v2.0/user';
/**
* @inheritDoc
*/
public $custom_fields_scope = 'account';
/**
* @inheritDoc
*/
public $name = 'SendinBlue';
/**
* @inheritDoc
*/
public $slug = 'sendinblue';
/**
* @inheritDoc
*/
public $uses_oauth = false;
public function __construct( $owner, $account_name, $api_key = '' ) {
parent::__construct( $owner, $account_name, $api_key );
$this->_maybe_set_custom_headers();
}
protected function _maybe_set_custom_headers() {
if ( empty( $this->custom_headers ) && isset( $this->data['api_key'] ) ) {
$this->custom_headers = array( 'api-key' => $this->data['api_key'] );
}
}
protected function _process_custom_fields( $args ) {
if ( ! isset( $args['custom_fields'] ) ) {
return $args;
}
$fields = $args['custom_fields'];
unset( $args['custom_fields'] );
foreach ( $fields as $field_id => $value ) {
if ( is_array( $value ) && $value ) {
// This is a multiple choice field (eg. checkbox, radio, select)
$value = array_values( $value );
if ( count( $value ) > 1 ) {
$value = implode( ',', $value );
} else {
$value = array_pop( $value );
}
}
self::$_->array_set( $args, "attributes.{$field_id}", $value );
}
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' => 'id',
'name' => 'name',
'subscribers_count' => $this->_should_use_legacy_api() ? 'total_subscribers' : 'totalSubscribers',
),
'subscriber' => array(
'email' => 'email',
'name' => 'attributes.FIRSTNAME',
'last_name' => 'attributes.LASTNAME',
'list_id' => $this->_should_use_legacy_api() ? '@listid' : '@listIds',
'custom_fields' => 'custom_fields',
'updateEnabled' => 'updateEnabled',
),
'custom_field' => array(
'field_id' => 'name',
'name' => 'name',
),
);
return parent::get_data_keymap( $keymap );
}
public function get_subscriber( $email ) {
$this->prepare_request( "{$this->USERS_URL}/{$email}", 'GET' );
$this->make_remote_request();
if ( $this->response->ERROR || ! isset( $this->response->DATA['listid'] ) ) {
return false;
}
if ( isset( $this->response->DATA['code'] ) && 'success' !== $this->response->DATA['code'] ) {
return false;
}
return $this->response->DATA;
}
/**
* @inheritDoc
*/
public function fetch_subscriber_lists() {
if ( empty( $this->data['api_key'] ) ) {
return $this->API_KEY_REQUIRED;
}
if ( empty( $this->custom_headers ) ) {
$this->_maybe_set_custom_headers();
}
$use_legacy_api = $this->_should_use_legacy_api();
if ( $use_legacy_api ) {
$this->LISTS_URL = 'https://api.sendinblue.com/v2.0/list'; // @phpcs:ignore ET.Sniffs.ValidVariableName.UsedPropertyNotSnakeCase -- Keep the variable name.
$this->response_data_key = 'data';
$params = array(
'page' => 1,
'page_limit' => 2,
);
} else {
$this->response_data_key = 'lists';
}
/**
* The maximum number of subscriber lists to request from Sendinblue's API.
*
* @since 4.11.4
*
* @param int $max_lists
*/
$max_lists = (int) apply_filters( 'et_core_api_email_sendinblue_max_lists', 50 );
$url = "{$this->LISTS_URL}?limit={$max_lists}&offset=0&sort=desc";
$this->prepare_request( $url, 'GET', false, $params );
$this->request->data_format = 'body';
parent::fetch_subscriber_lists();
if ( $this->response->ERROR ) {
return $this->response->ERROR_MESSAGE;
}
if ( isset( $this->response->DATA['code'] ) && 'success' !== $this->response->DATA['code'] ) {
return $this->response->DATA['message'];
}
$result = 'success';
$this->data['is_authorized'] = 'true';
$list_data = $use_legacy_api ? $this->response->DATA['data']['lists'] : $this->response->DATA['lists'];
if ( ! empty( $list_data ) ) {
$this->data['lists'] = $this->_process_subscriber_lists( $list_data );
$this->save_data();
}
return $result;
}
/**
* Get custom fields for a subscriber list.
* Need to override the method in the child class to dynamically use the API endpoint
* and response_data_key based on the API version being used.
*
* @param int|string $list_id The list ID.
* @param array $list The lists array.
*
* @return array
*/
protected function _fetch_custom_fields( $list_id = '', $list = array() ) {
if ( $this->_should_use_legacy_api() ) {
$this->FIELDS_URL = 'https://api.sendinblue.com/v2.0/attribute/normal'; // @phpcs:ignore ET.Sniffs.ValidVariableName.UsedPropertyNotSnakeCase -- Keep the variable name.
$this->response_data_key = 'data';
} else {
$this->response_data_key = 'attributes';
}
return parent::_fetch_custom_fields( $list_id, $list );
}
/**
* @inheritDoc
*/
public function subscribe( $args, $url = '' ) {
$args['list_id'] = array( absint( $args['list_id'] ) ); // in V3 the list id has to be integer.
if ( $this->_should_use_legacy_api() ) {
$this->SUBSCRIBE_URL = 'https://api.sendinblue.com/v2.0/user/createdituser'; // @phpcs:ignore ET.Sniffs.ValidVariableName.UsedPropertyNotSnakeCase -- Keep the variable name.
$existing_user = $this->get_subscriber( $args['email'] );
if ( false !== $existing_user ) {
$args['list_id'] = array_unique( array_merge( $args['list_id'], $existing_user['listid'] ) );
}
} else {
$args['updateEnabled'] = true; // Update existing contact if exists.
// Process data and encode to json, the new API (v3) uses json encoded body params.
if ( ! in_array( 'ip_address', $args, true ) || 'true' === $args['ip_address'] ) {
$args['ip_address'] = et_core_get_ip_address();
} elseif ( 'false' === $args['ip_address'] ) {
$args['ip_address'] = '0.0.0.0';
}
$args = $this->transform_data_to_provider_format( $args, 'subscriber' );
if ( $this->custom_fields ) {
$args = $this->_process_custom_fields( $args );
}
$this->prepare_request( $this->SUBSCRIBE_URL, 'POST', false, $args, true ); // @phpcs:ignore ET.Sniffs.ValidVariableName.UsedPropertyNotSnakeCase -- Keep the variable name.
}
return parent::subscribe( $args, $this->SUBSCRIBE_URL );
}
/**
* Check if the api-key being used is legacy (v2).
*
* @return boolean
*/
protected function _should_use_legacy_api() {
$api_key = isset( $this->data['api_key'] ) ? $this->data['api_key'] : '';
return ! empty( $api_key ) && 'xkeysib-' !== substr( $api_key, 0, 8 );
}
}