DotMailer SOAP API

Я пытаюсь использовать SOAP API от Dotmailer с NUSOAP, но мне совсем не везет. Я могу подключиться к их серверам, но не могу получить никакой информации. Вот что у меня так далеко:

<?php
# initialise
$error_message="Something went wrong";
$wsdlPath = "https://apiconnector.com/v2/api.svc?wsdl";

# perform lookup
require "http://www.domain.com/nusoap/nusoap.php";
$client=new soapclient( $wsdlPath,'wsdl' );
$client->setCredentials("username","password");
$err=$client->getError();
if( $err ) { echo $error_message; exit( $err ); }

# create a proxy client.
$proxy=$client->getproxy();
$err=$proxy->getError();
if( $err ) { echo $error_message; exit( $err ); }

# call the SOAP method for GetAddressBooks.
$result=$proxy->GetAddressBooksResponse->GetAddressBooksResult;
if( $proxy->fault ) {
echo $error_message;
} else {
$err=$proxy->getError();
if( $err ) {
echo $error_message; exit( $err );
} else {
AddressBooks( $result );
}
}

function AddressBooks( $result ) {
print "<table>
<tr>
<th></th>
<th>Id</th>
<th>Name</th>
<th>Visibility</th>
<th>Contact</th>
</tr>";
foreach( $result['addressBook'] as $key=>$addressbook ) {
print "<tr>
<td>" . $addressbook->Id . "</td>
<td>" . $addressbook->Name . "</td>
<td align='right'>" . $addressbook->Visibility . "</td>
<td align='right'>" . $vaddressbook>Contacts . "</td>
</tr>";
}
print "</table>";
}

?>

Единственное, что я получаю — это первая строка таблицы. Я разговаривал с дотмейлерами, но они не помогли вообще.

0

Решение

Хотя это не полный ответ на использование SOAP, так как в итоге я использовал REST, но это работает:

<?php

/** POST EMAIL FIRST AND GET CONTACT FROM DOTMAILER */
$postContactUrl = 'https://apiconnector.com/v2/contacts/';
$data = array(
'Email' => '[email protected]', //email to post
'EmailType' => 'Html', //other option is PlainText
'dataFields' => array(
array(
'Key' => 'CITY',
'Value' => $_POST['address2']),
array(
'Key' => 'COUNTRY',
'Value' => $country_name),
array(
'Key' => 'FIRSTNAME',
'Value' => $_POST['name_first']),
array(
'Key' => 'FULLNAME',
'Value' => $_POST['name_first']." ".$_POST['name_last'] ),
array(
'Key' => 'LASTNAME',
'Value' => $_POST['name_last']),
array(
'Key' => 'POSTCODE',
'Value' => $_POST['postcode']),
array(
'Key' => 'STREET',
'Value' => $_POST['address1']),
array(
'Key' => 'TOWN',
'Value' => $_POST['address3']),
)
);
//post email and response will be contact object from dotmailer
$contact = execute_post($postContactUrl, $data);

/** ADD CONTACT TO ADDRESS BOOK */
$addContactToAddressBookUrl = 'https://apiconnector.com/v2/address-books/' . 'address-book-id' . '/contacts'; //add your address book id
//post contact to address book and response will be address book object from dotmailer
$book =  execute_post($addContactToAddressBookUrl, $contact);

/**
* if you want to check if there was an error you can
* check it by calling this on response.
* example $book->message
*/

echo "<pre>" . print_r($data, true) . "</pre>";
// echo "<pre>" . print_r($contact, true) . "</pre>";
// echo "<pre>" . print_r($book, true) . "</pre>";

//Function to initiate curl, set curl options, execute and return the response
function execute_post($url, $data){
//encode the data as json string
$requestBody = json_encode($data);

//initialise curl session
$ch = curl_init();

//curl options
curl_setopt($ch, CURLAUTH_BASIC, CURLAUTH_DIGEST);
curl_setopt($ch, CURLOPT_USERPWD, 'user-name' . ':' . 'password'); // credentials
curl_setopt($ch, CURLOPT_POSTFIELDS, $requestBody);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_TIMEOUT, 10);
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
curl_setopt($ch, CURLOPT_HTTPHEADER, array ('Accept: ' . 'application/json' ,'Content-Type: application/json'));

//curl execute and json decode the response
$responseBody = json_decode(curl_exec($ch));

//close curl session
curl_close($ch);

return $responseBody;
}
?>
1

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]