class Json in Migrate Plus 8.5
Same name and namespace in other branches
- 8 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 16
Namespace
Drupal\migrate_plus\Plugin\migrate_plus\data_parserView source
class Json extends DataParserPluginBase implements ContainerFactoryPluginInterface {
/**
* Iterator over the JSON data.
*
* @var \Iterator
*/
protected $iterator;
/**
* Retrieves the JSON data and returns it as an array.
*
* @param string $url
* URL of a JSON feed.
*
* @return array
* The selected data to be iterated.
*
* @throws \GuzzleHttp\Exception\RequestException
*/
protected function getSourceData($url) {
$response = $this
->getDataFetcherPlugin()
->getResponseContent($url);
// Convert objects to associative arrays.
$source_data = json_decode($response, TRUE);
// If json_decode() has returned NULL, it might be that the data isn't
// valid utf8 - see http://php.net/manual/en/function.json-decode.php#86997.
if (is_null($source_data)) {
$utf8response = utf8_encode($response);
$source_data = json_decode($utf8response, TRUE);
}
// Backwards-compatibility for depth selection.
if (is_int($this->itemSelector)) {
return $this
->selectByDepth($source_data);
}
// Otherwise, we're using xpath-like selectors.
$selectors = explode('/', trim($this->itemSelector, '/'));
foreach ($selectors as $selector) {
if (!empty($selector) || $selector === '0') {
$source_data = $source_data[$selector];
}
}
return $source_data;
}
/**
* Get the source data for reading.
*
* @param array $raw_data
* Raw data from the JSON feed.
*
* @return array
* Selected items at the requested depth of the JSON feed.
*/
protected function selectByDepth(array $raw_data) {
// Return the results in a recursive iterator that can traverse
// multidimensional arrays.
$iterator = new \RecursiveIteratorIterator(new \RecursiveArrayIterator($raw_data), \RecursiveIteratorIterator::SELF_FIRST);
$items = [];
// Backwards-compatibility - an integer item_selector is interpreted as a
// depth. When there is an array of items at the expected depth, pull that
// array out as a distinct item.
$identifierDepth = $this->itemSelector;
$iterator
->rewind();
while ($iterator
->valid()) {
$item = $iterator
->current();
if (is_array($item) && $iterator
->getDepth() == $identifierDepth) {
$items[] = $item;
}
$iterator
->next();
}
return $items;
}
/**
* {@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) {
$field_data = $current;
$field_selectors = explode('/', trim($selector, '/'));
foreach ($field_selectors as $field_selector) {
if (is_array($field_data) && array_key_exists($field_selector, $field_data)) {
$field_data = $field_data[$field_selector];
}
else {
$field_data = '';
}
}
$this->currentItem[$field_name] = $field_data;
}
if (!empty($this->configuration['include_raw_data'])) {
$this->currentItem['raw'] = $current;
}
$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. | 1 |
DataParserPluginBase:: |
public | function | 1 | |
DataParserPluginBase:: |
public | function | ||
DataParserPluginBase:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
3 |
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 | Iterator over the JSON data. | |
Json:: |
protected | function |
Retrieves the next row of data. populating currentItem. Overrides DataParserPluginBase:: |
|
Json:: |
protected | function | Retrieves the JSON data and returns it as an array. | |
Json:: |
protected | function |
Opens the specified URL. Overrides DataParserPluginBase:: |
|
Json:: |
protected | function | Get the source data for reading. | |
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. |