PHP code example of melvin-hamilton-digital / emarsys-api
1. Go to this page and download the library: Download melvin-hamilton-digital/emarsys-api library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
melvin-hamilton-digital / emarsys-api example snippets
use GuzzleHttp\Client as HttpClient;
use MHD\Emarsys\Api\Authentication;
use MHD\Emarsys\Api\Client as EmarsysClient;
use MHD\Emarsys\Api\Contacts;
use MHD\Emarsys\Api\Events;
use MHD\Emarsys\Data\ContactFields;
$authentication = new Authentication('username', 'secret');
$httpClient = new HttpClient(['base_uri' => EmarsysClient::BASE_URI]);
$emarsysClient = new EmarsysClient($authentication, $httpClient);
# create new contact
$newContact = (new ContactFields())
->setEmail('[email protected]')
->setFirstName('John')
->setLastName('Doe')
->setGender(ContactFields::GENDER_MALE);
$contacts = new Contacts($emarsysClient);
$contacts->createContact($newContact);
# send email to John
$events = new Events($emarsysClient);
$events->triggerEvent(1234, '[email protected]');
use MHD\Emarsys\Data\ProductData;
use MHD\Emarsys\ProductFeed\ProductDataNameConverter;
use Symfony\Component\Serializer\Encoder\CsvEncoder;
use Symfony\Component\Serializer\Normalizer\DateTimeNormalizer;
use Symfony\Component\Serializer\Normalizer\PropertyNormalizer;
use Symfony\Component\Serializer\Serializer;
class CustomProductData extends ProductData
{
/**
* @MHD\Emarsys\ProductFeed\CustomField
*/
public $customField;
}
$productData = new CustomProductData;
$productData->item = 'foo';
$productData->customField = 'bar';
$normalizers = [
new PropertyNormalizer(null, new ProductDataNameConverter()),
new DateTimeNormalizer(),
];
$serializer = new Serializer($normalizers, [new CsvEncoder()]);
echo $serializer->serialize([$productData], 'csv');
# c_custom_field,item,title,link,image,zoom_image,category,available,description,price,msrp,brand
# bar,foo,,,,,,,,,,
use MHD\Emarsys\Data\SalesData;
use MHD\Emarsys\SalesFeed\SalesDataNameConverter;
use Symfony\Component\Serializer\Encoder\CsvEncoder;
use Symfony\Component\Serializer\Normalizer\DateTimeNormalizer;
use Symfony\Component\Serializer\Normalizer\PropertyNormalizer;
use Symfony\Component\Serializer\Serializer;
class CustomSalesData extends SalesData
{
/**
* @MHD\Emarsys\SalesFeed\CustomField("string")
*/
public $customField;
}
$salesData = new CustomSalesData;
$salesData->item = 'foo';
$salesData->customField = 'bar';
$normalizers = [
new PropertyNormalizer(null, new SalesDataNameConverter()),
new DateTimeNormalizer(),
];
$serializer = new Serializer($normalizers, [new CsvEncoder()]);
echo $serializer->serialize([$salesData], 'csv');
# s_custom_field,item,price,order,timestamp,customer,email,quantity
# bar,foo,,,,,,
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.