[TASK] Update php-cs-fixer to 2.5.0
[Packages/TYPO3.CMS.git] / typo3 / sysext / backend / Classes / Form / FormDataProvider / DatabaseRowDateTimeFields.php
1 <?php
2 namespace TYPO3\CMS\Backend\Form\FormDataProvider;
3
4 /*
5 * This file is part of the TYPO3 CMS project.
6 *
7 * It is free software; you can redistribute it and/or modify it under
8 * the terms of the GNU General Public License, either version 2
9 * of the License, or any later version.
10 *
11 * For the full copyright and license information, please read the
12 * LICENSE.txt file that was distributed with this source code.
13 *
14 * The TYPO3 project - inspiring people to share!
15 */
16
17 use TYPO3\CMS\Backend\Form\FormDataProviderInterface;
18 use TYPO3\CMS\Core\Database\Query\QueryHelper;
19
20 /**
21 * Migrate date and datetime db field values to timestamp
22 */
23 class DatabaseRowDateTimeFields implements FormDataProviderInterface
24 {
25 /**
26 * Migrate date and datetime db field values to timestamp
27 *
28 * @param array $result
29 * @return array
30 */
31 public function addData(array $result)
32 {
33 $dateTimeFormats = QueryHelper::getDateTimeFormats();
34 foreach ($result['processedTca']['columns'] as $column => $columnConfig) {
35 if (isset($columnConfig['config']['dbType'])
36 && ($columnConfig['config']['dbType'] === 'date' || $columnConfig['config']['dbType'] === 'datetime')
37 ) {
38 if (!empty($result['databaseRow'][$column])
39 && $result['databaseRow'][$column] !== $dateTimeFormats[$columnConfig['config']['dbType']]['empty']
40 ) {
41 // Create an ISO-8601 date from current field data; the database always contains UTC
42 // The field value is something like "2016-01-01" or "2016-01-01 10:11:12", so appending "UTC"
43 // makes date() treat it as a UTC date (which is what we store in the database).
44 $result['databaseRow'][$column] = date('c', strtotime($result['databaseRow'][$column] . ' UTC'));
45 } else {
46 $result['databaseRow'][$column] = null;
47 }
48 }
49 // its a UNIX timestamp! We do not modify this here, as it will only be treated as a datetime because
50 // of eval being set to "date" or "datetime". This is handled in InputTextElement then.
51 }
52 return $result;
53 }
54 }