Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
jsarnowski/brizy-pro / campaignmonitor / createsend-php / csrest_transactional_smartemail.php
Size: Mime:
<?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_SmartEmail')) {
    class CS_REST_Transactional_SmartEmail extends CS_REST_Wrapper_Base {

        /**
         * The client id to use for this mailer. Optional if using a client api key.
         * @var array
         * @access private
         */
        var $_client_id_param;

        /**
         * The base route of the smartemail resource.
         * @var string
         * @access private
         */
        var $_smartemail_base_route;

        /**
         * Constructor.
         * @param $client_id string The client id to send email on behalf of
         *        Optional if using a client api key
         * @param $smartemail_id string The smart email id to access (Ignored for list requests)
         * @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 (
        $smartemail_id,
        $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);
            $this->set_smartemail_id($smartemail_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);
        }

        /**
         * Change the smart email id used for calls after construction
         * @param $smartemail_id
         * @access public
         */
        function set_smartemail_id($smartemail_id) {
            $this->_smartemail_base_route = $this->_base_route . 'transactional/smartEmail/' . $smartemail_id;
        }

        /**
         * Gets a list of smart emails
         * @access public
         * @param $options optional array Query params to filter list
         *     This should be an array of the form
         *         array(
         *             "status" => "all|drafts|active"
         *         )
         * @return CS_REST_Wrapper_Result A successful response will be an object of the form
         *     array(
         *        array (
         *             'ID' => string
         *             'Name' => string
         *             'CreatedAt' => datestring
         *             'Status' => string
         *        )
         *     )
         */
        function get_list($options = array()) {
            $data = array_merge($this->_client_id_param, $options);
            return $this->get_request_with_params($this->_base_route . 'transactional/smartemail', $data);
        }

        /**
         * Sends a new smart transactional email
         * @param array $message The details of the template
         *     This should be an array of the form
         *         array(
         *             'To' => array(
         *                  "First Last <user@example.com>", "another@example.com"
         *             ) optional To recipients
         *             'CC' => array(
         *                  "First Last <user@example.com>", "another@example.com"
         *             ) optional CC recipients
         *             'BCC' => array(
         *                  "First Last <user@example.com>", "another@example.com"
         *             ) optional BCC recipients
         *             'Attachments' => array(
         *                  array(
         *                      "Name" => string
         *                      "Type" => string mime type
         *                      "Content" => string base64-encoded
         *                  )
         *             ) optional
         *             'Data' => array(
         *                  "variable" => "value",
         *                  "variable" => "value",
         *             )
         *         )
         * @param boolean $add_to_list optional. Whether to add all recipients to the list specified for the smart email
         * @access public
         * @return CS_REST_Wrapper_Result A successful response will be the include the details of the action, including a Message ID.
         *      array(
         *          array(
         *              "MessageID" => string
         *              "Recipient" => string
         *              "Status" => string
         *          )
         *      )
         */
        function send($message, $consent_to_track, $add_to_list = true) {
            $data = array_merge($message, array(
                "AddRecipientsToList" => $add_to_list,
                "ConsentToTrack" => $consent_to_track
            ));
            return $this->post_request($this->_smartemail_base_route . '/send.json', $data);
        }

        /**
         * Gets the details of Smart Email
         * @access public
         * @return CS_REST_Wrapper_Result A successful response will be an array of the form
         *     array(
         *        "SmartEmailID" => string
         *        "Name" => string
         *        "CreatedAt" => string
         *        "Status" => string
         *        "Properties" => array (
         *            "From" =. string
         *            "ReplyTo" => string
         *            "Subject" => string
         *            "Content": array(
         *                "HTML": string
         *                "Text": string
         *                "EmailVariables": array(
         *                    "username",
         *                    "reset_token"
         *                ),
         *                "InlineCss": boolean
         *            },
         *            "TextPreviewUrl": string
         *            "HtmlPreviewUrl": string
         *        ),
         *        "AddRecipientsToList": string
         *    }
         */
        function get_details() {
            return $this->get_request($this->_smartemail_base_route);
        }

    }
}