db.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. require_once "config.php";
  3. function db_connect($host, $user, $pass, $db) {
  4. if (DB_TYPE == "pgsql") {
  5. $string = "dbname=$db user=$user";
  6. if ($pass) {
  7. $string .= " password=$pass";
  8. }
  9. if ($host) {
  10. $string .= " host=$host";
  11. }
  12. if (defined('DB_PORT') && DB_PORT) {
  13. $string = "$string port=" . DB_PORT;
  14. }
  15. $link = pg_connect($string);
  16. if (!$link) {
  17. die("Unable to connect to database (as $user to $host, database $db):" . pg_last_error());
  18. }
  19. return $link;
  20. } else if (DB_TYPE == "mysql") {
  21. $link = mysql_connect($host, $user, $pass);
  22. if ($link) {
  23. $result = mysql_select_db($db, $link);
  24. if (!$result) {
  25. die("Can't select DB: " . mysql_error($link));
  26. }
  27. return $link;
  28. } else {
  29. die("Unable to connect to database (as $user to $host, database $db): " . mysql_error());
  30. }
  31. }
  32. }
  33. function db_escape_string($link, $s, $strip_tags = true) {
  34. if ($strip_tags) $s = strip_tags($s);
  35. if (DB_TYPE == "pgsql") {
  36. return pg_escape_string($link, $s);
  37. } else {
  38. return mysql_real_escape_string($s, $link);
  39. }
  40. }
  41. function db_query($link, $query, $die_on_error = true) {
  42. if (DB_TYPE == "pgsql") {
  43. $result = pg_query($link, $query);
  44. if (!$result) {
  45. $query = htmlspecialchars($query); // just in case
  46. if ($die_on_error) {
  47. die("Query <i>$query</i> failed [$result]: " . ($link ? pg_last_error($link) : "No connection"));
  48. }
  49. }
  50. return $result;
  51. } else if (DB_TYPE == "mysql") {
  52. $result = mysql_query($query, $link);
  53. if (!$result) {
  54. $query = htmlspecialchars($query);
  55. if ($die_on_error) {
  56. die("Query <i>$query</i> failed: " . ($link ? mysql_error($link) : "No connection"));
  57. }
  58. }
  59. return $result;
  60. }
  61. }
  62. function db_fetch_assoc($result) {
  63. if (DB_TYPE == "pgsql") {
  64. return pg_fetch_assoc($result);
  65. } else if (DB_TYPE == "mysql") {
  66. return mysql_fetch_assoc($result);
  67. }
  68. }
  69. function db_num_rows($result) {
  70. if (DB_TYPE == "pgsql") {
  71. return pg_num_rows($result);
  72. } else if (DB_TYPE == "mysql") {
  73. return mysql_num_rows($result);
  74. }
  75. }
  76. function db_fetch_result($result, $row, $param) {
  77. if (DB_TYPE == "pgsql") {
  78. return pg_fetch_result($result, $row, $param);
  79. } else if (DB_TYPE == "mysql") {
  80. // I hate incoherent naming of PHP functions
  81. return mysql_result($result, $row, $param);
  82. }
  83. }
  84. function db_unescape_string($str) {
  85. $tmp = str_replace("\\\"", "\"", $str);
  86. $tmp = str_replace("\\'", "'", $tmp);
  87. return $tmp;
  88. }
  89. function db_close($link) {
  90. if (DB_TYPE == "pgsql") {
  91. return pg_close($link);
  92. } else if (DB_TYPE == "mysql") {
  93. return mysql_close($link);
  94. }
  95. }
  96. function db_affected_rows($link, $result) {
  97. if (DB_TYPE == "pgsql") {
  98. return pg_affected_rows($result);
  99. } else if (DB_TYPE == "mysql") {
  100. return mysql_affected_rows($link);
  101. }
  102. }
  103. function db_last_error($link) {
  104. if (DB_TYPE == "pgsql") {
  105. return pg_last_error($link);
  106. } else if (DB_TYPE == "mysql") {
  107. return mysql_error($link);
  108. }
  109. }
  110. function db_quote($str){
  111. return("'$str'");
  112. }
  113. ?>