diff --git a/core/modules/user/src/Entity/User.php b/core/modules/user/src/Entity/User.php index ec8ac32..aedee55 100644 --- a/core/modules/user/src/Entity/User.php +++ b/core/modules/user/src/Entity/User.php @@ -439,6 +439,13 @@ public function setUsername($username) { /** * {@inheritdoc} */ + public function getChangedTime() { + return $this->get('changed')->value; + } + + /** + * {@inheritdoc} + */ public static function baseFieldDefinitions(EntityTypeInterface $entity_type) { $fields['uid'] = FieldDefinition::create('integer') ->setLabel(t('User ID')) @@ -508,6 +515,10 @@ public static function baseFieldDefinitions(EntityTypeInterface $entity_type) { ->setLabel(t('Created')) ->setDescription(t('The time that the user was created.')); + $fields['changed'] = FieldDefinition::create('changed') + ->setLabel(t('Changed')) + ->setDescription(t('The time that the user was last edited.')); + $fields['access'] = FieldDefinition::create('timestamp') ->setLabel(t('Last access')) ->setDescription(t('The time that the user last accessed the site.')) diff --git a/core/modules/user/src/UserInterface.php b/core/modules/user/src/UserInterface.php index 8b89dd4..e2c44d0 100644 --- a/core/modules/user/src/UserInterface.php +++ b/core/modules/user/src/UserInterface.php @@ -7,6 +7,7 @@ namespace Drupal\user; +use Drupal\Core\Entity\EntityChangedInterface; use Drupal\Core\Entity\ContentEntityInterface; use Drupal\Core\Session\AccountInterface; @@ -15,7 +16,7 @@ * * @ingroup user_api */ -interface UserInterface extends ContentEntityInterface, AccountInterface { +interface UserInterface extends ContentEntityInterface, EntityChangedInterface, AccountInterface { /** * Whether a user has a certain role. diff --git a/core/modules/user/user.install b/core/modules/user/user.install index eca1692..4964e6d 100644 --- a/core/modules/user/user.install +++ b/core/modules/user/user.install @@ -46,6 +46,12 @@ function user_schema() { 'unsigned' => TRUE, 'default' => 0, ), + 'changed' => array( + 'description' => 'The Unix timestamp when the user was most recently saved.', + 'type' => 'int', + 'not null' => TRUE, + 'default' => 0, + ), ), 'primary key' => array('uid', 'module', 'name'), 'indexes' => array( diff --git a/core/modules/user/user.views.inc b/core/modules/user/user.views.inc index b2e2773..c10892e 100644 --- a/core/modules/user/user.views.inc +++ b/core/modules/user/user.views.inc @@ -267,6 +267,74 @@ function user_views_data() { ), ); + $data['users']['changed'] = array( + 'title' => t('Updated date'), + 'help' => t('The date the user was last updated.'), + 'field' => array( + 'id' => 'date', + ), + 'sort' => array( + 'id' => 'date' + ), + 'filter' => array( + 'id' => 'date', + ), + ); + + $data['users']['changed_fulldate'] = array( + 'title' => t('Updated date'), + 'help' => t('Date in the form of CCYYMMDD.'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_fulldate', + ), + ); + + $data['users']['changed_year_month'] = array( + 'title' => t('Updated year + month'), + 'help' => t('Date in the form of YYYYMM.'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_year_month', + ), + ); + + $data['users']['changed_year'] = array( + 'title' => t('Updated year'), + 'help' => t('Date in the form of YYYY.'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_year', + ), + ); + + $data['users']['changed_month'] = array( + 'title' => t('Updated month'), + 'help' => t('Date in the form of MM (01 - 12).'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_month', + ), + ); + + $data['users']['changed_day'] = array( + 'title' => t('Updated day'), + 'help' => t('Date in the form of DD (01 - 31).'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_day', + ), + ); + + $data['users']['changed_week'] = array( + 'title' => t('Updated week'), + 'help' => t('Date in the form of WW (01 - 53).'), + 'argument' => array( + 'field' => 'changed', + 'id' => 'date_week', + ), + ); + if (\Drupal::moduleHandler()->moduleExists('filter')) { $data['users']['signature'] = array( 'title' => t('Signature'),