Ошибки с LinkedIn Invitation запрашиваются через их REST API с PHP с использованием PECL OAuth - PullRequest
2 голосов
/ 04 июня 2011

Я использую PECL OAuth с LinkedIn, потому что он отлично работает с GET-запросами Twitter и LinkedIn.Переключится на собственные библиотеки OAuth LinkedIn, если это не сработает, но предпочел бы делать все через одну и ту же библиотеку OAuth.

Код:

$xmlString = "<?xml version='1.0' encoding='UTF-8'?>".
                         "<mailbox-item>".
                          "<recipients>".
                            "<recipient>".
                             "<person path=\"/people/email={$person->PersonEmail}\">".
                              "<first-name>{$person->PersonFirstName}</first-name>".
                              "<last-name>{$person->PersonLastName}</last-name>".
                             "</person>".
                            "</recipient>".
                          "</recipients>".
                          "<subject>Invitation to Connect</subject>".
                          "<body>Please join my professional network on LinkedIn.</body>".
                          "<item-content>".
                           "<invitation-request>".
                            "<connect-type>friend</connect-type>".
                           "</invitation-request>".
                          "</item-content>".
                         "</mailbox-item>";

try {
                $oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_FORM);
                $oauth->setToken($accessToken, $accessTokenSecret);
                $oauth->fetch("http://api.linkedin.com/v1/people/~/mailbox", $xmlString, OAUTH_HTTP_METHOD_POST, array('Content-Type'=>'text/xml'));
                $result = $oauth->getLastResponse();
                return $result;
            } catch (OAuthException $e) {
                var_dump($e);
                throw new ModelException('Error - Invalid Access Token', ModelException::$excodes['invalid_access_token']);
            }

Это вызывает исключение, которое перехватывается,и var_dump много выплевывает, в первую очередь: «Неверный запрос аутентификации / неверный запрос (получил 401, ожидаемый HTTP / 1.1 20X или редирект)»

Я пробовал несколько вариантов с кодом.Например, удаление «Content-Type» => «text / xml» приводит к той же ошибке.Я проверил xml и знаю, что токены доступа хороши, так как я использую их просто для выполнения запросов GET.

Буду признателен за любую помощь, спасибо.

1 Ответ

1 голос
/ 04 июня 2011

Нашел решение, оно заменяло

$oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_FORM);

на

$oauth = new OAuth(self::$apiKey, self::$secretKey, OAUTH_SIG_METHOD_HMACSHA1, OAUTH_AUTH_TYPE_AUTHORIZATION);
...