Server IP : 103.119.228.120 / Your IP : 18.226.17.251 Web Server : Apache System : Linux v8.techscape8.com 3.10.0-1160.119.1.el7.tuxcare.els2.x86_64 #1 SMP Mon Jul 15 12:09:18 UTC 2024 x86_64 User : nobody ( 99) PHP Version : 5.6.40 Disable Function : shell_exec,symlink,system,exec,proc_get_status,proc_nice,proc_terminate,define_syslog_variables,syslog,openlog,closelog,escapeshellcmd,passthru,ocinum cols,ini_alter,leak,listen,chgrp,apache_note,apache_setenv,debugger_on,debugger_off,ftp_exec,dl,dll,myshellexec,proc_open,socket_bind,proc_close,escapeshellarg,parse_ini_filepopen,fpassthru,exec,passthru,escapeshellarg,escapeshellcmd,proc_close,proc_open,ini_alter,popen,show_source,proc_nice,proc_terminate,proc_get_status,proc_close,pfsockopen,leak,apache_child_terminate,posix_kill,posix_mkfifo,posix_setpgid,posix_setsid,posix_setuid,dl,symlink,shell_exec,system,dl,passthru,escapeshellarg,escapeshellcmd,myshellexec,c99_buff_prepare,c99_sess_put,fpassthru,getdisfunc,fx29exec,fx29exec2,is_windows,disp_freespace,fx29sh_getupdate,fx29_buff_prepare,fx29_sess_put,fx29shexit,fx29fsearch,fx29ftpbrutecheck,fx29sh_tools,fx29sh_about,milw0rm,imagez,sh_name,myshellexec,checkproxyhost,dosyayicek,c99_buff_prepare,c99_sess_put,c99getsource,c99sh_getupdate,c99fsearch,c99shexit,view_perms,posix_getpwuid,posix_getgrgid,posix_kill,parse_perms,parsesort,view_perms_color,set_encoder_input,ls_setcheckboxall,ls_reverse_all,rsg_read,rsg_glob,selfURL,dispsecinfo,unix2DosTime,addFile,system,get_users,view_size,DirFiles,DirFilesWide,DirPrintHTMLHeaders,GetFilesTotal,GetTitles,GetTimeTotal,GetMatchesCount,GetFileMatchesCount,GetResultFiles,fs_copy_dir,fs_copy_obj,fs_move_dir,fs_move_obj,fs_rmdir,SearchText,getmicrotime MySQL : ON | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /usr/share/awl/inc/ |
Upload File : |
<?php /** * AwlDatabase query/statement class and associated functions * * This subpackage provides some functions that are useful around database * activity and a AwlDBDialect, AwlDatabase and AwlStatement classes to simplify * handling of database queries and provide some access for a limited * ability to handle varying database dialects. * * The class is intended to be a very lightweight wrapper with some features * that have proved useful in developing and debugging web-based applications: * - All queries are timed, and an expected time can be provided. * - Parameters replaced into the SQL will be escaped correctly in order to * minimise the chances of SQL injection errors. * - Queries which fail, or which exceed their expected execution time, will * be logged for potential further analysis. * - Debug logging of queries may be enabled globally, or restricted to * particular sets of queries. * - Simple syntax for iterating through a result set. * * See http://wiki.davical.org/w/AwlDatabase for design and usage information. * * If not already connected, AwlDatabase will attempt to connect to the database, * successively applying connection parameters from the array in $c->pdo_connect. * * We will die if the database is not currently connected and we fail to find * a working connection. * * @package awl * @subpackage AwlDatabase * @author Andrew McMillan <andrew@morphoss.com> * @copyright Morphoss Ltd * @license http://gnu.org/copyleft/gpl.html GNU GPL v3 or later * @compatibility Requires PHP 5.1 or later */ require_once('AwlDBDialect.php'); if ( !defined('E_USER_ERROR') ) define('E_USER_ERROR',256); /** * Methods in the AwlDBDialect class which we inherit, include: * __construct() * SetSearchPath( $search_path ) * GetVersion() * GetFields( $tablename_string ) * TranslateSQL( $sql_string ) * Quote( $value, $value_type = null ) * ReplaceParameters( $query_string [, param [, ...]] ) */ /** * Typically there will only be a single instance of the database level class in an application. * @package awl */ class AwlDatabase extends AwlDBDialect { /**#@+ * @access private */ /** * Holds the state of the transaction 0 = not started, 1 = in progress, -1 = error pending rollback/commit */ protected $txnstate = 0; /** * Holds whether we are translating all statements. */ protected $translate_all = false; /**#@-*/ /** * Returns a PDOStatement object created using this database, the supplied SQL string, and any parameters given. * @param string $sql_query_string The SQL string containing optional variable replacements * @param array $driver_options PDO driver options to the prepare statement, commonly to do with cursors */ function prepare( $statement, $driver_options = array() ) { if ( isset($this->translate_all) && $this->translate_all ) { $statement = $this->TranslateSQL( $statement ); } return $this->db->prepare( $statement, $driver_options ); } /** * Returns a PDOStatement object created using this database, the supplied SQL string, and any parameters given. * @param string $sql_query_string The SQL string containing optional variable replacements * @param mixed ... Subsequent arguments are positionally replaced into the $sql_query_string */ function query( $statement ) { return $this->db->query( $statement ); } /** * Begin a transaction. */ function Begin() { if ( $this->txnstate == 0 ) { $this->db->beginTransaction(); $this->txnstate = 1; } else { fatal("Cannot begin a transaction while a transaction is already active."); } return true; } /** * Complete a transaction. */ function Commit() { if ( $this->txnstate != 0 ) { $this->db->commit(); $this->txnstate = 0; } return true; } /** * Cancel a transaction in progress. */ function Rollback() { if ( $this->txnstate != 0 ) { $this->db->rollBack(); $this->txnstate = 0; } else { throw new Exception("Cannot rollback unless a transaction is already active."); } return true; } /** * Returns the current state of a transaction, indicating if we have begun a transaction, whether the transaction * has failed, or if we are not in a transaction. * @return int 0 = not started, 1 = in progress, -1 = error pending rollback/commit */ function TransactionState() { return $this->txnstate; } /** * Operates identically to AwlDatabase::Prepare, except that $this->Translate() will be called on the query * before any processing. */ function PrepareTranslated( $statement, $driver_options = array() ) { $statement = $this->TranslateSQL( $statement ); return $this->prepare( $statement, $driver_options ); } /** * Switches on or off the processing flag controlling whether subsequent calls to AwlDatabase::Prepare are translated * as if PrepareTranslated() had been called. */ function TranslateAll( $onoff_boolean ) { $this->translate_all = $onoff_boolean; return $onoff_boolean; } /** * */ function ErrorInfo() { return $this->db->errorInfo(); } }