Uname: Linux webm005.cluster107.gra.hosting.ovh.net 5.15.167-ovh-vps-grsec-zfs-classid #1 SMP Tue Sep 17 08:14:20 UTC 2024 x86_64
User: 6036 (villadal)
Group: 100 (users)
Disabled functions: NONE
Safe mode: On[ PHPinfo ]
//home/villadal/www/old/////booked/lib/Database      ( Reset | Go to )
File Name: Database.php
Edit
<?php
/**
Copyright 2011-2014 Nick Korbel

This file is part of Booked Scheduler.

Booked Scheduler is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

Booked Scheduler is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with Booked Scheduler.  If not, see <http://www.gnu.org/licenses/>.
*/

class Database
{
    
/**
     * @var IDbConnection
     */
    
public $Connection null;

    public function 
__construct(IDbConnection &$dbConnection)
    {
        
$this->Connection = &$dbConnection;
    }

    
/**
     * Queries the database and returns an IReader
     *
     * @param ISqlCommand $command
     * @return IReader to iterate over
     */
    
public function &Query(ISqlCommand &$command)
    {
        
$this->Connection->Connect();

        
//Log::Debug('Database::Query %s', $command->GetQuery());

        
$reader $this->Connection->Query($command);
        
$this->Connection->Disconnect();

        return 
$reader;
    }

    
/**
     * @param ISqlCommand $command
     * @param int $limit
     * @param int $offset
     * @return IReader to iterate over
     */
    
public function &LimitQuery(ISqlCommand $command$limit$offset null)
    {
        
$this->Connection->Connect();

        
//Log::Debug('Database::LimitQuery %s', $command->GetQuery());

        
$reader $this->Connection->LimitQuery($command$limit$offset);
        
$this->Connection->Disconnect();

        return 
$reader;
    }

    
/**
     * Executes an alter query against the database
     *
     * @param SqlCommand $command
     * @return void
     */
    
public function Execute(ISqlCommand $command)
    {
        
$this->Connection->Connect();

        
//Log::Debug('Database::Execute %s', $command->GetQuery());

        
$this->Connection->Execute($command);
        
$this->Connection->Disconnect();
    }

    
/**
     * Executes an insert query against the database and returns the auto-increment id
     *
     * @param SqlCommand $command
     * @return long last id inserted for this connection
     */
    
public function ExecuteInsert(ISqlCommand $command)
    {
        
$this->Connection->Connect();

        
//Log::Debug('Database::ExecuteInsert %s', $command->GetQuery());

        
$this->Connection->Execute($command);
        
$insertedId $this->Connection->GetLastInsertId();
        
$this->Connection->Disconnect();

        return 
$insertedId;
    }
}

All system for education purposes only. For more tools: Telegram @jackleet

Mr.X Private Shell

Logo
-
New File | New Folder
Command
SQL