2008-11-26 14:50:40 -08:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* AgileBill - Open Billing Software
|
|
|
|
*
|
|
|
|
* This body of work is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the Open AgileBill License
|
|
|
|
* License as published at http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
*
|
|
|
|
* Originally authored by Tony Landis, AgileBill LLC
|
|
|
|
*
|
|
|
|
* Recent modifications by Deon George
|
|
|
|
*
|
|
|
|
* @author Deon George <deonATleenooksDOTnet>
|
|
|
|
* @copyright 2009 Deon George
|
|
|
|
* @link http://osb.leenooks.net
|
2008-11-26 14:50:40 -08:00
|
|
|
*
|
|
|
|
* @link http://www.agileco.com/
|
|
|
|
* @copyright 2004-2008 Agileco, LLC.
|
|
|
|
* @license http://www.agileco.com/agilebill/license1-4.txt
|
2009-08-03 14:10:16 +10:00
|
|
|
* @author Tony Landis <tony@agileco.com>
|
2008-11-26 14:50:40 -08:00
|
|
|
* @package AgileBill
|
2009-08-03 14:10:16 +10:00
|
|
|
* @subpackage Core
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The main AgileBill CORE Database SEARCH Method
|
|
|
|
*
|
|
|
|
* @uses CORE_validate
|
|
|
|
* @uses CORE_trigger
|
|
|
|
* @uses CORE_search
|
2008-11-26 14:50:40 -08:00
|
|
|
*/
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
function CORE_database_search($VAR,$construct,$type) {
|
|
|
|
global $C_list;
|
|
|
|
|
|
|
|
include_once(PATH_CORE.'validate.inc.php');
|
2008-11-26 14:50:40 -08:00
|
|
|
$validate = new CORE_validate;
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$db = &DB();
|
|
|
|
|
|
|
|
# Set the search criteria array
|
2008-11-26 14:50:40 -08:00
|
|
|
$arr = $VAR;
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Loop through the submitted field_names to get the WHERE statement
|
2008-11-26 14:50:40 -08:00
|
|
|
$where_list = '';
|
|
|
|
$i=0;
|
2009-08-03 14:10:16 +10:00
|
|
|
$pat = sprintf('/^%s_/',$construct->module);
|
|
|
|
while (list($key,$value) = each($arr)) {
|
|
|
|
if ($value != '') {
|
|
|
|
if (preg_match($pat,$key)) {
|
|
|
|
$field = preg_replace($pat,'',$key);
|
|
|
|
|
|
|
|
if (! is_array($value) && preg_match('/%/',$value)) {
|
|
|
|
# Do any data conversion for this field (date, encrypt, etc...)
|
|
|
|
if (isset($construct->field[$field]['convert']))
|
|
|
|
$value = $validate->convert($field,$value,$construct->field[$field]['convert']);
|
|
|
|
|
|
|
|
if ($i)
|
|
|
|
$where_list .= sprintf(' AND %s LIKE %s ',$field,$db->qstr($value,get_magic_quotes_gpc()));
|
2008-11-26 14:50:40 -08:00
|
|
|
else
|
2009-08-03 14:10:16 +10:00
|
|
|
$where_list .= sprintf(' WHERE %s LIKE %s',$field,$db->qstr($value,get_magic_quotes_gpc()));
|
|
|
|
|
|
|
|
$i++;
|
|
|
|
|
|
|
|
} else {
|
|
|
|
# Check if array
|
|
|
|
if (is_array($value)) {
|
|
|
|
for ($i_arr=0; $i_arr<count($value); $i_arr++) {
|
|
|
|
if ($value[$i_arr] != '') {
|
|
|
|
# Determine any field options (=, >, <, etc...)
|
|
|
|
$f_opt = '=';
|
|
|
|
$pat_field = sprintf('%s_%s',$construct->module,$field);
|
|
|
|
|
|
|
|
if (isset($VAR['field_option'][$pat_field][$i_arr])) {
|
|
|
|
$f_opt = $VAR['field_option'][$pat_field][$i_arr];
|
|
|
|
# Error checking, safety precaution
|
|
|
|
if (! in_array($f_opt,array('=','>','<','>=','<=','!=')))
|
|
|
|
$f_opt = '=';
|
|
|
|
}
|
|
|
|
|
|
|
|
# Do any data conversion for this field (date, encrypt, etc...)
|
|
|
|
if (isset($construct->field[$field]['convert']))
|
|
|
|
$value[$i_arr] = $validate->convert($field,$value[$i_arr],$construct->field[$field]['convert']);
|
|
|
|
|
|
|
|
if (($i_arr == 0) && ($i==0))
|
|
|
|
$where_list .= sprintf(' WHERE %s %s %s',$field,$f_opt,$db->qstr($value[$i_arr],get_magic_quotes_gpc()));
|
|
|
|
else
|
|
|
|
$where_list .= sprintf(' AND %s %s %s',$field,$f_opt,$db->qstr($value[$i_arr],get_magic_quotes_gpc()));
|
|
|
|
|
|
|
|
$i++;
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
} else {
|
|
|
|
if ($i)
|
|
|
|
$where_list .= sprintf(' AND %s=%s ',$field,$db->qstr($value,get_magic_quotes_gpc()));
|
2008-11-26 14:50:40 -08:00
|
|
|
else
|
2009-08-03 14:10:16 +10:00
|
|
|
$where_list .= sprintf(' WHERE %s=%s',$field,$db->qstr($value,get_magic_quotes_gpc()));
|
|
|
|
|
|
|
|
$i++;
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Some table joins
|
|
|
|
$join_table = '';
|
|
|
|
if (isset($VAR['join']) && is_array($VAR['join']))
|
|
|
|
foreach ($VAR['join'] as $table => $joins)
|
|
|
|
if ($C_list->is_installed($table)) {
|
|
|
|
|
|
|
|
include_once(PATH_MODULES.sprintf('%s/%s.inc.php',$table,$table));
|
|
|
|
$join = new $table;
|
|
|
|
|
|
|
|
if (method_exists($join,'sql_join')) {
|
|
|
|
foreach ($joins as $jointable => $id)
|
|
|
|
$q_join .= $join->sql_join($jointable,$id);
|
|
|
|
|
|
|
|
$join_table .= sprintf(',%s%s',AGILE_DB_PREFIX,$jointable);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($where_list)
|
|
|
|
$where_list .= sprintf(' AND %s',$q_join);
|
|
|
|
else
|
|
|
|
$where_list .= sprintf(' WHERE %s',$q_join);
|
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Finalize the WHERE statement
|
|
|
|
if ($where_list == '')
|
2008-11-26 14:50:40 -08:00
|
|
|
$where_list .= ' WHERE ';
|
|
|
|
else
|
|
|
|
$where_list .= ' AND ';
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Get limit type
|
|
|
|
if (isset($VAR['limit']))
|
2008-11-26 14:50:40 -08:00
|
|
|
$limit = $VAR['limit'];
|
|
|
|
else
|
|
|
|
$limit = $construct->limit;
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Get order by
|
|
|
|
if (isset($VAR['order_by']))
|
2008-11-26 14:50:40 -08:00
|
|
|
$order_by = $VAR['order_by'];
|
|
|
|
else
|
|
|
|
$order_by = $construct->order_by;
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Get any addition fields to select:
|
|
|
|
if (isset($construct->custom_EXP))
|
|
|
|
for ($ei=1; $ei<count($construct->custom_EXP); $ei++)
|
|
|
|
$field_list = sprintf(',%s',$construct->custom_EXP[$ei]['field']);
|
|
|
|
|
|
|
|
# Get any static vars to search
|
|
|
|
$join_list = '';
|
|
|
|
$pre = AGILE_DB_PREFIX;
|
2011-09-17 20:45:08 +10:00
|
|
|
/*
|
2009-08-03 14:10:16 +10:00
|
|
|
if (! empty($VAR['static_relation']) && count($VAR['static_relation']>0)) {
|
|
|
|
while (list($idx,$value) = each($VAR['static_relation'])) {
|
|
|
|
if ($value != '') {
|
|
|
|
$join_list .= sprintf(" INNER JOIN %sstatic_var_record AS s%s ON (s%s.record_id=%s%s.id AND s%s.static_var_relation_id='%s' AND s%s.site_id=%s AND",
|
|
|
|
$pre,$idx,$idx,$pre,$this->table,$idx,$idx,$idx,$db->qstr(DEFAULT_SITE));
|
|
|
|
|
|
|
|
if(preg_match('/%/',$value))
|
|
|
|
$join_list .= sprintf(' s%s.value LIKE %s',$idx,$db->qstr($VAR['static_relation'][$idx]));
|
|
|
|
else
|
|
|
|
$join_list .= sprintf(' s%s.value = %s',$idx,$db->qstr($VAR['static_relation'][$idx]));
|
|
|
|
|
|
|
|
$join_list .= ') ';
|
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# standard where list
|
|
|
|
$q .= $join_list . $where_list ." ".AGILE_DB_PREFIX."account.site_id = " . $db->qstr(DEFAULT_SITE);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Code for member group
|
|
|
|
if(!empty($VAR['account_group'])) {
|
|
|
|
$q .= " AND ".AGILE_DB_PREFIX."account_group.group_id = " . $db->qstr($VAR['account_group'])."
|
|
|
|
AND ".AGILE_DB_PREFIX."account_group.site_id = " . $db->qstr(DEFAULT_SITE);
|
|
|
|
}
|
|
|
|
if(!empty($VAR['account_group'])) {
|
|
|
|
$q_save .= " LEFT JOIN ".AGILE_DB_PREFIX."account_group ON ".AGILE_DB_PREFIX."account_group.account_id = ".AGILE_DB_PREFIX."account.id ";
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if(!empty($join_list))
|
|
|
|
$q_save .= $join_list;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$q_save .= $where_list ." %%whereList%% ";
|
|
|
|
$q_save .= AGILE_DB_PREFIX."account_group.group_id = " . $db->qstr($VAR['account_group'])." AND ";
|
|
|
|
} else {
|
|
|
|
if(!empty($join_list))
|
|
|
|
$q_save .= $join_list;
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
$q_save .= $where_list ." %%whereList%% ";
|
|
|
|
}
|
|
|
|
*/
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# generate the full query
|
|
|
|
$q = sprintf('SELECT %s%s.id AS id%s FROM %s%s %s %s %s%s.site_id=%s',
|
|
|
|
AGILE_DB_PREFIX,$construct->table,$field_list,
|
|
|
|
AGILE_DB_PREFIX,$construct->table,$join_table,
|
|
|
|
$where_list,AGILE_DB_PREFIX,$construct->table,DEFAULT_SITE);
|
|
|
|
$q_save = "SELECT %%fieldList%% FROM %%tableList%% $join_table".$where_list." %%whereList%% ";
|
|
|
|
$result = $db->Execute($q);
|
|
|
|
|
|
|
|
# Error reporting
|
|
|
|
if ($result === false) {
|
2008-11-26 14:50:40 -08:00
|
|
|
global $C_debug;
|
2009-08-03 14:10:16 +10:00
|
|
|
$C_debug->error(__FILE__,__METHOD__,$db->ErrorMsg());
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (isset($construct->trigger[$type])) {
|
|
|
|
include_once(PATH_CORE.'trigger.inc.php');
|
|
|
|
$trigger = new CORE_trigger;
|
|
|
|
$trigger->trigger($construct->trigger[$type],0,$VAR);
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
return;
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Get the result count:
|
2008-11-26 14:50:40 -08:00
|
|
|
$results = $result->RecordCount();
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Get the first record id:
|
|
|
|
if ($results == 1)
|
|
|
|
$record_id = $result->fields['id'];
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Run any custom validation on this result for this module
|
|
|
|
if (isset($construct->custom_EXP)) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$results = 0;
|
2009-08-03 14:10:16 +10:00
|
|
|
|
|
|
|
while (! $result->EOF) {
|
|
|
|
for ($ei=0; $ei<count($construct->custom_EXP); $ei++) {
|
|
|
|
$field = $construct->custom_EXP[$ei]['field'];
|
|
|
|
$value = $construct->custom_EXP[$ei]['value'];
|
|
|
|
|
|
|
|
if ($result->fields[$field] == $value) {
|
2008-11-26 14:50:40 -08:00
|
|
|
$ei = count($construct->custom_EXP);
|
2009-08-03 14:10:16 +10:00
|
|
|
$results++;
|
|
|
|
}
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
|
2008-11-26 14:50:40 -08:00
|
|
|
$result->MoveNext();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
# Define the DB vars as a Smarty accessible block
|
2008-11-26 14:50:40 -08:00
|
|
|
global $smarty;
|
|
|
|
|
|
|
|
# Create the definition for fast-forwarding to a single record:
|
|
|
|
if ($results == 1 && !isset($construct->fast_forward))
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('record_id',$record_id);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
|
|
|
# create the search record:
|
2009-08-03 14:10:16 +10:00
|
|
|
if ($results > 0) {
|
2008-11-26 14:50:40 -08:00
|
|
|
# create the search record
|
2009-08-03 14:10:16 +10:00
|
|
|
include_once(PATH_CORE.'search.inc.php');
|
2008-11-26 14:50:40 -08:00
|
|
|
$search = new CORE_search;
|
2009-08-03 14:10:16 +10:00
|
|
|
$arr['module'] = $construct->module;
|
2008-11-26 14:50:40 -08:00
|
|
|
$arr['sql'] = $q_save;
|
2009-08-03 14:10:16 +10:00
|
|
|
$arr['limit'] = $limit;
|
2008-11-26 14:50:40 -08:00
|
|
|
$arr['order_by']= $order_by;
|
|
|
|
$arr['results'] = $results;
|
|
|
|
$search->add($arr);
|
|
|
|
|
|
|
|
# define the search id and other parameters for Smarty
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('search_id',$search->id);
|
2008-11-26 14:50:40 -08:00
|
|
|
# page:
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('page','1');
|
2008-11-26 14:50:40 -08:00
|
|
|
# limit:
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('limit',$limit);
|
2008-11-26 14:50:40 -08:00
|
|
|
# order_by:
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('order_by',$order_by);
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
# define the result count
|
2009-08-03 14:10:16 +10:00
|
|
|
$smarty->assign('results',$results);
|
2008-11-26 14:50:40 -08:00
|
|
|
|
2009-08-03 14:10:16 +10:00
|
|
|
if (isset($construct->trigger[$type])) {
|
|
|
|
include_once(PATH_CORE.'trigger.inc.php');
|
|
|
|
$trigger = new CORE_trigger;
|
|
|
|
$trigger->trigger($construct->trigger[$type],1,$VAR);
|
2008-11-26 14:50:40 -08:00
|
|
|
}
|
|
|
|
}
|
2009-08-03 14:10:16 +10:00
|
|
|
?>
|