20220717
This commit is contained in:
55
fcms-core/classes/FcmsDB.php
Normal file
55
fcms-core/classes/FcmsDB.php
Normal file
@@ -0,0 +1,55 @@
|
||||
<?php
|
||||
/*
|
||||
* Класс для работы с базой данных
|
||||
* @package freecms
|
||||
*/
|
||||
|
||||
namespace freecms\classes;
|
||||
|
||||
/**
|
||||
* Используем класс PDO для подключения к БД
|
||||
*/
|
||||
|
||||
use freecms;
|
||||
use freecms\components\Dictionary;
|
||||
use freecms\enums\DBDriversEnum;
|
||||
use PDO;
|
||||
use const freecms\FCMS_DB_DRIVER;
|
||||
use const freecms\FCMS_DBNAME;
|
||||
use const freecms\FCMS_DBUSERNAME;
|
||||
use const freecms\FCMS_DBUSERPASSWORD;
|
||||
|
||||
/**
|
||||
* Класс для работы с базой данных
|
||||
*/
|
||||
class FcmsDB
|
||||
{
|
||||
/**
|
||||
* @var PDO Переменная, хранящая класс PDO.
|
||||
*/
|
||||
private PDO $pdo;
|
||||
|
||||
/**
|
||||
* Конструктор. Подключает базу данных
|
||||
* @param DBDriversEnum $dbType Тип базы данных
|
||||
* @param string $connectionString Строка подключения к базе данных
|
||||
* @param string $userName Имя пользователя базы данных
|
||||
* @param string $userPassword Пароль к базе данных
|
||||
*/
|
||||
public function __construct()
|
||||
{
|
||||
$type = match (FCMS_DB_DRIVER) {
|
||||
DBDriversEnum::MSSQL => 'sqlsrv',
|
||||
DBDriversEnum::PostgreSQL => 'pgsql',
|
||||
DBDriversEnum::OracleDB => 'oci',
|
||||
DBDriversEnum::SQLite => 'sqlite',
|
||||
default => 'mysql',
|
||||
};
|
||||
$this->pdo = new PDO($type . ':' . FCMS_DBNAME, FCMS_DBUSERNAME, FCMS_DBUSERPASSWORD);
|
||||
}
|
||||
|
||||
public function select(string $query, Dictionary $variables)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
@@ -1,25 +0,0 @@
|
||||
<?php
|
||||
/*
|
||||
* Класс для работы с базой данных
|
||||
* @package freecms
|
||||
*/
|
||||
|
||||
namespace freecms\classes;
|
||||
|
||||
//Используем класс PDO для подключения к БД
|
||||
use PDO;
|
||||
|
||||
/*
|
||||
* Класс для работы с БД
|
||||
*/
|
||||
|
||||
class db
|
||||
{
|
||||
// Переменная инициализации PDO
|
||||
private PDO $pdo;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->pdo = new PDO ("");
|
||||
}
|
||||
}
|
103
fcms-core/components/Dictionary.php
Normal file
103
fcms-core/components/Dictionary.php
Normal file
@@ -0,0 +1,103 @@
|
||||
<?php
|
||||
/**
|
||||
* Класс словаря
|
||||
*/
|
||||
|
||||
namespace freecms\components;
|
||||
|
||||
use Exception;
|
||||
|
||||
/**
|
||||
* Словарь (реализация интерфейса IDictionary
|
||||
*/
|
||||
class Dictionary implements IDictionary
|
||||
{
|
||||
/**
|
||||
* @var array Содержимое словаря
|
||||
*/
|
||||
private array $dict;
|
||||
|
||||
public function __construct()
|
||||
{
|
||||
$this->dict = [];
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
*/
|
||||
public function add(string $key, mixed $value): void
|
||||
{
|
||||
if (!$this->isKeyExists($key)) {
|
||||
$this->dict[$key] = $value;
|
||||
} else {
|
||||
$this->update($key, $value);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
*/
|
||||
public function isKeyExists(string $key): bool
|
||||
{
|
||||
return array_key_exists($key, $this->dict);
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
*/
|
||||
public function update(string $key, mixed $newValue): void
|
||||
{
|
||||
if (!$this->isKeyExists($key)) {
|
||||
$this->add($key, $newValue);
|
||||
} else {
|
||||
$this->dict[$key] = $newValue;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
* @throws Exception Если ключ не существует
|
||||
*/
|
||||
public function get(string $key): mixed
|
||||
{
|
||||
if ($this->isKeyExists($key)) {
|
||||
return $this->dict[$key];
|
||||
} else {
|
||||
throw new Exception('Ключ "' . $key . '" не существует в этом словаре!', 0, null);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
* @throws Exception Если ключ не существует
|
||||
*/
|
||||
public function clear(): void
|
||||
{
|
||||
$keys = $this->getAllKeys();
|
||||
|
||||
foreach ($keys as $key) {
|
||||
$this->remove($key);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
*/
|
||||
public function getAllKeys(): array
|
||||
{
|
||||
return array_keys($this->dict);
|
||||
}
|
||||
|
||||
/**
|
||||
* @inheritDoc
|
||||
* @throws Exception Если ключ не существует
|
||||
*/
|
||||
public function remove(string $key): void
|
||||
{
|
||||
if ($this->isKeyExists($key)) {
|
||||
unset($this->dict[$key]);
|
||||
} else {
|
||||
throw new Exception('Ключ "' . $key . '" не существует в этом словаре!', 0, null);
|
||||
}
|
||||
}
|
||||
}
|
62
fcms-core/components/IDictionary.php
Normal file
62
fcms-core/components/IDictionary.php
Normal file
@@ -0,0 +1,62 @@
|
||||
<?php
|
||||
/**
|
||||
* Интерфейс словаря.
|
||||
* @package freecms
|
||||
*/
|
||||
|
||||
namespace freecms\components;
|
||||
|
||||
/**
|
||||
* Словарь
|
||||
*/
|
||||
interface IDictionary
|
||||
{
|
||||
/**
|
||||
* Добавление строки в словарь
|
||||
* @param string $key Ключ
|
||||
* @param mixed $value Значение
|
||||
* @return void
|
||||
*/
|
||||
public function add(string $key, mixed $value): void;
|
||||
|
||||
/**
|
||||
* Получение значения по ключу
|
||||
* @param string $key Ключ
|
||||
* @return mixed
|
||||
*/
|
||||
public function get(string $key): mixed;
|
||||
|
||||
/**
|
||||
* Обновление значения
|
||||
* @param string $key Ключ
|
||||
* @param mixed $newValue Новое значение
|
||||
* @return void
|
||||
*/
|
||||
public function update(string $key, mixed $newValue): void;
|
||||
|
||||
/**
|
||||
* Получение всех ключей
|
||||
* @return array Одномерный массив ключей
|
||||
*/
|
||||
public function getAllKeys(): array;
|
||||
|
||||
/**
|
||||
* Проверяет существование ключа
|
||||
* @param string $key Ключ
|
||||
* @return bool
|
||||
*/
|
||||
public function isKeyExists(string $key): bool;
|
||||
|
||||
/**
|
||||
* Удаляет ключ
|
||||
* @param string $key Ключ
|
||||
* @return void
|
||||
*/
|
||||
public function remove(string $key): void;
|
||||
|
||||
/**
|
||||
* Очищает словарь
|
||||
* @return void
|
||||
*/
|
||||
public function clear(): void;
|
||||
}
|
19
fcms-core/enums/DBDriversEnum.php
Normal file
19
fcms-core/enums/DBDriversEnum.php
Normal file
@@ -0,0 +1,19 @@
|
||||
<?php
|
||||
/**
|
||||
* Перечисление драйверов баз данных
|
||||
* @package freecms
|
||||
*/
|
||||
|
||||
namespace freecms\enums;
|
||||
|
||||
/**
|
||||
*Перечисление PDO-драйверов
|
||||
*/
|
||||
enum DBDriversEnum
|
||||
{
|
||||
case MySQL;
|
||||
case MSSQL;
|
||||
case PostgreSQL;
|
||||
case OracleDB;
|
||||
case SQLite;
|
||||
}
|
@@ -4,4 +4,25 @@
|
||||
* @package FreeCMS
|
||||
*/
|
||||
|
||||
//Подключаем глобальные параметры сервера
|
||||
namespace freecms;
|
||||
|
||||
use Whoops\Handler\PrettyPageHandler;
|
||||
use Whoops\Run;
|
||||
|
||||
/**
|
||||
* Подключаем настройки
|
||||
*/
|
||||
require 'fcms-configs/config.php';
|
||||
/**
|
||||
* Подключаем автозагрузчик
|
||||
*/
|
||||
require './vendor/autoload.php';
|
||||
|
||||
/**
|
||||
* Подключаем страницу с ошибками (только в режиме разработки)
|
||||
*/
|
||||
if (FCMS_ENVIRONMENT == 'dev') {
|
||||
$whoops = new Run();
|
||||
$whoops->pushHandler(new PrettyPageHandler());
|
||||
$whoops->register();
|
||||
}
|
||||
|
Reference in New Issue
Block a user