/** * Проверяем header уведомлений и ответов от PayQR на соответствие значению SecretKeyIn * * @param $secretKeyIn * @return bool */ public static function checkHeader($secretKeyIn, $headers = false) { if (!PayqrConfig::$checkHeader) { return true; } if (!$headers) { if (!function_exists('getallheaders')) { $headers = PayqrBase::getallheaders(); } else { $headers = getallheaders(); } } if (!$headers) { header("HTTP/1.0 404 Not Found"); PayqrLog::log(__FILE__ . "\n\r" . __METHOD__ . "\n\r L:" . __LINE__ . "\n\r Не удалось выполнить проверку входящего секретного ключа SecretKeyIn, отсутствует headers"); return false; } // Проверяем соответствие пришедшего значения поля PQRSecretKey значению SecretKeyIn из конфигурации библиотеки if (isset($headers['PQRSecretKey']) && $headers['PQRSecretKey'] == $secretKeyIn) { return true; } foreach ($headers as $key => $header) { $headers[strtolower($key)] = $header; } if (isset($headers['pqrsecretkey']) && $headers['pqrsecretkey'] == $secretKeyIn) { return true; } header("HTTP/1.0 404 Not Found"); PayqrLog::log(__FILE__ . "\n\r" . __METHOD__ . "\n\r L:" . __LINE__ . "\n\r Входящий секретный ключ из headers не совпадает с входящим ключом из файла конфигурации \n\r Текущее значение SecretKeyIn из вашего PayqrConfig.php: " . $secretKeyIn . " \n\r Содержание headers полученного уведомления от PayQR: " . print_r($headers, true)); return false; }
/** * Отправка POST-запроса * @param $url * @param $postdata * @return bool|PayqrCurl_response */ public function post($url, $postdata) { if (is_array($postdata)) { $postdata = PayqrBase::http_build_query($postdata, '', '&'); } $url_obj = parse_url($url); if (!isset($url_obj['host'])) { PayqrLog::log(__FILE__ . "\n\r" . __METHOD__ . "\n\r L:" . __LINE__ . "\n\r" . " Неверный параметр url: " . $url . " не удалось определить host для запроса"); return false; } $host = $url_obj['host']; $errno = ""; $errstr = ""; $fp = fsockopen("ssl://" . $host, 443, &$errno, &$errstr, intval(PayqrConfig::$maxTimeOut)); if (!$fp) { PayqrLog::log(__FILE__ . "\n\r" . __METHOD__ . "\n\r L:" . __LINE__ . "\n\r" . 'Ошибка при запросе ' . $url . ' ' . $errstr($errno) . "\n"); } else { $out = "POST {$url} HTTP/1.1\r\n"; $out .= "User-Agent: PayQr Lib\r\n"; $out .= "Host: {$host}\r\n"; $out .= "Accept: */*\r\n"; if (is_array($this->headers)) { foreach ($this->headers as $key => $value) { $out .= "{$key}: {$value}\r\n"; } } $out .= "Connection: Close\r\n\r\n"; $out .= "{$postdata}\n\n"; $out .= "\r\n"; fwrite($fp, $out); $output = ""; while (!feof($fp)) { $output .= fgets($fp, 1024); } fclose($fp); $response = false; if ($output) { $response = new PayqrCurl_response($output); } else { PayqrLog::log(__FILE__ . "\n\r" . __METHOD__ . "\n\r L:" . __LINE__ . "\n\r" . 'Ошибка при запросе ' . $url . ' пустой или неправильный ответ ' . print_r($output, true) . "\n"); } return $response; } }
public function __construct() { $this->setModuleConfig(); PayqrBase::checkConfig(); }
public function __construct() { PayqrBase::checkConfig(); }