class Json in Migrate Plus 8
Same name and namespace in other branches
- 8.5 src/Plugin/migrate_plus/data_parser/Json.php \Drupal\migrate_plus\Plugin\migrate_plus\data_parser\Json
- 8.2 src/Plugin/migrate_plus/data_parser/Json.php \Drupal\migrate_plus\Plugin\migrate_plus\data_parser\Json
- 8.3 src/Plugin/migrate_plus/data_parser/Json.php \Drupal\migrate_plus\Plugin\migrate_plus\data_parser\Json
- 8.4 src/Plugin/migrate_plus/data_parser/Json.php \Drupal\migrate_plus\Plugin\migrate_plus\data_parser\Json
Obtain JSON data for migration.
Plugin annotation
@DataParser(
  id = "json",
  title = @Translation("JSON")
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait- class \Drupal\migrate_plus\DataParserPluginBase implements DataParserPluginInterface- class \Drupal\migrate_plus\Plugin\migrate_plus\data_parser\Json implements ContainerFactoryPluginInterface
 
 
- class \Drupal\migrate_plus\DataParserPluginBase implements DataParserPluginInterface
 
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of Json
File
- src/Plugin/ migrate_plus/ data_parser/ Json.php, line 83 
- Contains Drupal\migrate_plus\Plugin\migrate_plus\data_parser\JSON.
Namespace
Drupal\migrate_plus\Plugin\migrate_plus\data_parserView source
class Json extends DataParserPluginBase implements ContainerFactoryPluginInterface {
  /**
   * The request headers passed to the data fetcher.
   *
   * @var array
   */
  protected $headers = [];
  /**
   * Iterator over the JSON data.
   *
   * @var \Iterator
   */
  protected $iterator;
  /**
   * {@inheritdoc}
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition) {
    parent::__construct($configuration, $plugin_id, $plugin_definition);
  }
  /**
   * {@inheritdoc}
   */
  protected function getSourceData($url) {
    $iterator = $this
      ->getSourceIterator($url);
    // Recurse through the result array. When there is an array of items at the
    // expected depth, pull that array out as a distinct item.
    $identifierDepth = $this->itemSelector;
    $items = [];
    while ($iterator
      ->valid()) {
      $iterator
        ->next();
      $item = $iterator
        ->current();
      if (is_array($item) && $iterator
        ->getDepth() == $identifierDepth) {
        $items[] = $item;
      }
    }
    return $items;
  }
  /**
   * Get the source data for reading.
   *
   * @param string $url
   *   The URL to read the source data from.
   *
   * @return \RecursiveIteratorIterator|resource
   *
   * @throws \Drupal\migrate\MigrateException
   */
  protected function getSourceIterator($url) {
    try {
      $response = $this
        ->getDataFetcherPlugin()
        ->getResponseContent($url);
      // The TRUE setting means decode the response into an associative array.
      $array = json_decode($response, TRUE);
      // Return the results in a recursive iterator that
      // can traverse multidimensional arrays.
      return new \RecursiveIteratorIterator(new \RecursiveArrayIterator($array), \RecursiveIteratorIterator::SELF_FIRST);
    } catch (RequestException $e) {
      throw new MigrateException($e
        ->getMessage(), $e
        ->getCode(), $e);
    }
  }
  /**
   * {@inheritdoc}
   */
  protected function openSourceUrl($url) {
    // (Re)open the provided URL.
    $source_data = $this
      ->getSourceData($url);
    $this->iterator = new \ArrayIterator($source_data);
    return TRUE;
  }
  /**
   * {@inheritdoc}
   */
  protected function fetchNextRow() {
    $current = $this->iterator
      ->current();
    if ($current) {
      foreach ($this
        ->fieldSelectors() as $field_name => $selector) {
        $this->currentItem[$field_name] = $current[$selector];
      }
      $this->iterator
        ->next();
    }
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| DataParserPluginBase:: | protected | property | Index of the currently-open url. | |
| DataParserPluginBase:: | protected | property | Value of the ID for the current item when iterating. | |
| DataParserPluginBase:: | protected | property | Current item when iterating. | |
| DataParserPluginBase:: | protected | property | The data retrieval client. | |
| DataParserPluginBase:: | protected | property | String indicating how to select an item's data from the source. | |
| DataParserPluginBase:: | protected | property | List of source urls. | |
| DataParserPluginBase:: | public | function | ||
| DataParserPluginBase:: | public static | function | ||
| DataParserPluginBase:: | public | function | ||
| DataParserPluginBase:: | protected | function | Return the selectors used to populate each configured field. | |
| DataParserPluginBase:: | public | function | Returns the initialized data fetcher plugin. | |
| DataParserPluginBase:: | public | function | ||
| DataParserPluginBase:: | public | function | Implementation of Iterator::next(). | |
| DataParserPluginBase:: | protected | function | Advances the data parser to the next source url. | |
| DataParserPluginBase:: | public | function | ||
| DataParserPluginBase:: | public | function | ||
| DependencySerializationTrait:: | protected | property | An array of entity type IDs keyed by the property name of their storages. | |
| DependencySerializationTrait:: | protected | property | An array of service IDs keyed by property name used for serialization. | |
| DependencySerializationTrait:: | public | function | 1 | |
| DependencySerializationTrait:: | public | function | 2 | |
| Json:: | protected | property | The request headers passed to the data fetcher. | |
| Json:: | protected | property | Iterator over the JSON data. | |
| Json:: | protected | function | Retrieves the next row of data from the open source URL, populating
currentItem. Overrides DataParserPluginBase:: | |
| Json:: | protected | function | ||
| Json:: | protected | function | Get the source data for reading. | |
| Json:: | protected | function | Opens the specified URL. Overrides DataParserPluginBase:: | |
| Json:: | public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides DataParserPluginBase:: | |
| MessengerTrait:: | protected | property | The messenger. | 29 | 
| MessengerTrait:: | public | function | Gets the messenger. | 29 | 
| MessengerTrait:: | public | function | Sets the messenger. | |
| PluginBase:: | protected | property | Configuration information passed into the plugin. | 1 | 
| PluginBase:: | protected | property | The plugin implementation definition. | 1 | 
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
| PluginBase:: | public | function | Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: | 3 | 
| PluginBase:: | public | function | Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Determines if the plugin is configurable. | |
| StringTranslationTrait:: | protected | property | The string translation service. | 1 | 
| StringTranslationTrait:: | protected | function | Formats a string containing a count of items. | |
| StringTranslationTrait:: | protected | function | Returns the number of plurals supported by a given language. | |
| StringTranslationTrait:: | protected | function | Gets the string translation service. | |
| StringTranslationTrait:: | public | function | Sets the string translation service to use. | 2 | 
| StringTranslationTrait:: | protected | function | Translates a string to the current language or to a given language. | 
