MS-Tropical/app/modules/DatabaseModule.php
2024-06-29 08:07:30 -05:00

110 lines
3.2 KiB
PHP
Executable File

<?php
/*
--- The Database Module
--- This module is for the general CRUD methods.
--- This module was crafted by Skylear. : )
--- Copyright (c) Mad Splash, 2014, all rights reserved.
*/
class DatabaseModule {
/* --- Variables - data the module needs to work with. --- */
private $Handle = null;
private $userHandle = null;
private $FHandle = null;
/* --- Constructor - creates the module's instance. --- */
public function __construct() {
$DBUsername = 'root';
$DBPassword = 'root';
$DBName = 'database';
try {
$DBHandle = new PDO('mysql: host=localhost; dbname=' . $DBName, $DBUsername, $DBPassword);
} catch(PDOException $ex) {
die("Oops, we failed to the connect to the database. The error: " . $ex->getMessage() . ".");
}
$DBHandle->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$DBHandle->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
$this->Handle = $DBHandle;
}
public function createUserHandle() {
$DBUsername = 'root';
$DBPassword = 'root';
$DBName = 'database';
try {
$DBHandle = new PDO('mysql: host=localhost; dbname=' . $DBName, $DBUsername, $DBPassword);
} catch(PDOException $ex) {
die("Oops, we failed to the connect to the database. The error: " . $ex->getMessage() . ".");
}
$DBHandle->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$DBHandle->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
$this->userHandle = $DBHandle;
}
public function createFHandle() {
$DBUsername = 'root';
$DBPassword = 'root';
$DBName = 'database';
try {
$DBHandle = new PDO('mysql: host=localhost; dbname=' . $DBName, $DBUsername, $DBPassword);
} catch(PDOException $ex) {
die("Oops, we failed to the connect to the database. The error: " . $ex->getMessage() . ".");
}
$DBHandle->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$DBHandle->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
$this->FHandle = $DBHandle;
}
public function __get($what) {
if(property_exists($this, $what)) {
return $this->{$what};
} else {
return null;
}
}
/* --- Module Functions - the meat and purpose of the module. --- */
/* Create Table - for creating a table when need be.
* @param string $name - the name of the table to be created.
* @param string $columns - a long string containing the columns to be made.
*/
public function createTable($name, $columns) {
// No need for creating tables for the time being.
}
/* Select Data - used for getting data from the database.
* @return array $selectedRos - an array containing the data.
*/
public function getData($from, $retrieve, $condition, $limit, $orderby) {
$Handle = $this->Handle;
$query = 'SELECT ' . $retrieve . ' FROM ' . $from . ' ' . $condition . ' ' . $orderby . ' ' . $limit ;
$selectQuery = $Handle->prepare($query);
$selectQuery->execute();
$selectedRows = $selectQuery->fetchAll();
return $selectedRows;
}
public function countRows($which, $condition) {
$Handle = $this->Handle;
$query = 'SELECT COUNT(*) FROM ' . $which . ' ' . $condition;
$count = $Handle->query($query);
return $count->fetch();
}
}
?>