Drupal8Post.php in hCaptcha 8
Custom Drupal 8 request method class for hCaptcha.
Namespace
Drupal\hcaptcha\HCaptchaFile
src/HCaptcha/Drupal8Post.phpView source
<?php
/**
* @file
* Custom Drupal 8 request method class for hCaptcha.
*/
namespace Drupal\hcaptcha\HCaptcha;
/**
* Sends POST requests to the hCaptcha service.
*/
class Drupal8Post implements RequestMethod {
/**
* Submit the POST request with the specified parameters.
*
* @param array $params
* Request parameters.
*
* @return \stdClass
* Body of the hCaptcha response.
*/
public function submit($url, array $params) {
$options = array(
'headers' => array(
'Content-type' => 'application/x-www-form-urlencoded',
),
'body' => http_build_query($params, '', '&'),
// Stop firing exception on response status code >= 300.
// See http://docs.guzzlephp.org/en/stable/handlers-and-middleware.html
'http_errors' => false,
);
$response = \Drupal::httpClient()
->post($url, $options);
if ($response
->getStatusCode() == 200) {
// The service request was successful.
$result = (string) $response
->getBody();
}
elseif ($response
->getStatusCode() < 0) {
// Negative status codes typically point to network or socket issues.
$result = '{"success": false, "error-codes": ["connection-failed"]}';
}
else {
// Positive none 200 status code typically means the request has failed.
$result = '{"success": false, "error-codes": ["bad-response"]}';
}
return json_decode($result);
}
}
Classes
Name | Description |
---|---|
Drupal8Post | Sends POST requests to the hCaptcha service. |