You are here

function social_profile_update_8006 in Open Social 8.3

Same name and namespace in other branches
  1. 8.9 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  2. 8 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  3. 8.2 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  4. 8.4 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  5. 8.5 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  6. 8.6 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  7. 8.7 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  8. 8.8 modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  9. 10.3.x modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  10. 10.0.x modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  11. 10.1.x modules/social_features/social_profile/social_profile.install \social_profile_update_8006()
  12. 10.2.x modules/social_features/social_profile/social_profile.install \social_profile_update_8006()

Create a profile for users that have none.

File

modules/social_features/social_profile/social_profile.install, line 254
Install, update and uninstall functions for the social_profile module.

Code

function social_profile_update_8006(&$sandbox) {
  if (!isset($sandbox['progress'])) {

    // This must be the first run. Initialize the sandbox.
    $sandbox['progress'] = 0;
    $sandbox['profiles_created'] = 0;

    // We use array_values to get the entity_ids.
    // Not interested in the revisions.
    $sandbox['uids'] = array_values(\Drupal::entityQuery('user')
      ->execute());
    $sandbox['user_count'] = count($sandbox['uids']);
    \Drupal::logger('social_profile')
      ->info('Checking profile status for @count users', [
      '@count' => $sandbox['user_count'],
    ]);
  }

  // Try to do 5 each cycle. Never do more than are available.
  for ($target = $sandbox['progress'] + 5; $sandbox['progress'] < $target && $sandbox['progress'] < $sandbox['user_count']; $sandbox['progress']++) {
    $uid = $sandbox['uids'][$sandbox['progress']];

    /** @var \Drupal\user\Entity\User $account */
    $account = User::load($uid);

    // For anonymous we do nothing.
    if ($account
      ->isAnonymous()) {
      continue;
    }

    // Check if the user has a profile already.
    $profile = \Drupal::entityTypeManager()
      ->getStorage('profile')
      ->loadByUser($account, ProfileType::load('profile')
      ->id(), TRUE);
    if (!$profile) {
      try {
        Profile::create([
          'type' => ProfileType::load('profile')
            ->id(),
          'uid' => $account
            ->id(),
        ])
          ->save();
        $sandbox['profiles_created']++;
      } catch (Exception $e) {
        \Drupal::logger('social_profile')
          ->error('Could not create profile for @user_id', [
          '@user_id' => $uid,
        ]);
      }
    }
  }
  $sandbox['#finished'] = empty($sandbox['user_count']) ? 1 : $sandbox['progress'] / $sandbox['user_count'];
  if ($sandbox['#finished'] === 1) {
    \Drupal::logger('social_profile')
      ->info('Created profiles for @count users', [
      '@count' => $sandbox['profiles'],
    ]);
  }
}