There is no license information available for the latest version (dev-master) of this package.

Simple implementation of the campaign monitor API within Silverstripe

Installs: 500

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 1

Forks: 0


dev-master 2018-01-24 00:31 UTC

This package is auto-updated.

Last update: 2024-06-11 14:21:30 UTC


Simple implementation of the campaign monitor API within Silverstripe

Credits and Authors


  • TODO


  • SilverStripe 3.0
  • PHP 5.3
  • Campaign Monitor PHP library 2.5.2

Installation instructions

composer require "tractorcow/silverstripe-campaignmonitor": "3.0.*@dev"

composer require "campaignmonitor/createsend-php": "v2.5.2"


Using the API to set a destination list (SiteConfig extension)

Given a hard coded API key, allow the user to select a client from their account, and subsequently a list.

	function updateCMSFields(FieldList $fields) {

		// Load base object
		$resources = new CMResources("my api key");

		// Get clients under our account
		$clients = $resources->Clients()->map();
			new DropdownField('Client', 'Client', $clients)

		// check if client is available to select
		if($this->owner->Client && ($client = $resources->getClient($this->owner->Client))) {
			$lists = $client->Lists()->map();
				new DropdownField('DefaultList', 'Default List', $lists)

Saving a subscriber

Handling subscription details from a form submission

	public function subscribe($data, $form) {
		$listID = SiteConfig::current_site_config()->DefaultList;
		$resources = new CMResources("my api key");
		if($resources && $listID && $list = $resources->getList($listID)) {
			$this->addUserToList($data, $list);
		// Error handling here

	protected function addUserToList($data, $list) {
		if(empty($list)) return;
		// Create subscriber
		$fields = array(
			'EmailAddress' => $data['Email'],
			'Name' => $data['FirstName'],
			'CustomFields' => array(
				'LastName' => $data['LastName'],
				'Company' => $data['Company'],
				'Phone' => $data['Phone'],
				'Mobile' => $data['Mobile']
			'Resubscribe' => true,
			'RestartSubscriptionBasedAutoresponders' => true
		$subscriber = new CMSubscriber(null, $fields, $list);

Get a list of sent Campaigns

Get a list of all sent campaigns for a client including from name, from email, reply to email, web version URL, ID, subject, name, date sent, and the total number of recipients.

See the [Campaign Monitor API documentation] ( for more information.

	public function Campaigns() {
		$resources = new CMResources("my api key");
		if($resources && $client = $resources->getClient("my client id")) {
			return $client->Campaigns();