You are here

class Photos in Album Photos 8.5

Same name in this branch
  1. 8.5 src/Plugin/media/Source/Photos.php \Drupal\photos\Plugin\media\Source\Photos
  2. 8.5 src/Plugin/migrate/source/Photos.php \Drupal\photos\Plugin\migrate\source\Photos
  3. 8.5 src/Plugin/migrate/destination/Photos.php \Drupal\photos\Plugin\migrate\destination\Photos
Same name and namespace in other branches
  1. 8.4 src/Plugin/migrate/destination/Photos.php \Drupal\photos\Plugin\migrate\destination\Photos
  2. 6.0.x src/Plugin/migrate/destination/Photos.php \Drupal\photos\Plugin\migrate\destination\Photos

Photos migration destination.

Plugin annotation


@MigrateDestination(
  id = "d7_photos",
  destination_module = "photos"
)

Hierarchy

Expanded class hierarchy of Photos

10 string references to 'Photos'
d7_photos.yml in migrations/d7_photos.yml
migrations/d7_photos.yml
d7_photos_count.yml in migrations/d7_photos_count.yml
migrations/d7_photos_count.yml
d7_photos_image.yml in migrations/d7_photos_image.yml
migrations/d7_photos_image.yml
photos.info.yml in ./photos.info.yml
photos.info.yml
photos.links.menu.yml in ./photos.links.menu.yml
photos.links.menu.yml

... See full list

File

src/Plugin/migrate/destination/Photos.php, line 20

Namespace

Drupal\photos\Plugin\migrate\destination
View source
class Photos extends DestinationBase implements ContainerFactoryPluginInterface {

  /**
   * The database connection.
   *
   * @var \Drupal\Core\Database\Connection
   */
  protected $connection;

  /**
   * Constructs a PhotosImage object.
   *
   * @param array $configuration
   *   Plugin configuration.
   * @param string $plugin_id
   *   The plugin ID.
   * @param mixed $plugin_definition
   *   The plugin definition.
   * @param \Drupal\migrate\Plugin\MigrationInterface $migration
   *   The current migration.
   * @param \Drupal\Core\Database\Connection $connection
   *   The database connection.
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration, Connection $connection) {
    parent::__construct($configuration, $plugin_id, $plugin_definition, $migration);
    $this->connection = $connection;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition, MigrationInterface $migration = NULL) {
    return new static($configuration, $plugin_id, $plugin_definition, $migration, $container
      ->get('database'));
  }

  /**
   * {@inheritdoc}
   */
  public function import(Row $row, array $old_destination_id_values = []) {

    // Look up {photos_image}.id for cover_id.
    $photosImageIds = \Drupal::entityQuery('photos_image')
      ->condition('field_image.target_id', $row
      ->getDestinationProperty('fid'))
      ->execute();
    $cover_id = 0;
    if (!empty($photosImageIds)) {
      $cover_id = reset($photosImageIds);
    }
    $path = $this->connection
      ->update('photos_album')
      ->fields([
      'cover_id' => $cover_id,
      'weight' => $row
        ->getDestinationProperty('wid'),
      'count' => $row
        ->getDestinationProperty('count'),
      'data' => $row
        ->getDestinationProperty('data'),
    ])
      ->condition('album_id', $row
      ->getDestinationProperty('pid'))
      ->execute();
    return [
      $path['album_id'],
    ];
  }

  /**
   * {@inheritdoc}
   */
  public function getIds() {
    $ids['album_id']['type'] = 'integer';
    return $ids;
  }

  /**
   * {@inheritdoc}
   */
  public function fields(MigrationInterface $migration = NULL) {
    return [
      'album_id' => $this
        ->t('Photos Album node ID'),
      'cover_id' => $this
        ->t('Album cover file ID'),
      'weight' => $this
        ->t('Weight'),
      'count' => $this
        ->t('Image count'),
      'data' => $this
        ->t('Serialized array of album data'),
    ];
  }

}

Members

Namesort descending Modifiers Type Description Overrides
DependencySerializationTrait::$_entityStorages protected property An array of entity type IDs keyed by the property name of their storages.
DependencySerializationTrait::$_serviceIds protected property An array of service IDs keyed by property name used for serialization.
DependencySerializationTrait::__sleep public function 1
DependencySerializationTrait::__wakeup public function 2
DestinationBase::$migration protected property The migration.
DestinationBase::$rollbackAction protected property The rollback action to be saved for the last imported item.
DestinationBase::$supportsRollback protected property Indicates whether the destination can be rolled back.
DestinationBase::checkRequirements public function Checks if requirements for this plugin are OK. Overrides RequirementsInterface::checkRequirements
DestinationBase::getDestinationModule public function Gets the destination module handling the destination data. Overrides MigrateDestinationInterface::getDestinationModule 1
DestinationBase::rollback public function Delete the specified destination object from the target Drupal. Overrides MigrateDestinationInterface::rollback 2
DestinationBase::rollbackAction public function The rollback action for the last imported item. Overrides MigrateDestinationInterface::rollbackAction
DestinationBase::setRollbackAction protected function For a destination item being updated, set the appropriate rollback action.
DestinationBase::supportsRollback public function Whether the destination can be rolled back or not. Overrides MigrateDestinationInterface::supportsRollback
MessengerTrait::$messenger protected property The messenger. 29
MessengerTrait::messenger public function Gets the messenger. 29
MessengerTrait::setMessenger public function Sets the messenger.
Photos::$connection protected property The database connection.
Photos::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create
Photos::fields public function Returns an array of destination fields. Overrides MigrateDestinationInterface::fields
Photos::getIds public function Gets the destination IDs. Overrides MigrateDestinationInterface::getIds
Photos::import public function Import the row. Overrides MigrateDestinationInterface::import
Photos::__construct public function Constructs a PhotosImage object. Overrides DestinationBase::__construct
PluginBase::$configuration protected property Configuration information passed into the plugin. 1
PluginBase::$pluginDefinition protected property The plugin implementation definition. 1
PluginBase::$pluginId protected property The plugin_id.
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition 3
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.
StringTranslationTrait::$stringTranslation protected property The string translation service. 1
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.