bd_pdo_rest.php 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. <<<<<<< HEAD
  3. require_once "/saa_dsk/www/vendor/autoload.php";
  4. =======
  5. require_once "/usr/share/nginx/html/paad/vendor/autoload.php";
  6. >>>>>>> 7688f1aac1824c234bc5f19b154e9ad1f4808d4f
  7. $dotenv = Dotenv\Dotenv::createImmutable(__DIR__);
  8. $dotenv->load();
  9. use \SeinopSys\PostgresDb;
  10. # Connect to the database
  11. try {
  12. // Postgres
  13. $pdo = new PDO("pgsql:host=" . $_ENV['DB_HOST'] . ";dbname=" . $_ENV['DB_NAME'], $_ENV['DB_USER'], $_ENV['DB_PASS']);
  14. $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  15. $db = new PostgresDb();
  16. $db->setConnection($pdo);
  17. } catch (PDOException $e) {
  18. echo "Error: " . $e->getMessage();
  19. }
  20. // check recursivelly if the array has only empty strings
  21. function is_response_empty($array)
  22. {
  23. foreach ($array as $value) {
  24. if (is_array($value)) {
  25. if (!is_response_empty($value)) {
  26. return false;
  27. }
  28. } else {
  29. if (!empty($value)) {
  30. return false;
  31. }
  32. }
  33. }
  34. return true;
  35. }
  36. // SQL function
  37. function query(string $sql, array $params = null, bool $single = true)
  38. {
  39. global $pdo;
  40. try {
  41. $stmt = $pdo->prepare($sql);
  42. $stmt->execute($params);
  43. $response = $single ? $stmt->fetch(PDO::FETCH_ASSOC) : $stmt->fetchAll(PDO::FETCH_ASSOC);
  44. return $response;
  45. } catch (PDOException $e) {
  46. echo "Error: " . $e->getMessage();
  47. return false;
  48. } finally {
  49. $stmt->closeCursor();
  50. $stmt = null;
  51. }
  52. }
  53. function queryAll(string $sql, array $params = null)
  54. {
  55. return query($sql, $params, false);
  56. }
  57. function toSQLArray(array $array): string
  58. {
  59. return sprintf("{%s}", implode(", ", $array));
  60. }