Files
DomFramework/tools/modelGenerator.php

173 lines
5.3 KiB
PHP
Executable File

#!/usr/bin/php
<?php
/** DomFramework
@package domframework
@author Dominique Fournier <dominique@fournier38.fr> */
require_once ("domframework/getopts.php");
require_once ("domframework/dblayeroo.php");
/** Generate the model files from an existing database
* Provide the DSN to connect to the database, and the program will generate
* the models/table.php files
*/
class modelGenerator
{
/** The DSN provided by the user
*/
private $dsn;
/** The modelsDir provided by the user
*/
private $modelsDir;
/** The namespace name provided by the user
*/
private $namespaceName;
/** The dblayer object
*/
private $db;
/** The constructor
*/
public function __construct ()
{
$getopts = new \getopts ();
$getopts->add ("Help", "?h", "help", "Help of the software");
$getopts->add ("DSN", "", "dsn:", "DSN - Data Source Name\n".
" Exemple : --dsn \"mysql:dbname=DBNAME\"",
"dsn");
$getopts->add ("Output", "o:", "output:",
"Output directory, ./models by default", "dir");
$getopts->add ("Namespace", "n:", "namespace:",
"The namespace (if '', not added), models by default",
"namespaceName");
$getopts->add ("Username", "u:", "username:", "Username to connect",
"username");
$getopts->add ("Password", "p:", "password:", "Password to connect",
"password");
if ($getopts->get ("Help"))
die ($getopts->help ());
if ($getopts->get ("DSN") === false)
{
file_put_contents ("php://stderr", "ERROR: The DSN is not provided\n");
exit (1);
}
$dsn = $getopts->get ("DSN");
$modelsDir = $getopts->get ("Output");
if ($modelsDir === false)
$modelsDir = "./models";
if (! file_exists ($modelsDir) || ! is_dir ($modelsDir))
{
file_put_contents ("php://stderr",
"ERROR: The modelsDir '$modelsDir' doesn't exists or is not a directory\n");
exit (1);
}
$this->dsn = $dsn;
$this->modelsDir = $modelsDir;
$this->namespaceName = $getopts->get ("Namespace");
try
{
$this->db = new \dblayeroo ($dsn,
$getopts->get ("Username"),
$getopts->get ("Password"));
}
catch (\Exception $e)
{
file_put_contents ("php://stderr", $e->getMessage ()."\n");
exit (3);
}
}
/** List all the existing tables in the database
*/
public function listTables ()
{
return $this->db->listTables ();
}
/** Create the model file from the $tableName
* @param string $tableName The table to examine
*/
public function createModel ($tableName)
{
if (file_exists ($this->modelsDir."/$tableName".".php"))
{
file_put_contents ("php://stderr",
"WARNING: File ".$this->modelsDir."/$tableName".".php already exists. ".
"SKIP\n");
return;
}
echo "Create File ".$this->modelsDir."/$tableName".".php\n";
$schema = $this->db->getTableSchema ($tableName);
$f = "";
$f .= "<"."?"."php\n\n";
if ($this->namespaceName === false)
$f .= "namespace models;\n\n";
elseif ($this->namespaceName !== "")
$f .= "namespace $this->namespaceName;\n\n";
$f .= "require_once (\"domframework/dblayeroo.php\");\n\n";
$f .= "/** The model for $tableName table in the database\n */\n";
$f .= "class $tableName extends \dbalyeroo\n";
$f .= "{\n";
$f .= " /** The constructor connect to database\n */\n";
$f .= " public function __construct ()\n {\n";
$f .= " // The table name\n";
$f .= " \$this->table (\"$tableName\");\n\n";
$f .= " // The fields name and parameters\n";
$f .= " \$this->fields (array (\n";
foreach ($schema["fields"] as $field=>$params)
{
$f .= " \"$field\" => array (\"".implode ("\", \"", $params).
"\"),\n";
}
$f .= " ));\n\n";
$f .= " // The primary key\n";
$f .= " \$this->primary (\"".$schema["primary"]."\");\n";
if (count ($schema["unique"]))
{
$f .= "\n";
$f .= " // The unique constraints\n";
$f .= " \$this->unique (array (\n";
foreach ($schema["unique"] as $unique)
{
if (is_array ($unique))
$f .= " array (\"".implode ("\", \"", $unique)."\"),\n";
else
$f .= " array (\"$unique\"),\n";
}
$f .= " ));\n";
}
$f .= "\n";
$f .= " // The titles\n";
$f .= " \$this->titles = array (\n";
foreach ($schema["fields"] as $field=>$params)
{
$f .= " \"$field\" => _(\"$field\"),\n";
}
$f .= " );\n";
if (count ($schema["foreign"]))
{
$f .= "\n";
$f .= " // The foreign constraints\n";
$f .= " \$this->foreign = array (\n";
foreach ($schema["foreign"] as $field=>$params)
$f .= " \"$field\" => array (\n \"".
implode ("\", \"", $params).
"\"),\n";
$f .= " );\n";
}
$f .= " }\n";
$f .= "}\n";
file_put_contents ($this->modelsDir."/$tableName".".php", $f);
}
}
$modelGenerator = new modelGenerator ();
$tables = $modelGenerator->listTables ();
foreach ($tables as $tableName)
$modelGenerator->createModel ($tableName);