承接 vasek-purchart/doctrine-date-time-immutable-types-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

vasek-purchart/doctrine-date-time-immutable-types-bundle

最新稳定版本:2.0

Composer 安装命令:

composer require vasek-purchart/doctrine-date-time-immutable-types-bundle

包简介

Bundle integration of Doctrine DateTimeImmutable types for Symfony

README 文档

README

In Doctrine DBAL 2.6 immutable DateTime types were added, so this bundle no longer uses custom DateTime types implementation, but rather offers control, how the immutable types are registered, offering the possibility to replace the original DateTime types.

If you cannot upgrade to Doctrine DBAL 2.6 use 1.0 version of this bundle, which uses the vasek-purchart/doctrine-date-time-immutable-types custom DateTime types implementation.

Why would I want to use immutable types?

All Doctrine date/time based types are using DateTime instances, which are mutable. This can lead to breaking encapsulation and therefore bugs. For two reasons:

  1. You accidentally modify a date when you are doing some computation on it:
<?php

use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity()
 */
class LogRow
{

	// ...

	/**
	 * @ORM/Column(type="datetime")
	 * @var \DateTime
	 */
	private $createdDate;

	public function getCreatedDate(): DateTime
	{
		return $this->createdDate;
	}

}
<?php

// created date might be modified
// even if this was not intended by the creator
// (there is no "setter" method for this on the entity)
var_dump($logRow->getCreatedDate()); // 2015-01-01 00:00:00
$logRow->getCreatedDate()->modify('+14 days');
var_dump($logRow->getCreatedDate()); // 2015-01-15 00:00:00
  1. Or you do intentionally try to update it, which fails because Doctrine will not see this:
<?php

$product->getRenewDate()->modify('+1 year');
$entityManager->persist($product);
// no updates will be fired because Doctrine could not detect change
// (objects are compared by identity)
$entityManager->flush();

You can prevent this behaviour by returning a new instance (cloning) or using DateTimeImmutable (which returns a new instance when modified).

Configuration

Configuration structure with listed default values:

# app/config/config.yml
doctrine_date_time_immutable_types:
    # Choose under which names the types will be registered.
    register: add # One of "add"; "replace"

register

  • add - add types as new - suffixed with _immutable (e.g. datetime_immutable) - this is already done by DBAL from version 2.6
  • replace - replace the original types date, time, datetime, datetimetz, i.e. making them immutable

Usage

If you are using the replace option, you don't need to change any property mappings of your entities.

If you are using the add option (default), you only have to suffix your field types with _immutable:

<?php

use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity()
 */
class LogRow
{

	// ...

	/**
	 * @ORM/Column(type="datetime_immutable")
	 * @var \DateTimeImmutable
	 */
	private $createdDate;

	public function getCreatedDate(): DateTimeImmutable
	{
		return $this->createdDate;
	}

}
<?php

// created date can no longer be modified from outside
var_dump($logRow->getCreatedDate()); // 2015-01-01 00:00:00
$logRow->getCreatedDate()->modify('+14 days');
var_dump($logRow->getCreatedDate()); // 2015-01-01 00:00:00

Installation

Install package vasek-purchart/doctrine-date-time-immutable-types-bundle with Composer:

composer require vasek-purchart/doctrine-date-time-immutable-types-bundle

Register the bundle in your application kernel:

// app/AppKernel.php
public function registerBundles()
{
	return array(
		// ...
		new VasekPurchart\DoctrineDateTimeImmutableTypesBundle\DoctrineDateTimeImmutableTypesBundle(),
	);
}

统计信息

  • 总下载量: 85.53k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 10
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 10
  • Watchers: 1
  • Forks: 3
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-06-17