[SCHEMADEF] Add preliminary support for foreign keys

This commit is contained in:
Hugo Sales 2021-02-21 17:13:46 +00:00
parent f486656756
commit b337d6b2eb

View File

@ -31,7 +31,6 @@
namespace App\DependencyInjection\Compiler; namespace App\DependencyInjection\Compiler;
use App\Core\Log;
use Doctrine\Persistence\Mapping\ClassMetadata; use Doctrine\Persistence\Mapping\ClassMetadata;
use Doctrine\Persistence\Mapping\Driver\StaticPHPDriver; use Doctrine\Persistence\Mapping\Driver\StaticPHPDriver;
use Functional as F; use Functional as F;
@ -94,8 +93,6 @@ class SchemaDefDriver extends StaticPHPDriver implements CompilerPassInterface
{ {
$schema = $class_name::schemaDef(); $schema = $class_name::schemaDef();
Log::emergency($class_name);
$metadata->setPrimaryTable([ $metadata->setPrimaryTable([
'name' => $schema['name'], 'name' => $schema['name'],
'indexes' => self::kv_to_name_col($schema['indexes'] ?? []), 'indexes' => self::kv_to_name_col($schema['indexes'] ?? []),
@ -104,16 +101,31 @@ class SchemaDefDriver extends StaticPHPDriver implements CompilerPassInterface
]); ]);
foreach ($schema['fields'] as $name => $opts) { foreach ($schema['fields'] as $name => $opts) {
// TODO if ($opts['type'] === 'foreign key') {
// See Doctrine\ORM\Mapping::associationMappings
// TODO still need to map nullability, comment, fk name and such, but
// the interface doesn't seem to support it currently
list($target_entity, $target_field) = explode('.', $opts['target']);
switch ($opts['multiplicity']) {
case 'one to one':
$metadata->mapOneToOne([
'fieldName' => $name,
'targetEntity' => $target_entity,
'joinColumns' => [[
'name' => $name,
'referencedColumnName' => $target_field,
]],
]);
break;
default:
dd('Not yet implemented');
}
} else {
// Convert old to new types // Convert old to new types
$type = $name === 'date'
// Old date fields were stored as int, store as datetime/timestamp
? 'datetime'
// For ints, prepend the size (smallint) // For ints, prepend the size (smallint)
// The size field doesn't exist otherwise // The size field doesn't exist otherwise
: $type = self::types[($opts['size'] ?? '') . $opts['type']];
self::types[($opts['size'] ?? '') . $opts['type']];
$unique = null; $unique = null;
foreach ($schema['unique keys'] ?? [] as $key => $uniq_arr) { foreach ($schema['unique keys'] ?? [] as $key => $uniq_arr) {
if (in_array($name, $uniq_arr)) { if (in_array($name, $uniq_arr)) {
@ -131,7 +143,7 @@ class SchemaDefDriver extends StaticPHPDriver implements CompilerPassInterface
'fieldName' => $name, 'fieldName' => $name,
// string // string
'type' => $type, 'type' => $type,
// stringn, optional // string, optional
'unique' => $unique, 'unique' => $unique,
// String length, ignored if not a string // String length, ignored if not a string
// int, optional // int, optional
@ -163,7 +175,7 @@ class SchemaDefDriver extends StaticPHPDriver implements CompilerPassInterface
$metadata->setIdGeneratorType($metadata::GENERATOR_TYPE_AUTO); $metadata->setIdGeneratorType($metadata::GENERATOR_TYPE_AUTO);
} }
} }
// TODO foreign keys }
} }
/** /**