Вопрос или проблема
Я создал настраиваемую конечную точку REST API WordPress, чтобы использовать её в качестве URL вебхука в WooCommerce для преобразования полученных данных и последующей отправки их в стороннюю систему, но, похоже, конечная точка не принимает никаких данных. Я протестировал код, отправив некоторые данные JSON на свою настраиваемую конечную точку с помощью Postman, и это сработало только после установки другого плагина для включения базовой аутентификации. Мне интересно, проблема в том, что вебхук, вероятно, требует аутентификации, чтобы иметь возможность отправить данные на тот же домен? Если это так, у меня нет идеи, где настроить базовую аутентификацию в настройках вебхука в WooCommerce.
это мой код:
function woocbz_CallAPI($method, $url, $data = false)
{
$curl = curl_init();
switch ($method) {
case "POST":
curl_setopt($curl, CURLOPT_POST, 1);
if ($data) {
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
}
break;
case "PUT":
curl_setopt($curl, CURLOPT_PUT, 1);
break;
default:
if ($data) {
$url = sprintf("%s?%s", $url, http_build_query($data));
}
}
// Дополнительная аутентификация:
curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($curl, CURLOPT_USERPWD, "username:password");
curl_setopt($curl, CURLOPT_URL, $url);
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
$result = curl_exec($curl);
curl_close($curl);
return $result;
}
function woocbz_order_created(WP_REST_Request $request)
{
$method = 'POST';
$url="https://webhook.site/2e5e23db-68ef-4d03-b9ec-687309d35166";
$data = $request->get_json_params();
$user_data = array(
'order_id' => $data['id'],
'memo' => $data['order_key'],
'status' => $data['status']
);
$resultado = woocbz_CallAPI($method, $url, $user_data);
return $data;
}
add_action(
'rest_api_init',
function () {
register_rest_route(
'woocbz/v1',
'/new-order',
array(
'methods' => 'POST',
'callback' => 'woocbz_order_created',
'permission_callback' => function () {
return true;
}
)
);
}
);
Любая помощь будет очень признательна.
Я догадался, что это может быть проблемой с авторизацией, затем я посмотрел функции вебхуков WooCommerce и нашел, где выполняется доставка: /wp-content/plugins/woocommerce/includes/class-wc-webhook.php Я жестко закодировал свой Authorization заголовок после строки # 303 в функции deliver():
'headers' => array(
'Content-Type' => 'application/json',
'Authorization' => 'Basic bmNkaWgdrGFsOiNIb25kdXJhczIwMThTUFMh',
),
Теперь мне нужно рассчитать Authorization Basic token на основе идентификатора пользователя, создавшего вебхук, который уполномочен делать это решение гибким.
Вместо изменения плагина вы можете использовать фильтр woocommerce_webhook_http_args, чтобы добавить заголовок Authorization:
add_filter( 'woocommerce_webhook_http_args', 'add_auth_header' );
function add_auth_header($http_args) {
$http_args['headers']['Authorization'] = 'Basic bmNkaWgdrGFsOiNIb25kdXJhczIwMThTUFMh';
return $http_args;
}
Ответ или решение
Для решения проблемы с обработкой вебхуков WooCommerce и перенаправлением данных на созданную вами конечную точку REST API, необходимо учесть несколько важных моментов, связанных с аутентификацией. Ваша задача заключается в настройке вебхука WooCommerce для корректной отправки данных на вашу конечную точку.
1. Проблема с аутентификацией
Вы правильно заметили, что проблема может заключаться в аутентификации. Вебхуки WooCommerce по умолчанию не будут работать, если ваша конечная точка требует аутентификации (например, Basic Auth), если это не настроено корректно. Вы можете добавить заголовок аутентификации с помощью фильтра woocommerce_webhook_http_args
, что является более гибким и чистым решением по сравнению с модификацией исходных файлов плагина.
2. Использование фильтра woocommerce_webhook_http_args
Для добавления заголовка аутентификации к запросам вебхука, вы можете использовать следующий код:
add_filter( 'woocommerce_webhook_http_args', 'add_auth_header' );
function add_auth_header($http_args) {
// Убедитесь, что мы используем корректные данные для аутентификации
$username = 'ваш_пользователь'; // замените на актуальное имя пользователя
$password = 'ваш_пароль'; // замените на актуальный пароль
$credentials = base64_encode("$username:$password");
$http_args['headers']['Authorization'] = 'Basic ' . $credentials;
return $http_args;
}
3. Настройка конечной точки REST API
Ваш код для конечной точки REST API выглядит корректно, но для полной уверенности, убедитесь, что:
- Конечная точка регистрируется правильно.
- Используется соответствующий путь в вебхуке (например,
https://ваш_домен/wp-json/woocbz/v1/new-order
). - Ваш метод
woocbz_order_created
корректно обрабатывает входящие данные.
4. Отладка
Чтобы отладить процесс, убедитесь в следующем:
- Сделайте запрос к вашей конечной точке REST API с помощью Postman, чтобы убедиться, что она работает без вебхуков. Убедитесь, что заголовки аутентификации также установлены в этом тесте.
- Проверьте логи сервера, чтобы понять, не возникает ли каких-либо ошибок при попытке вебхука WooCommerce обратиться к вашей конечной точке.
- Убедитесь, что WooCommerce действительно отправляет события на указанную конечную точку.
5. Итог
Настройка аутентификации через фильтр woocommerce_webhook_http_args
является подходящим решением вашей проблемы, так как это позволяет избежать изменения исходных кодов плагина. Более того, данный подход будет работать для всех вебхуков, которые будут отправляться в будущем, обеспечивая надежную и безопасную интеграцию с вашим REST API.
Если у вас возникнут дополнительные вопросы или потребуются дальнейшие разъяснения, не стесняйтесь обратиться за дополнительной помощью.