Merged changes from master branch up to current state.
[fa-stable.git] / includes / db_pager.inc
index 522b04b6873eb1aa9da1ca2258fa8c053c6d8574..70243392f75e53096ca1c1de63af72fa901c30fc 100644 (file)
@@ -57,7 +57,12 @@ class db_pager {
        var $key;       // key field name
        
        //  db_pager constructor
-       //  accepts $sql like 'SELECT ...[FROM ...][WHERE ...][GROUP ...][ORDER ...]'
+       //  accepts $sql query either as:
+       //  a. string in form 'SELECT field_list FROM table_joins [WHERE conditions [GROUP group_list [ORDER order_list]]]'
+       //              - if WHERE keyword is used in table_joins, WHERE conditions is obligatory
+       //  b. associative array using select, where, group and order keys ex :
+       //      array('select' => 'SUM(quantity)', 'from' => TB_PREF."stock_moves", 'group' => 'location')
+       //
        //      $name is base name for pager controls
        function db_pager($sql, $name, $table = null, $page_len=0) 
        {
@@ -68,14 +73,12 @@ class db_pager {
                $this->set_sql($sql);
        }
        //
-       //      Parse base sql select query.
-       //      or use an associative array.
-       //  Usefull is the query can't be split correctly (using subquery for example).
-       //  The associative array shouldn't contain the keyword itself.
-       //  ex :
-       //  array('select' => 'SUM(quantity)', 'from' => TB_PREF."stock_moves", 'group' => 'location')
+       //      Parse base sql select query     or use an associative array.
+       //
        function set_sql($sql)
        {
+               global $SysPrefs;
+
                if ($sql != $this->sql) {
                    $this->sql = $sql;
                    $this->ready = false;
@@ -88,29 +91,39 @@ class db_pager {
                                }
                                else {
                                        // parse the query
-                                               $parts = preg_split('/\sORDER\s*BY\s/si', $sql, 2);
-                                       if(count($parts) == 2) {
-                                               $sql = $parts[0];
-                                               $this->order = $parts[1];
-                                       }
-                                               $parts = preg_split('/\sGROUP\s*BY\s/si', $sql, 2);
-                                       if(count($parts) == 2) {
-                                               $sql = $parts[0];
-                                               $this->group = $parts[1];
+                                       $parts = preg_split('/\sFROM\s/si', $sql, 2);
+                                       if (count($parts) == 2) {
+                                               $this->select = $parts[0];
+                                               $sql = $parts[1];
+                                       } else {
+                                               if ($SysPrefs->go_debug)
+                                                       display_error("Invalid sql input for db_pager");
                                        }
-                                               $parts = preg_split('/\sWHERE\s/si', $sql, 2);
-                                       if(count($parts) == 2) {
-                                               $sql = $parts[0];
-                                               $this->where = $parts[1];
-                                       }
-                                               $parts = preg_split('/\sFROM\s/si', $sql, 2);
+
+                                       $parts = preg_split('/\sWHERE(?!.*WHERE.*)\s/si', $sql, 2); // last occurence
                                        if(count($parts) == 2) {
-                                               $sql = $parts[0];
-                                               $this->from = $parts[1];
+                                               $this->from = $parts[0];
+                                               $sql = $parts[1];
+
+                                               $parts = preg_split('/\sORDER\s*BY\s/si', $sql, 2);
+                                               if(count($parts) == 2) {
+                                                       $sql = $parts[0];
+                                                       $this->order = $parts[1];
+                                               }
+                                               $parts = preg_split('/\sGROUP\s*BY\s/si', $sql, 2);
+                                               if(count($parts) == 2) {
+                                                       $sql = $parts[0];
+                                                       $this->group = $parts[1];
+                                               }
+                                               $this->where = $sql;
                                        }
-                                       $this->select = $sql;
                        }
                }
+               //_vd($this->select);
+               //_vd($this->from);
+               //_vd($this->where);
+               //_vd($this->group);
+               //_vd($this->order);
        }
        //
        //      Set additional constraint on record set
@@ -197,7 +210,7 @@ class db_pager {
                } else 
                  return false;
                return true;
-       }           
+       }
        //
        //      Calculates page numbers for html controls.
        //
@@ -312,8 +325,7 @@ class db_pager {
            }
 
            if (count($ord)) {
-                       $ord = array_map(function_exists('mysql_real_escape_string') ? 
-                               'mysql_real_escape_string': 'mysql_escape_string', $ord);
+                       $ord = array_map('db_escape_function', $ord);
                        $sql .= " ORDER BY " . implode(',', $ord);
                } else {
                        if($order)
@@ -333,7 +345,7 @@ class db_pager {
        //
        function _init() 
        {
-               global $go_debug;
+               global $SysPrefs;
                
            if ($this->ready == false ) {
                        $sql = $this->_sql_gen(true);
@@ -345,14 +357,14 @@ class db_pager {
                        $this->max_page = $this->page_len ?
                                ceil($this->rec_count/$this->page_len) : 0;
                
-                       if ($go_debug) { // FIX - need column name parsing, but for now:
+                       if ($SysPrefs->go_debug) { // FIX - need column name parsing, but for now:
                                // check if field names are set explicite in col def
                                // for all initially ordered columns
                            foreach ($this->columns as $col) {
                                if (isset($col['ord']) && $col['ord'] != '' 
                                                &&  !isset($col['name'])) {
                                                        display_warning("Result field names must be set
-                                                               for all intially ordered db_pager columns.");
+                                                               for all initially ordered db_pager columns.");
                                }
                                }
                }
@@ -501,4 +513,3 @@ function refresh_pager($name)
        if (isset($_SESSION[$name]))
                $_SESSION[$name]->ready = false;
 }
-?>