This PHP library is intended to be used as a facade to our API exposed services. Through this implementation, you can perform the most common operations included in our official API documentation site.
Additional Information:
- API version: 1.4
- This library follows the structure from our Postman Collection File
- You can post any request, bug or issue or also reach us at: [email protected]
- PHP 5.6 >=
To install from the cli with Composer, simply run:
composer require newsletter2go/api
composer install
You can also download the standalone class from this repository and add it to your PHP project.
- This example shows how to setup your account credentials and make further API calls.
<?php
namespace NL2GO;
//Import the standalone class in your working directory
require_once '/Newsletter2Go_REST_Api.php';
//Add your account credentials
$authKey = "your auth key here";
$userEmail = "login email address";
$userPassword = "login password";
//Instantiate the Newsletter2Go_REST_Api
$api = new Newsletter2Go_REST_Api($authKey, $userEmail, $userPassword);
//Allow SSL check
$api->setSSLVerification(true);
//Retrieve and display all the contact lists stored your account
$lists = $api->getLists();
var_dump($lists);
The following are the supported Entities in this library:
getListDetails() - API Documentation Get all information for one specific list.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID you want to get details from. |
stdClass |
@return stdClass | returned Object. |
createList() - API Documentation Create a new list.
Parameter | Type | Description |
---|---|---|
$name |
@param string | List name |
$uses_econda |
@param boolean | Enable/Disable Encoda tracking. |
$uses_googleanalytics |
@param boolean | Enable/Disable Google tracking. |
$has_opentracking |
@param boolean | Enable/Disable tracking for E-mail opening. |
$has_clicktracking |
@param boolean | Enable/Disable tracking for clicks in newsletter. |
$has_conversiontracking |
@param boolean | Enable/Disable Conversion tracking. |
$imprint |
@param string | Link to company imprint. |
$header_from_email |
@param string | Default sender address for E-mails. |
$header_from_name |
@param string | Default sender name for E-mails. |
$header_reply_email |
@param string | Default address for replied E-mails. |
$header_reply_name |
@param string | Default sender name for replied E-mail. |
$tracking_url |
@param string | Additional URL tracking. |
$landingpage |
@param string | Landing page URL. |
$use_ecg_list |
@param boolean | Enable/Disable ECG. |
stdClass |
@return stdClass | returned Object. |
updateList() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$name |
@param string | List name. |
$uses_econda |
@param boolean | Enable/Disable Encoda tracking. |
$uses_googleanalytics |
@param boolean | Enable/Disable Google tracking. |
$has_opentracking |
@param boolean | Enable/Disable tracking for E-mail opening. |
$has_clicktracking |
@param boolean | Enable/Disable tracking for clicks in newsletter. |
$has_conversiontracking |
@param boolean | Enable/Disable Conversion tracking. |
$imprint |
@param string | Link to company imprint. |
$header_from_email |
@param string | Default sender address for E-mails. |
$header_from_name |
@param string | Default sender name for E-mails. |
$header_reply_email |
@param string | Default address for replied E-mails. |
$header_reply_name |
@param string | Default sender name for replied E-mail. |
$tracking_url |
@param string | Additional URL tracking. |
$landingpage |
@param string | Landing page URL. |
$use_ecg_list |
@param boolean | Enable/Disable ECG. |
stdClass |
@return stdClass | returned Object. |
deleteList() - API Documentation Delete a specific list by its ID
Be careful! You're irrevocably deleting the entire list with all campaigns and contacts.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
stdClass |
@return stdClass | returned Object. |
getRecipients() - API Documentation Get recipients from any list.
Parameter | Type | Description |
---|---|---|
stdClass |
@return stdClass | returned Object. |
getRecipient() - API Documentation Get the details of one recipient.
Parameter | Type | Description |
---|---|---|
$recipientId |
@param string | description |
stdClass |
@return stdClass | returnedObject |
updateRecipientList() - API Documentation Create one or more recipients. If the email address already exists, the existing recipient will get updated.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | Recipient ID to perform the actions on. |
$email |
@param string | Recipient's e-mail. |
$phone |
@param string | Recipient's phone. |
$gender |
@param string | Recipient's gender. |
$first_name |
@param string | Recipient's name. |
$last_name |
@param string | Recipient's last name |
$is_unsubscribed |
@param boolean | Recipient's subscription status. |
$is_blacklisted |
@param boolean | Recipient's blacklist status. |
stdClass |
@return stdClass | returnedObject |
deleteRecipientsFromList() - API Documentation Get recipients from a specific list.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$recipientId |
@param string | Recipient ID to be deleted. |
stdClass |
@return stdClass | returnedObject |
updateRecipients() - API Documentation Update multiple / all recipients in one list.
Make sure to pass the
$filter
variable or all your recipients in the list will be updated. E.g: /{{list_id}}/recipients?_filter=email%3DLIKE%3D%22%example%25%22
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$email |
@param string | New e-mail address. |
$phone |
@param string | New phone address. |
$gender |
@param string | New gender. |
$first_name |
@param string | New name. |
$last_name |
@param string | New last name. |
$is_unsubscribed |
@param boolean | Redifine recipient's subscription status. |
$is_blacklisted |
@param boolean | Redifine recipient's blacklist status. |
$filter |
@param string | Query variable. Make sure to do URL encoding to the variable. |
stdClass |
@return stdClass | returnedObject |
updateRecipient() - API Documentation
_Update one recipient only by passing its $recipientId
.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$email |
@param string | New e-mail address. |
$phone |
@param string | New phone address. |
$gender |
@param string | New gender. |
$first_name |
@param string | New name. |
$last_name |
@param string | New last name. |
$is_unsubscribed |
@param boolean | Redifine recipient's subscription status. |
$is_blacklisted |
@param boolean | Redifine recipient's blacklist status. |
stdClass |
@return stdClass | returnedObject |
getSegmentsList() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
stdClass |
@return stdClass | returnedObject |
createSegment() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$name |
@param string | description |
stdClass |
@return stdClass | returnedObject |
createDynamicSegment() - API Documentation
The attribute $filter
should be the conditions upon which the auto-update action is executed.
The attribute $is_dynamic
defines wether the segment will auto-update or not.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$name |
@param string | Segment name |
$filter |
@param string | Conditions upon which the auto-update action is executed |
stdClass |
@return stdClass | returnedObject |
updateSegment() - API Documentation
Parameter | Type | Description |
---|---|---|
$segmentId |
@param string | Segment ID to update. |
$name |
@param string | Name to be updated |
stdClass |
@return stdClass | returnedObject |
deleteSegment() - API Documentation
Parameter | Type | Description |
---|---|---|
$segmentId |
@param string | Segment ID to be deleted |
stdClass |
@return stdClass | returnedObject |
getRecipientSegment() - API Documentation Gets all recipients from specified segment.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$segmentId |
@param string | Segment ID to retrieve the recipients from. |
stdClass |
@return stdClass | returnedObject |
addRecipientSegment() - API Documentation Add one recipient to the segment.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$segmentId |
@param string | Segment ID where the recipient will be |
$recipientId |
@param string | description |
stdClass |
@return stdClass | returnedObject |
deleteRecipientsSegment() - API Documentation Delete recipient from one or multiple recipients from segment.
If you don't pass a
$filter
, all your recipients will be deleted from the group irrevocably.
Parameter | Type | Description |
---|---|---|
$segmentId |
@param string | Segment ID for deletion |
$recipientId |
@param string | Recipient ID to be deleted |
$filter |
@param string | Filter parameter for deletion |
stdClass |
@return stdClass | returnedObject |
getAttributesList() - API Documentation Retrieve attributes from a list.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
stdClass |
@return stdClass | returnedObject |
getAttributeDetails() - API Documentation Get metadata from the attribute.
Parameter | Type | Description |
---|---|---|
$attributeId |
@param string | Attribute ID to be retrieved. |
stdClass |
@return stdClass | returnedObject |
createAttributeList() - API Documentation Create a new custom attribute on a given list.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$name |
@param string | Attribute name |
$display |
@param string | Attribute display |
$type |
@param string | Attribute type. |
$sub_type |
@param string | |
$is_enum |
@param boolean | Represented by a number. |
$is_public |
@param boolean | Visibility of the attribute. |
$is_multiselect |
@param boolean | Can hold multiple options. |
$html_element_type |
@param string | Description for HTML element. |
$is_global |
@param boolean | Define if this attribute should apply to all lists. |
stdClass |
@return stdClass | returnedObject |
updateAttribute() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$attributeId |
@param string | Attribute ID to be updated. |
$attributename |
@param string | New attribute name. |
$value |
@param string | New attribute value. |
stdClass |
@return stdClass | returnedObject |
deleteAttribute() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$attributeId |
@param string | Attribute ID to be deleted. |
stdClass |
@return stdClass | returnedObject |
getMailingsList() - API Documentation
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
stdClass |
@return stdClass | returnedObject |
getMailing() - API Documentation
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to be sent. |
stdClass |
@return stdClass | returnedObject |
getMailingVersions() - API Documentation
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to be retrieved. |
stdClass |
@return stdClass | returnedObject |
createMailing() - API Documentation
If your list has default values for header_from_email
, header_from_name
, header_reply_email
and/or header_reply_name
, those will be used in case you don't pass them in this call.
Parameter | Type | Description |
---|---|---|
$listId |
@param string | List ID to perform the actions on. |
$type |
@param string | Mailing type "default", "doi", "transactional" |
$name |
@param string | Name for new mailing |
$has_open_tracking |
@param boolean | Enabled/Disabled open tracking. |
$has_click_tracking |
@param boolean | Enabled/Disabled click tracking. |
$has_conversion_tracking |
@param boolean | Enabled/Disabled conversion tracking. |
stdClass |
@return stdClass | returnedObject |
sendTest() - API Documentation
This will send a test but leave the mailing status untouched.
Be aware that the subject line will be prepended by [TEST]
.
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to be tested. |
$address |
@param string | E-mail address where the test should arrive. |
stdClass |
@return stdClass | returnedObject |
sendOneTimeMailing() - API Documentation There are different ways to address a mailing.
- To the whole contac list by using the
list_id
. - To single segments (using the
group_ids
field). - To single recipients only (by using the
recipient_ids
together with thelist_selected
field set to false) and - A combination of the above.
Important: Please take into account, that you have to set the list_selected
field to false, if you like to send to single recipients only or together with segments. This makes clear that the newsletter will not be sent to the whole contact list.
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to be sent. |
$time |
@param string | Time for execution. Please format it to ISO-8601 |
$groupIds |
@param string | Groups (Segments) to be addressed. |
$recipientIds |
@param string | Individual recipient e-mails. |
$listId |
@param string | List ID where to be addressed. |
$state |
@param boolean | Active/Unactive campaign. |
stdClass |
@return stdClass | returnedObject |
sendTransactional() - API Documentation
You can pass other data fields (such as first_name
or custom attributes) in the recipient
object as well and reference them in the body of the email.
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to be sent. |
$time |
@param string | Time for execution. Please format it to ISO-8601 |
$address |
@param string | Individual recipient e-mail. |
stdClass |
@return stdClass | returnedObject |
updateMailing() - API Documentation
If you want to be able to trigger automated mailings, make sure that the state is set to active
. Use list_selected: true
to send to the whole list, pass an array of group ids in the group_ids
or send to individual contacts by passing an array in the recipient_ids
parameter.
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param | Newsletter ID to be modified. |
$name |
@param | Updated mailing name. |
$isDeleted |
@param | Enabled/Disabled deletion state. |
$has_open_tracking |
@param | Enabled/Disabled email open tracking. |
$has_click_tracking |
@param boolean | Enabled/Disabled click tracking. |
$has_conversion_tracking |
@param boolean | Enabled/Disabled conversion tracking. |
stdClass |
@return stdClass | returnedObject |
getSpecificMailingReports() - API Documentation This call is useful for automated mailings that run every day since it returns the reports by day.
Parameter | Type | Description |
---|---|---|
$newsletterId |
@param string | Newsletter ID to retrieve reports. |
$filter |
@param string | FIQL advanced filter. |
stdClass |
@return stdClass | returnedObject |
Parameter | Type | Description |
---|---|---|
$formId |
@param string | description |
stdClass |
@return stdClass | returnedObject |
submitForm() - API Documentation
Parameter | Type | Description |
---|---|---|
$formId |
@param string | Form Id to be submitted. |
$address |
@param string | E-mail address of form recipient. |
stdClass |
@return stdClass | returnedObject |
getCompany() - API Documentation Get your company details.
Parameter | Type | Description |
---|---|---|
stdClass |
@return stdClass | returnedObject |