PHP & WP: is_wp_error не работает при попытке поймать - PullRequest
0 голосов
/ 20 сентября 2019

Я разместил следующий вопрос PHP & WP: попытаться перехватить не работает, когда выдается ошибка из БД .В настоящее время я пытаюсь предотвратить сбой приложения, когда база данных --read-only.

В настоящее время я получаю следующую ошибку:

Ошибка базы данных WordPress. Команда INSERT запрещена пользователю 'readonly'@'10.XXX.XX.XX' для таблицы 'response' дляquery INSERT INTO responses (uid, data) VALUES

Это происходит, когда база данных, имеющая доступ --read-only, пытается вставить в нее данные.Во время сбоя кластера база данных писателя стала читателем, и поэтому эта проблема возникает.Я пытаюсь написать для него обработку ошибок, но безуспешно.

function drools_request($data, $uid) {
  try {
    $db = _get_db();
    $insertion = $db->insert("requests", [
      "uid" => $uid,
      "data" => json_encode($data),
    ]);
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e)
  {
    echo 'Error writing to database: ',  $e->getMessage(), "\n";
  }
}

Переменная $db - это база данных с конечной точки AWS RDS, которая имеет доступ --read-only.Поэтому, когда $db->insert выдает ошибку, я ожидаю, что журналы на движке WP показали 'Error writing to database: ', однако этого не произошло, и я увидел WordPress database error INSERT command denied to user ...

Почему не работает обработка ошибокв этом случае?Отсутствие возможности записи в базу данных не должно мешать работе сайта.Вот полный класс.

<?php

namespace StatCollector;

function drools_request($data, $uid) {
  try {
    $db = _get_db();
    $insertion = $db->insert("requests", [
      "uid" => $uid,
      "data" => json_encode($data),
    ]);
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e)
  {
    echo 'Error writing to database: ',  $e->getMessage(), "\n";
  }
}

function drools_response($response, $uid) {
  try {
    $db = _get_db();
    $insertion = $db->insert("responses", [
      "uid" => $uid,
      "data" => json_encode($response),
    ]);
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e)
  {
    echo 'Error writing to database: ',  $e->getMessage(), "\n";
  }
}

function results_sent($type, $to, $uid, $url = null, $message = null) {
  try {
    $db = _get_db();
    $insertion = $db->insert("messages", [
      "uid" => $uid,
      "msg_type" => strtolower($type),
      "address" => $to,
      "url" => $url,
      "message" => $message
    ]);
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e)
  {
    echo 'Error writing to database: ',  $e->getMessage(), "\n";
  }
}

function peu_data($staff, $client, $uid) {
  try {
    if (empty($uid)) {
      return;
    }
    $db = _get_db();

    if (! empty($staff)) {
      $insertion = $db->insert("peu_staff", [
        "uid" => $uid,
        "data" => json_encode($staff)
      ]);
    }
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
    if (! empty($client)) {
      $insertion = $db->insert("peu_client", [
        "uid" => $uid,
        "data" => json_encode($client)
      ]);
    }
    if( is_wp_error( $insertion ) ) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e){
    echo 'Error writing to database: ',  $e->getMessage(), "\n";
  }
}


function response_update() {
  $uid = $_POST['GUID'];
  $url = $_POST['url'];
  $programs = $_POST['programs'];
  if (empty($uid) || empty($url) || empty($programs)) {
    wp_send_json(["status" => "fail","message" => "missing values"]);
    return wp_die();
  }

  try {
    $db = _get_db();
    $insertion = $db->insert("response_update", [
      "uid" => $uid,
      "url" => $url,
      "program_codes" => $programs
    ]);
    wp_send_json(["status" => "ok"]);
    wp_die();
    if( is_wp_error( $insertion )) {
      echo $return->get_error_message();
    }
  }
  catch(\Exception $e)
  {
    echo 'Error writing to database: ', $e->getMessage(), "\n";
  }
}

function _get_db() {
  $host = get_option('statc_host');
  $database = get_option('statc_database');
  $user = get_option('statc_user');
  $password = get_option('statc_password');
  $bootstrapped = get_option('statc_bootstrapped');

  $host = (!empty($host)) ? $host : $_ENV['STATC_HOST'];
  $database = (!empty($database)) ? $database : $_ENV['STATC_DATABASE'];
  $user = (!empty($user)) ? $user : $_ENV['STATC_USER'];
  $password = (!empty($password)) ? $password : $_ENV['STATC_PASSWORD'];
  $bootstrapped = (!empty($bootstrapped)) ? $bootstrapped : $_ENV['STATC_BOOTSTRAPPED'];

  if (empty($host) || empty($database) || empty($user) || empty($password)) {
    error_log('StatCollector is missing database connection information. Cannot log');
    return new MockDatabase();
  }

  $db = new \wpdb($user, $password, $database, $host);
  $db->show_errors();

  if ($bootstrapped !== '5') {
    __bootstrap($db);
  }
  return $db;
}

Как может работать обработка ошибок?

1 Ответ

0 голосов
/ 21 сентября 2019

Потому что как согласно документации и insert для wp_db класса не выдает ошибку , если она не удалась.

Он просто возвращает ложь.Блок try..catch будет перехватывать выданные ошибки.

В этом случае вам следует просто проверить, был ли результат insert равным === false.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...