Create New Item
Item Type
File
Folder
Item Name
Search file in folder and subfolders...
Are you sure want to rename?
File Manager
/
wp-content
/
plugins
/
woocommerce
/
vendor
/
woocommerce
/
blueprint
/
src
:
ImportSchema.php
Advanced Search
Upload
New Item
Settings
Back
Back Up
Advanced Editor
Save
<?php namespace Automattic\WooCommerce\Blueprint; use Automattic\WooCommerce\Blueprint\Schemas\JsonSchema; use Automattic\WooCommerce\Blueprint\Schemas\ZipSchema; use Opis\JsonSchema\Errors\ErrorFormatter; use Opis\JsonSchema\Validator; /** * Class ImportSchema * * Handles the import schema functionality for WooCommerce. * * @package Automattic\WooCommerce\Blueprint */ class ImportSchema { use UseWPFunctions; /** * JsonSchema object. * * @var JsonSchema The schema instance. */ private JsonSchema $schema; /** * Validator object. * * @var Validator The JSON schema validator instance. */ private Validator $validator; /** * Built-in step processors. * * @var BuiltInStepProcessors The built-in step processors instance. */ private BuiltInStepProcessors $builtin_step_processors; /** * ImportSchema constructor. * * @param JsonSchema $schema The schema instance. * @param Validator|null $validator The validator instance, optional. */ public function __construct( JsonSchema $schema, Validator $validator = null ) { $this->schema = $schema; if ( null === $validator ) { $validator = new Validator(); } $this->validator = $validator; $this->builtin_step_processors = new BuiltInStepProcessors( $schema ); } /** * Get the schema. * * @return JsonSchema The schema. */ public function get_schema() { return $this->schema; } /** * Create an ImportSchema instance from a file. * * @param string $file The file path. * @return ImportSchema The created ImportSchema instance. */ public static function create_from_file( $file ) { // @todo check for mime type // @todo check for allowed types -- json or zip $path_info = pathinfo( $file ); $is_zip = 'zip' === $path_info['extension']; return $is_zip ? self::create_from_zip( $file ) : self::create_from_json( $file ); } /** * Create an ImportSchema instance from a JSON file. * * @param string $json_path The JSON file path. * @return ImportSchema The created ImportSchema instance. */ public static function create_from_json( $json_path ) { return new self( new JsonSchema( $json_path ) ); } /** * Create an ImportSchema instance from a ZIP file. * * @param string $zip_path The ZIP file path. * * @return ImportSchema The created ImportSchema instance. */ public static function create_from_zip( $zip_path ) { return new self( new ZipSchema( $zip_path ) ); } /** * Import the schema steps. * * @return StepProcessorResult[] */ public function import() { $results = array(); $result = StepProcessorResult::success( 'ImportSchema' ); $results[] = $result; $step_processors = $this->builtin_step_processors->get_all(); /** * Filters the step processors. * * Allows adding/removing custom step processors. * * @param StepProcessor[] $step_processors The step processors. * * @since 0.0.1 */ $step_processors = $this->wp_apply_filters( 'wooblueprint_importers', $step_processors ); $indexed_step_processors = Util::index_array( $step_processors, function ( $key, $step_processor ) { return $step_processor->get_step_class()::get_step_name(); } ); // validate steps before processing. $this->validate_step_schemas( $indexed_step_processors, $result ); if ( count( $result->get_messages( 'error' ) ) !== 0 ) { return $results; } foreach ( $this->schema->get_steps() as $step_schema ) { $step_processor = $indexed_step_processors[ $step_schema->step ] ?? null; if ( ! $step_processor instanceof StepProcessor ) { $result->add_error( "Unable to create a step processor for {$step_schema->step}" ); continue; } $results[] = $step_processor->process( $step_schema ); } return $results; } /** * Validate the step schemas. * * @param array $indexed_step_processors Array of step processors indexed by step name. * @param StepProcessorResult $result The result object to add messages to. * * @return void */ protected function validate_step_schemas( array $indexed_step_processors, StepProcessorResult $result ) { $step_schemas = array_map( function ( $step_processor ) { return $step_processor->get_step_class()::get_schema(); }, $indexed_step_processors ); foreach ( $this->schema->get_steps() as $step_json ) { $step_schema = $step_schemas[ $step_json->step ] ?? null; if ( ! $step_schema ) { $result->add_info( "No schema found for step $step_json->step" ); continue; } // phpcs:ignore $validate = $this->validator->validate( $step_json, json_encode( $step_schema ) ); if ( ! $validate->isValid() ) { $result->add_error( "Schema validation failed for step {$step_json->step}" ); $errors = ( new ErrorFormatter() )->format( $validate->error() ); $formatted_errors = array(); foreach ( $errors as $value ) { $formatted_errors[] = implode( "\n", $value ); } $result->add_error( implode( "\n", $formatted_errors ) ); } } } }