PHP Classes

File: www/_mmServerScripts/MMHTTPDB.php

Recommend this page to a friend!
  Classes of Adnane EL Mouttaki   Covoiturage Libre   www/_mmServerScripts/MMHTTPDB.php   Download  
File: www/_mmServerScripts/MMHTTPDB.php
Role: Example script
Content type: text/plain
Description: Example script
Class: Covoiturage Libre
Web application for managing a carpoling site
Author: By
Last change:
Date: 6 years ago
Size: 4,406 bytes
 

Contents

Class file image Download
<?php // <ERRORS><ERROR><DESCRIPTION>Your testing server do not has support for PHP pages</DESCRIPTION></ERROR>\n</ERRORS>

$debug_to_file = false;

function
log_messages($error_message){
        global
$f, $debug_to_file;
        if (
$debug_to_file === true){
                if (!
is_resource($f)){
                        @
ini_set('display_errors', 1);
                        @
error_reporting(E_ALL);
                       
$f = @fopen('log.txt', 'a');
                }
                if (
is_resource($f)){
                        return @
fwrite($f, $error_message."\n");
                }
        }
        return
false;
}
function
create_error($error_msg = '', $line = -1){
        if (
$error_msg != ''){
                return
'<ERRORS><ERROR><DESCRIPTION>'.$error_msg.'</DESCRIPTION></ERROR></ERRORS>\n';
        }else{
                return
'<ERRORS><ERROR><DESCRIPTION> Unidentified Connection Error at Line '.$line.'</DESCRIPTION></ERROR></ERRORS>\n';
        }
}

log_messages("\n--------------------------------");
// what parameters were sent ?!
foreach($_POST as $key=>$value) {
     if (
strtoupper($key) != 'PASSWORD'){
            
log_messages('$_POST["'.$key.'"] = \''.$value."';");
     }
}
// We need these information only once when the test button is hit
if (isset($_POST['opCode']) && $_POST['opCode'] == 'IsOpen' ){
       
// What PHP version
       
log_messages("\nPHP-Version: ".phpversion());
       
// What OS System is running on
       
log_messages('PHP-OS: '.PHP_OS);
       
// How PHP is installed (CGI, ISAPI, FastCGI)
        // !!!! Major difference exists on these servers for $_ENV, $_SERVER
       
log_messages('PHP-SAPI-NAME: '.php_sapi_name());
       
// MySQL, mbstring modules are installed ?!
       
log_messages('PHP-Extensions: '.var_export(get_loaded_extensions(),true));
}

if(
extension_loaded('mbstring'))
{
   
$acceptCharsetHeader = 'Accept-Charset: ' . mb_internal_encoding();
   
header( $acceptCharsetHeader );
   
$head = '<html><head><meta http-equiv=\'Content-Type\' content=\'text/html; charset=' . mb_http_output() . '\'></head>';
    echo
$head;
}else{
    echo
'<html><head></head>';
}

// Build connection object
if (isset($_POST['Type']) && $_POST['Type'] == 'MYSQL')
{
    require(
"./mysql.php");
   
$oConn = new MySqlConnection(@$_POST['ConnectionString'], @$_POST['Timeout'], @$_POST['Host'], @$_POST['Database'], @$_POST['UserName'], @$_POST['Password']);
    if (!isset(
$oConn) || $oConn == false){
           
log_messages("\n".'MySQL Connection Object initialisation failed'."\n\n".@$error);
    }else{
           
log_messages("\n".'MySQL Connection Object Created'."\n\n");
    }
}else{
    
$error=create_error('The files from the _mmServerScripts folder are for the server model PHP-MySQL. You try to connect to a database using a different server model '.@$_POST['Type'].".\n\nPlease remove this folder outside the Dreamweaver environment on both local and testing machines and try again.",__LINE__);
    
log_messages("\nError Sent:\n\n\t".@$error."\n\n\n");
     echo
$error.'</HTML>';
     return;
}

// Process opCode
if (isset($oConn) && $oConn)
{
   
$oConn->Open();

    if (
$_POST['opCode'] == 'IsOpen'){
           
$answer = $oConn->TestOpen();
    }elseif (
is_resource($oConn->connectionId) && $oConn->isOpen){

        switch (
$_POST['opCode']){
                case
'GetTables': $answer = $oConn->GetTables(@$_POST['Database']); break;
                case
'GetColsOfTable': $answer = $oConn->GetColumnsOfTable(@$_POST['TableName']); break;
                case
'ExecuteSQL': $answer = $oConn->ExecuteSQL(@$_POST['SQL'], @$_POST['MaxRows']); break;
                case
'GetODBCDSNs': $answer = $oConn->GetDatabaseList(); break;
                case
'SupportsProcedure': $answer = $oConn->SupportsProcedure(); break;
                case
'GetProviderTypes': $answer = $oConn->GetProviderTypes(); break;
                case
'GetViews': $answer = $oConn->GetViews(); break;
                case
'GetProcedures': $answer = $oConn->GetProcedures(); break;
                case
'GetParametersOfProcedure': $answer = $oConn->GetParametersOfProcedure(@$_POST['ProcName']); break;
                case
'ReturnsResultset': $answer = $oConn->ReturnsResultSet($_POST['RRProcName']); break;
                case
'ExecuteSP': $answer = $oConn->ExecuteSP(@$_POST['ExecProcName'], 0, @$_POST['ExecProcParameters']); break;
                case
'GetKeysOfTable': $answer = $oConn->GetPrimaryKeysOfTable(@$_POST['TableName']); break;
                default:
$answer = create_error('The \''.$_POST['opCode'].'\' command is not supported.'); break;
        }
    }

   
$oConn->Close();
}else{
   
$answer = create_error('The Connection Module was not initialized properly for an unknown reason.');
}

log_messages("\nAnswer From Database:\n\n\t".@$answer."\n\n\n");
echo
$answer;

echo
'</html>';
?>