TYPO3 CMS  TYPO3_8-7
DatabaseRowDateTimeFields.php
Go to the documentation of this file.
1 <?php
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 
19 
24 {
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 }