Я работаю над своей первой реализацией API DocuSign, и у меня возникают проблемы при аутентификации в REST API.
Следуя документации по 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 Unauthorized» с текстом:
'{
"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 (документы по адресу: http://devel-m6w6.rhcloud.com/mdref/http )
$ url превращается в: '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.
Пожалуйста ознакомтесь Как использовать заголовок X-DocuSign-Authentication для REST и SOAP? как я думаю, ваши «(кавычки» «) отсутствуют для json» ключ «:» значение «…
и он подозревает, что этот образец может служить вам 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" )
);
На данный момент, похоже, библиотека HTTP, которую я использовал, является источником проблемы. Я перешел на GuzzleHttp и вызовы API работали без проблем.
Я подозреваю, что массив, в котором я указал заголовки, не был указан в правильном формате. Вместо этого это мог бы быть формат key => value, но у меня не было времени / интереса для тестирования этого. Жадность кажется более современной и работает, так что я не потрудился вернуться к пакету pecl.