本文整理匯總了PHP中Doctrine\Common\Persistence\ObjectManager::getMetadataFactory方法的典型用法代碼示例。如果您正苦於以下問題:PHP ObjectManager::getMetadataFactory方法的具體用法?PHP ObjectManager::getMetadataFactory怎麽用?PHP ObjectManager::getMetadataFactory使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Doctrine\Common\Persistence\ObjectManager
的用法示例。
在下文中一共展示了ObjectManager::getMetadataFactory方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: __construct
/**
* Initializes context.
*
* @param ManagerRegistry $doctrine
*/
public function __construct(ManagerRegistry $doctrine)
{
$this->manager = $doctrine->getManager();
$this->schemaTool = new SchemaTool($this->manager);
$this->classes = $this->manager->getMetadataFactory()->getAllMetadata();
$this->inspector = new JsonInspector('javascript');
}
示例2: __construct
/**
* Initializes context.
*
* Every scenario gets its own context instance.
* You can also pass arbitrary arguments to the
* context constructor through behat.yml.
*/
public function __construct(ManagerRegistry $doctrine)
{
$this->doctrine = $doctrine;
$this->manager = $doctrine->getManager();
$this->schemaTool = new SchemaTool($this->manager);
$this->classes = $this->manager->getMetadataFactory()->getAllMetadata();
}
示例3: createSchema
/**
* Create the database schema.
*
* @param ObjectManager $om
*/
protected function createSchema(ObjectManager $om)
{
if ($om instanceof \Doctrine\ORM\EntityManager) {
$schemaTool = new \Doctrine\ORM\Tools\SchemaTool($om);
$schemaTool->createSchema($om->getMetadataFactory()->getAllMetadata());
} elseif ($om instanceof \Doctrine\ODM\MongoDB\DocumentManager) {
$sm = new \Doctrine\ODM\MongoDB\SchemaManager($om, $om->getMetadataFactory());
$sm->createCollections();
}
}
示例4: __construct
/**
* Initializes context.
*
* Every scenario gets its own context instance.
* You can also pass arbitrary arguments to the
* context constructor through behat.yml.
*
* @param ManagerRegistry $doctrine
* @param JWTManagerInterface $jwtManager
* @param UserManager $userManager
* @param EncoderFactoryInterface $encoderFactory
*/
public function __construct(ManagerRegistry $doctrine, JWTManagerInterface $jwtManager, UserManager $userManager, EncoderFactoryInterface $encoderFactory)
{
$this->doctrine = $doctrine;
$this->manager = $doctrine->getManager();
$this->schemaTool = new SchemaTool($this->manager);
$this->metadata = $this->manager->getMetadataFactory()->getAllMetadata();
$this->jwtManager = $jwtManager;
$this->userManager = $userManager;
$this->encoderFactory = $encoderFactory;
$this->inspector = new JsonInspector('javascript');
}
示例5: setUp
/**
* {@inheritdoc}
*/
public function setUp()
{
static::$kernel = static::createKernel();
static::$kernel->boot();
$this->doctrine = static::$kernel->getContainer()->get('doctrine');
$this->doctrineManager = $this->doctrine->getManager();
$this->validator = static::$kernel->getContainer()->get('validator');
// Recreate a fresh database instance before each test case
$metadata = $this->doctrineManager->getMetadataFactory()->getAllMetadata();
$schemaTool = new SchemaTool($this->doctrineManager);
$schemaTool->dropSchema($metadata);
$schemaTool->createSchema($metadata);
}
示例6: setUp
protected function setUp()
{
if (!class_exists('Twig_Environment')) {
$this->markTestSkipped('Twig is not available.');
}
if (null === $this->em) {
$this->em = $this->client->getContainer()->get('doctrine')->getManager();
if (!static::$schemaSetUp) {
$st = new SchemaTool($this->em);
$classes = $this->em->getMetadataFactory()->getAllMetadata();
$st->dropSchema($classes);
$st->createSchema($classes);
static::$schemaSetUp = true;
}
}
parent::setUp();
}
示例7: load
public function load(ObjectManager $manager, $tags = null)
{
if (!$this->hasTag($tags)) {
return;
}
$cmf = $manager->getMetadataFactory();
// The model class for all fixtures defined in this file
$class = $this->file['model'];
// Get the fields that are not "associations"
$metadata = $cmf->getMetaDataFor($class);
$mapping = array_keys($metadata->fieldMappings);
$associations = array_keys($metadata->associationMappings);
foreach ($this->file['fixtures'] as $reference => $fixture) {
// Instantiate new object
$object = new $class();
foreach ($fixture as $field => $value) {
// Add the fields defined in the fistures file
$method = Inflector::camelize('set_' . $field);
//
if (strpos($value, '$') === 0) {
// custom reference loader format: $<referencedEntityKey>|<referencedColumn>
// ex: $first_campaign|idcampaign
list($referencedEntity, $referenceColumn) = explode('|', ltrim($value, '$'));
$getterMethod = Inflector::camelize('get_' . $referenceColumn);
$object->{$method}($this->loader->getReference($referencedEntity)->{$getterMethod}());
} elseif (in_array($field, $mapping)) {
// Dates need to be converted to DateTime objects
$type = $metadata->fieldMappings[$field]['type'];
if ($type == 'datetime' or $type == 'date') {
$value = new \DateTime($value);
}
$object->{$method}($value);
} else {
if (in_array($field, $associations)) {
// This field is an association, we load it from the references
$object->{$method}($this->loader->getReference($value));
} else {
// It's a method call that will set a field named differently
// eg: FOSUserBundle ->setPlainPassword sets the password after
// Encrypting it
$object->{$method}($value);
}
}
}
// Save a reference to the current object
$this->loader->setReference($reference, $object);
if (!$this->isReverseSaveOrder()) {
$manager->persist($object);
}
}
if ($this->isReverseSaveOrder()) {
$refs = array_keys($this->file['fixtures']);
for ($i = count($refs) - 1; $i >= 0; $i--) {
$manager->persist($this->loader->getReference($refs[$i]));
}
}
$manager->flush();
}
示例8: getAllEntities
/**
* Get all entities
*
* @access public
*
* @return array entities
*/
public function getAllEntities()
{
$entities = array();
$allMetadata = $this->entityManager->getMetadataFactory()->getAllMetadata();
foreach ($allMetadata as $entityMetadata) {
$entities[] = $entityMetadata->getName();
}
return $entities;
}
示例9: createData
private function createData(ObjectManager $manager)
{
$data = array('entities' => array(), 'relations' => array());
$passes = array(new ImportMetadataPass(), new InheritancePass(), new ShortNamePass());
foreach ($passes as $pass) {
$data = $pass->process($manager->getMetadataFactory(), $data);
}
return $data;
}
示例10: isEntitySupported
/**
* Checks whether provided entity is supported by the Metadatable Controller.
*
* @param mixed $entity
*
* @return bool
*/
protected function isEntitySupported($entity)
{
try {
$classMetadata = $this->om->getMetadataFactory()->getMetadataFor(get_class($entity));
} catch (\Exception $e) {
return false;
}
$reflClass = $classMetadata->reflClass;
$traitNames = [];
while ($reflClass) {
$traitNames = array_merge($traitNames, $reflClass->getTraitNames());
$reflClass = $reflClass->getParentClass();
}
$supported = in_array('Unifik\\DoctrineBehaviorsBundle\\Model\\Metadatable\\Metadatable', $traitNames);
if (!$supported && is_callable([$entity, 'getTranslation'])) {
return $this->isEntitySupported($entity->getTranslation());
}
return $supported;
}
示例11: isCorrectClassName
/**
* @param string $entityName
*
* @return bool
*/
protected function isCorrectClassName($entityName)
{
try {
$classMetadata = $this->em->getMetadataFactory()->getMetadataFor($entityName);
$classMetadata->getName();
} catch (\Exception $e) {
return false;
}
return true;
}
示例12: __construct
/**
* Initializes extension driver.
*
* @param \Doctrine\Common\Persistence\ObjectManager $objectManager
* @param string $extensionNamespace
* @param object $annotationReader
*/
public function __construct(ObjectManager $objectManager, $extensionNamespace, $annotationReader)
{
$this->objectManager = $objectManager;
$this->annotationReader = $annotationReader;
$this->extensionNamespace = $extensionNamespace;
$omDriver = $objectManager->getConfiguration()->getMetadataDriverImpl();
$omCache = $this->objectManager->getMetadataFactory()->getCacheDriver();
$metadataClassName = null;
if (class_exists($this->extensionNamespace . '\\Mapping\\ClassMetadata')) {
$metadataClassName = $this->extensionNamespace . '\\Mapping\\ClassMetadata';
}
$driver = $this->getDriver($omDriver);
$driver->setBaseMetadataFactory($objectManager->getMetadataFactory());
parent::__construct($driver, $omCache, $extensionNamespace, $metadataClassName);
}
示例13: compile
/**
* Called from functional tests, creates/updates database tables and compiles proxies.
*
* @return boolean
*/
public function compile()
{
// "driver" is used only for Doctrine, thus we (mis-)use it here
// additionally, when no path is set, skip this step, assuming no DB is needed
if ($this->settings['backendOptions']['driver'] !== null && $this->settings['backendOptions']['path'] !== null) {
$schemaTool = new SchemaTool($this->entityManager);
if ($this->settings['backendOptions']['driver'] === 'pdo_sqlite') {
$schemaTool->createSchema($this->entityManager->getMetadataFactory()->getAllMetadata());
} else {
$schemaTool->updateSchema($this->entityManager->getMetadataFactory()->getAllMetadata());
}
$proxyFactory = $this->entityManager->getProxyFactory();
$proxyFactory->generateProxyClasses($this->entityManager->getMetadataFactory()->getAllMetadata());
$this->systemLogger->log('Doctrine 2 setup finished');
return true;
} else {
$this->systemLogger->log('Doctrine 2 setup skipped, driver and path backend options not set!', LOG_NOTICE);
return false;
}
}
示例14: generateMigration
/**
* Generates a new migration file and returns the path to it.
*
* If $diffAgainstCurrent is TRUE, it generates a migration file with the
* diff between current DB structure and the found mapping metadata.
*
* Only include tables/sequences matching the $filterExpression regexp when
* diffing models and existing schema.
*
* Otherwise an empty migration skeleton is generated.
*
* @param boolean $diffAgainstCurrent
* @param string $filterExpression
* @return string Path to the new file
*/
public function generateMigration($diffAgainstCurrent = true, $filterExpression = null)
{
$configuration = $this->getMigrationConfiguration();
$up = null;
$down = null;
if ($diffAgainstCurrent === true) {
/** @var \Doctrine\DBAL\Connection $connection */
$connection = $this->entityManager->getConnection();
if ($filterExpression) {
$connection->getConfiguration()->setFilterSchemaAssetsExpression($filterExpression);
}
$metadata = $this->entityManager->getMetadataFactory()->getAllMetadata();
if (empty($metadata)) {
return ['No mapping information to process.', null];
}
$tool = new SchemaTool($this->entityManager);
$fromSchema = $connection->getSchemaManager()->createSchema();
$toSchema = $tool->getSchemaFromMetadata($metadata);
if ($filterExpression) {
foreach ($toSchema->getTables() as $table) {
$tableName = $table->getName();
if (!preg_match($filterExpression, $this->resolveTableName($tableName))) {
$toSchema->dropTable($tableName);
}
}
foreach ($toSchema->getSequences() as $sequence) {
$sequenceName = $sequence->getName();
if (!preg_match($filterExpression, $this->resolveTableName($sequenceName))) {
$toSchema->dropSequence($sequenceName);
}
}
}
$platform = $connection->getDatabasePlatform();
$up = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateToSql($toSchema, $platform));
$down = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateFromSql($toSchema, $platform));
if (!$up && !$down) {
return ['No changes detected in your mapping information.', null];
}
}
return ['Generated new migration class!', $this->writeMigrationClassToFile($configuration, $up, $down)];
}
示例15: generateMigration
/**
* Generates a new migration file and returns the path to it.
*
* If $diffAgainstCurrent is TRUE, it generates a migration file with the
* diff between current DB structure and the found mapping metadata.
*
* Otherwise an empty migration skeleton is generated.
*
* @param boolean $diffAgainstCurrent
* @return string Path to the new file
*/
public function generateMigration($diffAgainstCurrent = true)
{
$configuration = $this->getMigrationConfiguration();
$up = null;
$down = null;
if ($diffAgainstCurrent === true) {
$connection = $this->entityManager->getConnection();
$platform = $connection->getDatabasePlatform();
$metadata = $this->entityManager->getMetadataFactory()->getAllMetadata();
if (empty($metadata)) {
return 'No mapping information to process.';
}
$tool = new \Doctrine\ORM\Tools\SchemaTool($this->entityManager);
$fromSchema = $connection->getSchemaManager()->createSchema();
$toSchema = $tool->getSchemaFromMetadata($metadata);
$up = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateToSql($toSchema, $platform));
$down = $this->buildCodeFromSql($configuration, $fromSchema->getMigrateFromSql($toSchema, $platform));
if (!$up && !$down) {
return 'No changes detected in your mapping information.';
}
}
return $this->writeMigrationClassToFile($configuration, $up, $down);
}