Я работаю над своей первой реализацией API DocuSign, и у меня возникли проблемы с аутентификацией API REST.
Следуя документам API, я могу успешно пройти аутентификацию с помощью curl в командной строке:
$ curl --request GET 'https://demo.docusign.net/restapi/v2/login_information' --header 'Content-Type:application/json' --header 'Accept:application/json' --header 'X-DocuSign-Authentication:{"<redacted>", "Password": "<redacted>", "IntegratorKey": "<redacted>"}'
{
"loginAccounts": [
{
"name": "<redacted>",
"accountId": "<redacted>",
"baseUrl": "https://demo.docusign.net/restapi/v2/accounts/<redacted>",
"isDefault": "true",
"userName": "<redacted>",
"userId": "<redacted>",
"email": "<redacted>",
"siteDescription": ""
}
]
Однако при попытке аутентификации с использованием HTTP-запроса через PHP я получаю ответ "401 несанкционированный" с телом:
'{
"errorCode": "PARTNER_AUTHENTICATION_FAILED",
"message": "The specified Integrator Key was not found or is disabled. An Integrator key was not specified."
}'
Я уверен, что я устанавливаю заголовок IntegratorKey. Мой PHP-код выглядит так:
$request = new \http\Client\Request('GET', $url, $this->getHeaders());
$client = new \http\Client();
$client->enqueue($request)->send();
$response = $client->getResponse();
Я использую HTTP-библиотеку pecl/http-v2 (docs: http://devel-m6w6.rhcloud.com/mdref/http)
$ url evals: 'https://demo.docusign.net/restapi/v2/login_information'
Массив заголовка выглядит так:
array (size=3)
0 => string 'X-DocuSign-Authentication: {"Username": "<redacted>", "Password": "<redacted>", "IntegratorKey": "<redacted>"}' (length=155)
1 => string 'Content-Type: application/json' (length=30)
2 => string 'Accept: application/json' (length=24)
Кажется, что ключ API не принимается, хотя я вижу, что отправляются соответствующие заголовки. Любые идеи, что я делаю неправильно здесь? Спасибо за вашу помощь!
Изменение: Исправлена пропавшая двойная кавычка вокруг поля пароля в заголовке проверки подлинности. Я случайно удалил его, отредактировав пароль. Заголовок аутентификации соответствует символу для символа с заголовком, используемым в команде (curl).
На данный момент, похоже, что используемая мной библиотека HTTP является источником проблемы. Я переключился на GuzzleHttp, и вызовы API работали без проблем.
Я подозреваю, что массив, в котором я указывал заголовки, не был указан в правильном формате. Возможно, это был формат key => value, но у меня не было времени/интереса к тестированию этого. Кажется, что Гузлль более современен и работает, поэтому я не потрудился вернуться к пакету.
Пожалуйста, просмотрите Как использовать заголовок X-DocuSign-Authentication для REST и SOAP? как я думаю, ваши "(цитаты" ") отсутствуют для json" key ":" value "...
и он подозревает, что этот образец может служить вам от http://iodocs.docusign.com/APIWalkthrough/requestSignatureFromTemplate:
$data = array("accountId" => $accountId,
"emailSubject" => "DocuSign API - Signature Request from Template",
"templateId" => $templateId,
"templateRoles" => array(
array( "email" => $email, "name" => $recipientName, "roleName" => $templateRoleName )),
"status" => "sent");
$data_string = json_encode($data);
$curl = curl_init($baseUrl . "/envelopes" );
curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
curl_setopt($curl, CURLOPT_POST, true);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($curl, CURLOPT_HTTPHEADER, array(
'Content-Type: application/json',
'Content-Length: ' . strlen($data_string),
"X-DocuSign-Authentication: $header" )
);