Compare commits
1 Commits
Author | SHA1 | Date |
---|---|---|
Michał Sieciechowicz | 248006a830 |
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name": "fufle/sibase2",
|
"name": "fufle/micro-orm",
|
||||||
"description": "MicroORM for php8",
|
"description": "MicroORM for php8",
|
||||||
"type": "orm",
|
"type": "orm",
|
||||||
"require": {
|
"require": {
|
||||||
|
@ -17,7 +17,7 @@
|
||||||
"autoload": {
|
"autoload": {
|
||||||
"psr-4": {
|
"psr-4": {
|
||||||
"Fufle\\": "src/Fufle/",
|
"Fufle\\": "src/Fufle/",
|
||||||
"Fufle\\Demo\\": "app/"
|
"Fufle\\Demo\\": "demo/"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,15 +5,16 @@ namespace Fufle\Demo\Model;
|
||||||
use Fufle\Demo\Query\IJobQuery;
|
use Fufle\Demo\Query\IJobQuery;
|
||||||
use Fufle\Demo\Query\JobQuery;
|
use Fufle\Demo\Query\JobQuery;
|
||||||
use Fufle\ORM\Model as BaseModel;
|
use Fufle\ORM\Model as BaseModel;
|
||||||
|
use Fufle\ORM\IQuery;
|
||||||
|
|
||||||
class Job extends BaseModel {
|
class Job extends BaseModel {
|
||||||
public int $id;
|
public int $id;
|
||||||
public float $budget;
|
public float $budget;
|
||||||
public static function QueryModel() {
|
public static function SetQueryModel(): IQuery {
|
||||||
return new JobQuery( static::class );
|
return new JobQuery( static::class );
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function GetLast10() {
|
public static function GetLast10() {
|
||||||
return self::QueryAll(self::QueryModel()->GetLast10());
|
return self::QueryAll(self::QueryModel()->GetLast10());
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -7,6 +7,6 @@ use Fufle\ORM\Query as BaseQuery;
|
||||||
|
|
||||||
class JobQuery extends BaseQuery implements IJobQuery {
|
class JobQuery extends BaseQuery implements IJobQuery {
|
||||||
public function GetLast10(): string {
|
public function GetLast10(): string {
|
||||||
return "select * from jobs order by id desc limit 10";
|
return "SELECT * from jobs order by id desc limit 10";
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,27 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
namespace Fufle\Database;
|
|
||||||
|
|
||||||
use PDO;
|
|
||||||
|
|
||||||
class ConnectionManager {
|
|
||||||
private static $connection;
|
|
||||||
|
|
||||||
public static function connect(string $connectionString) {
|
|
||||||
self::$connection = new PDO($connectionString);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function Query(string $query, array|object $params = [], string $output = 'stdObject') {
|
|
||||||
$stmt = self::$connection->prepare($query);
|
|
||||||
$stmt->execute($params);
|
|
||||||
$stmt->setFetchMode(PDO::FETCH_CLASS, $output);
|
|
||||||
return $stmt->fetch();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function QueryAll(string $query, array|object $params = [], string $output = 'stdObject') {
|
|
||||||
$stmt = self::$connection->prepare($query);
|
|
||||||
$stmt->execute($params);
|
|
||||||
$stmt->setFetchMode(PDO::FETCH_CLASS, $output);
|
|
||||||
return $stmt->fetchAll();
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,52 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Fufle\ORM\Database;
|
||||||
|
|
||||||
|
use PDO;
|
||||||
|
use Fufle\ORM\Database\QueryData;
|
||||||
|
use Fufle\ORM\Database\Connectors\IConnector;
|
||||||
|
|
||||||
|
class ConnectionManager {
|
||||||
|
private static $connection;
|
||||||
|
private static $connectors = [];
|
||||||
|
private static string $connectionString;
|
||||||
|
private static Credentials $credentials;
|
||||||
|
|
||||||
|
public static function RegisterConnector(IConnector $connector) {
|
||||||
|
self::$connectors[] = $connector;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function Connect(string $driver, $host, $port = null, $database = null, $user = null, $password = null) {
|
||||||
|
foreach (self::$connectors as $c) {
|
||||||
|
if ($c->driverEquals($driver)) {
|
||||||
|
$credentials = new Credentials($host, $port, $database, $user, $password);
|
||||||
|
self::$connectionString = $c->getConnectionString($credentials);
|
||||||
|
self::ConnectWithString(self::$connectionString);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw new Exception('Driver not found');
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function ConnectWithString(string $connectionString) {
|
||||||
|
self::$connection = new PDO($connectionString);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function Query(string $query, array|object $params = [], string $output = 'stdObject') {
|
||||||
|
$data = new QueryData($query, $params);
|
||||||
|
$data->normalize();
|
||||||
|
$stmt = self::$connection->prepare($data->query);
|
||||||
|
$stmt->execute($data->params);
|
||||||
|
$stmt->setFetchMode(PDO::FETCH_CLASS, $output);
|
||||||
|
return $stmt->fetch();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function QueryAll(string $query, array|object $params = [], string $output = 'stdObject') {
|
||||||
|
$data = new QueryData($query, $params);
|
||||||
|
$data->normalize();
|
||||||
|
$stmt = self::$connection->prepare($data->query);
|
||||||
|
$stmt->execute($data->params);
|
||||||
|
$stmt->setFetchMode(PDO::FETCH_CLASS, $output);
|
||||||
|
return $stmt->fetchAll();
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,11 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Fufle\ORM\Database\Connectors;
|
||||||
|
|
||||||
|
use Fufle\ORM\Database\Credentials;
|
||||||
|
|
||||||
|
interface IConnector {
|
||||||
|
public function getConnectionString(Credentials $credentials);
|
||||||
|
public function driverEquals(string $driver);
|
||||||
|
public static function Connect(string $host, int $port, string $database, string $user, string $password);
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Fufle\ORM\Database\Connectors;
|
||||||
|
|
||||||
|
use Fufle\ORM\Database\Credentials;
|
||||||
|
use Fufle\ORM\Database\ConnectionManager;
|
||||||
|
|
||||||
|
class PostgresConnector implements IConnector {
|
||||||
|
public function getConnectionString(Credentials $c) {
|
||||||
|
return "pgsql:host={$c->host};port={$c->port};dbname={$c->database};user={$c->user};password={$c->password}";
|
||||||
|
}
|
||||||
|
public function driverEquals(string $driver) {
|
||||||
|
return $driver === 'pgsql';
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function Connect(string $host, int $port, string $database, string $user, string $password) {
|
||||||
|
ConnectionManager::RegisterConnector(new PostgresConnector());
|
||||||
|
ConnectionManager::Connect('pgsql', $host, $port, $database, $user, $password);
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,15 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Fufle\ORM\Database;
|
||||||
|
|
||||||
|
class Credentials {
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
public string $host,
|
||||||
|
public ?int $port = null,
|
||||||
|
public ?string $database = null,
|
||||||
|
public ?string $user = null,
|
||||||
|
public ?string $password = null) {
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,29 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Fufle\ORM\Database;
|
||||||
|
|
||||||
|
class QueryData {
|
||||||
|
public function __construct(
|
||||||
|
public string $query,
|
||||||
|
public array|object $params
|
||||||
|
) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function normalize() {
|
||||||
|
$params = (array)$this->params;
|
||||||
|
$replaces = [];
|
||||||
|
foreach($params as $name => $param) {
|
||||||
|
if (is_array($param)) {
|
||||||
|
$replaces2 = [];
|
||||||
|
foreach($param as $i => $p) {
|
||||||
|
$params[$name.$i.'x'] = $p;
|
||||||
|
$replaces[] = ':'.$name.$i.'x';
|
||||||
|
}
|
||||||
|
unset($params[$name]);
|
||||||
|
$this->query = str_replace(':'.$name, implode(', ', $replaces), $this->query);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$this->params = $params;
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,16 +2,29 @@
|
||||||
|
|
||||||
namespace Fufle\ORM;
|
namespace Fufle\ORM;
|
||||||
|
|
||||||
use Fufle\Database\ConnectionManager;
|
use Fufle\ORM\Database\ConnectionManager;
|
||||||
|
|
||||||
abstract class Model {
|
abstract class Model {
|
||||||
protected static string $primaryKey = 'id';
|
protected static string $primaryKey = 'id';
|
||||||
protected static ?string $table = null;
|
protected static ?string $table = null;
|
||||||
private static ?IQuery $query = null;
|
private static ?IQuery $query = null;
|
||||||
|
|
||||||
|
protected static array $fields = [];
|
||||||
|
|
||||||
|
public function toArray(): array {
|
||||||
|
$array = [];
|
||||||
|
$fields = static::$fields;
|
||||||
|
foreach($fields as $field) {
|
||||||
|
if ($this->{$field} ?? null !== null) {
|
||||||
|
$array[$field] = $this->{$field};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $array;
|
||||||
|
}
|
||||||
|
|
||||||
protected static function QueryModel() {
|
protected static function QueryModel() {
|
||||||
if (self::$query === null && self::class !== static::class) {
|
if (self::$query === null && self::class !== static::class) {
|
||||||
self::$query = static::QueryModel();
|
self::$query = static::SetQueryModel();
|
||||||
}
|
}
|
||||||
return self::$query;
|
return self::$query;
|
||||||
}
|
}
|
||||||
|
@ -46,4 +59,6 @@ abstract class Model {
|
||||||
$params,
|
$params,
|
||||||
get_called_class());
|
get_called_class());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
abstract public static function SetQueryModel(): IQuery;
|
||||||
}
|
}
|
|
@ -1,7 +1,7 @@
|
||||||
<?php
|
<?php
|
||||||
namespace Fufle\ORM;
|
namespace Fufle\ORM;
|
||||||
|
|
||||||
class Query {
|
class Query implements IQuery {
|
||||||
protected string $table;
|
protected string $table;
|
||||||
protected string $primaryKey;
|
protected string $primaryKey;
|
||||||
|
|
||||||
|
|
|
@ -2,10 +2,21 @@
|
||||||
require_once __DIR__ . '/../vendor/autoload.php';
|
require_once __DIR__ . '/../vendor/autoload.php';
|
||||||
|
|
||||||
use Fufle\Demo\Model\Job;
|
use Fufle\Demo\Model\Job;
|
||||||
use Fufle\Database\ConnectionManager;
|
//use Fufle\ORM\Database\ConnectionManager;
|
||||||
|
use Fufle\ORM\Database\Connectors\PostgresConnector;
|
||||||
|
|
||||||
$dns = 'pgsql:host=localhost;port=5432;dbname=dynamic;user=dynamic;password=password123';
|
//$dns = 'pgsql:host=localhost;port=5432;dbname=dynamic;user=dynamic;password=password123';
|
||||||
ConnectionManager::Connect($dns);
|
$params = [
|
||||||
|
// 'pgsql',
|
||||||
|
'localhost',
|
||||||
|
5432,
|
||||||
|
'dynamic_dev',
|
||||||
|
'dynamic',
|
||||||
|
'Pass@Dyna21',
|
||||||
|
];
|
||||||
|
PostgresConnector::Connect(...$params);
|
||||||
|
//ConnectionManager::RegisterConnector(new PostgresConnector());
|
||||||
|
//ConnectionManager::Connect(...$params);
|
||||||
echo "
|
echo "
|
||||||
|
|
||||||
";
|
";
|
||||||
|
|
Loading…
Reference in New Issue