<?php class OpalEstate_Command { public $path; /** * Constructor */ public function __construct() { return; $this->path = OPALESTATE_PLUGIN_DIR; // $this->cfg = json_decode( file get contents( $this->path.'project.json' ) ); $this->cfg = json_decode( wp_remote_get( $this->path.'project.json' ) ); $this->server = $this->cfg->server; $this->oldurl = $this->cfg->oldurl; $this->theme = $this->cfg->theme; $this->name = $this->cfg->name; $this->subpath = $this->cfg->subpath; } /** * Write data in file */ private function output_file_content( $file_path, $output ) { $fp = fopen( $file_path, 'w+' ); fwrite( $fp, $output ); fclose( $fp ); } /** * Get more options */ public function get_more_options(){ $data = array( 'header' => 'header-1', 'footer' => 'footer-1', 'page' => 'home-1' ); if( isset($this->cfg->active) && $this->cfg->active ) { $data = (array) $this->cfg->active; } return array( 'active' => $data, 'oldurl' => $this->oldurl, 'server' => $this->server, "samples" => array( 'post' => array(), 'product' => array() ) ); } /** * Export theme options in customizer */ public function options(){ return array(); $thememods = get_option( 'theme_mods_' . $this->theme ); $file = $this->path.'/sample/thememods.json'; $ids = array(); foreach( $thememods as $key => $mod ){ if( is_string($mod) ){ // $thememods[$key] = $this->_replace_uri( $mod, $this->oldurl, "SITE_URL_HERE"); if( preg_match( "#jpg|png|gif|svg#", $mod) && $mod ){ $ids[$key] = $this->find_image_id_byguid( $mod ); } } if( isset($thememods['wpopal_customize_css']) ){ unset( $thememods['wpopal_customize_css'] ); } if( isset($thememods['osf_theme_custom_style']) ){ unset( $thememods['osf_theme_custom_style'] ); } if( isset($thememods['sidebars_widgets']) ){ unset( $thememods['sidebars_widgets'] ); } /// if( $key == 'custom_logo' && $mod ){ $ids[$key] = $mod; } } $attachments = array(); if( $ids ){ foreach( $ids as $id ) { $post = get_post( $id ); if( $post ) { $attachments[$post->ID] = array( 'id' => $post->ID, 'guid' => wp_get_attachment_url( $post->ID ), 'post_parent' => $post->post_parent, 'post_name' => $post->post_name, 'post_date' => $post->post_date ); } } } $options = array( 'woocommerce_single_image_width' => '', 'woocommerce_thumbnail_image_width' => '', 'woocommerce_thumbnail_cropping' => '', 'woocommerce_thumbnail_cropping_custom_height' => '', 'woocommerce_thumbnail_cropping_custom_width' => '', "woocommerce_shop_page_id" => '', "woocommerce_cart_page_id" => '', 'woocommerce_checkout_page_id' => '', 'woocommerce_myaccount_page_id' => '', 'woocommerce_terms_page_id' => '', 'yith_wcwl_wishlist_page_id' => '' ); foreach( $options as $key => $value ){ $value = get_option( $key ); if( empty($value) ) { unset( $options[$key] ); continue; } $options[$key] = $value; } $options['page_for_posts'] = 'Blog'; if( function_exists( 'wp_get_custom_css_post' ) ) { $options['wp_css'] = wp_get_custom_css(); } $data = array( 'thememods' => $thememods, 'attachments' => $attachments, "options" => $options ); // $this->output_file_content( $file, wp_json_encode($data ,JSON_PRETTY_PRINT ) ); return $data; } /** * Replace URI in xml */ public function _replace_uri( $str, $oldurl, $server ){ $str = str_replace( str_replace("/","\/", $oldurl ), str_replace("/","\/", $server ), $str ); $str = str_replace( $oldurl, $server, $str ); $str = str_replace( str_replace("/","\\\\\\/", $oldurl ), str_replace("/","\\\\\\/", $server ), $str ); return $str; } /** * Export config samples */ public function config_samples( $dev=0 ){ $data['samples'] = array(); $file = $this->path.$this->cfg->folder_source.'/samples.json'; $niches = $this->cfg->niches; $single = $this->cfg->single; $key = 0; $data['samples'][] = array( "name" => isset($single->name)?$single->name:"Sample", "key" => "niche-".$key, "url" => isset($single->url)?$single->url:"", "demo" => isset($single->demo)?$single->demo:"", "preview" => $this->cfg->server_source.'/screenshot.png', "sample" => $this->cfg->server_source.'/data.zip' ); $this->output_file_content( $file, wp_json_encode($data ) ); /// //$file = $this->path.'/wp-content/themes/'.$this->cfg->theme.'/project.json'; //$data = $this->cfg->themeinfo; //$this->output_file_content( $file, json_encode($data , JSON_PRETTY_PRINT ) ); } /** * Export all pages */ public function pages(){ return array(); $excludes = array(); global $wpdb; $post_type = 'page'; /// items $where = $wpdb->prepare( "{$wpdb->posts}.post_type = %s and {$wpdb->posts}.post_content LIKE '%opalestate_%'", $post_type ); // grab a snapshot of post IDs, just in case it changes during the export $post_ids = $wpdb->get_col( "SELECT ID FROM {$wpdb->posts} WHERE $where" ); $data = $this->export_json_ids( $post_ids, $excludes, $isattachement ); echo '<pre>' . print_r( $data ,1 );die; //$file = $this->path.'sample/pages.json'; // $this->output_file_content( $file, wp_json_encode($data ) ); return $data; } /** * Export all pages */ public function data_posttypes(){ $excludes = array(); $data = $this->export_posttype( array( 'opalestate_agent', 'opalestate_agency', 'opalestate_agent_ft', 'opalestate_agency_ft', 'opalestate_rating_ft', 'opalestate_property' ), $excludes ); // $file = ABSPATH.'src/json/elementor.json'; // $this->output_file_content( $file, wp_json_encode($data ) ); return $data; } /** * get all attachments by post ids */ protected function get_attachment( $post_ids ) { $attachments = array(); foreach ( $post_ids as $post_id) { $value = get_post_meta($post_id, '_thumbnail_id', true); if ( $value ) { $attachments = array_merge( $attachments, array($value) ); } $attachArgs = array( 'post_parent' => $post_id, 'post_type' => 'attachment', 'numberposts' => -1, 'post__not_in' => $attachments, //To skip duplicates ); $attachList = get_children($attachArgs, ARRAY_A); $attachments = array_merge($attachments, array_keys($attachList)); } $ids = $this->get_images_posts( $post_ids ); if( $ids ){ $attachments = array_merge( $ids, $attachments ); } return $attachments; } /** * Export data posts by post type with attachments */ protected function export_posttype( $post_type, $excludes=array(), $isattachement=true ) { global $wpdb; /// items if( is_array($post_type) ){ $tmp = "'".implode( "','", $post_type )."'"; $where = "{$wpdb->posts}.post_type IN( ".$tmp ." )"; } else { $where = $wpdb->prepare( "{$wpdb->posts}.post_type = %s", $post_type ); } // grab a snapshot of post IDs, just in case it changes during the export $post_ids = $wpdb->get_col( "SELECT ID FROM {$wpdb->posts} WHERE $where" ); return $this->export_json_ids( $post_ids, $excludes, $isattachement ); } public function aa(){ global $wpdb; $postmeta = $wpdb->get_results( $wpdb->prepare( "SELECT * FROM $wpdb->postmeta WHERE post_id = %d", 240) ); $exls = array( '_edit_last', '_edit_lock', '_elementor_version', '_menu_item_type', '_menu_item_menu_item_parent', '_menu_item_object_id', '_menu_item_object', '_menu_item_target', '_menu_item_classes', '_menu_item_xfn', '_menu_item_url', '_elementor_css' ); $tmp = array(); foreach( $postmeta as $key => $meta ){ unset( $postmeta[$key]->post_id ); unset( $postmeta[$key]->meta_id ); foreach( $exls as $exl ){ if( $meta->meta_key == $exl ){ unset( $postmeta[$key] ); } } } foreach( $postmeta as $key => $meta ){ $tmp[$meta->meta_key] = $meta->meta_value; } } /** * export json data by ids */ protected function export_json_ids( $post_ids , $excludes, $isattachement ){ global $wpdb; $output = array(); $export = array(); if( $isattachement ){ $ids = $this->get_attachment( $post_ids ); if( $ids ){ $where = 'WHERE ID IN (' . join( ',', $ids ) . ')'; $posts = $wpdb->get_results( "SELECT * FROM {$wpdb->posts} $where" ); $export['attachments'] = array(); foreach( $posts as $post ) { $export['attachments'][$post->ID] = array( 'id' => $post->ID, 'guid'=> wp_get_attachment_url( $post->ID ), 'post_parent' => $post->post_parent, 'post_name' => $post->post_name, 'post_date' => $post->post_date ); } } } while ( $next_posts = array_splice( $post_ids, 0, 20 ) ) { $where = 'ID IN (' . join( ',', $next_posts ) . ')'; $posts = $wpdb->get_results( "SELECT * FROM {$wpdb->posts} WHERE post_status='publish' and $where" ); // Begin Loop. foreach ( $posts as $post ) { if( in_array($post->ID , $excludes) ){ continue; } setup_postdata( $post ); $data = array(); if ( get_post_meta( $post->ID, '_elementor_edit_mode', true ) === 'builder' ) { $post->post_content = ""; } $post->guid = $this->_replace_uri( $post->guid, $this->oldurl, "SITE_URL_HERE" ); $excludes = array( 'guid', 'to_ping', 'pinged', 'post_content_filtered', 'post_mime_type', 'comment_count', 'filter', 'post_modified', 'post_modified_gmt' ); foreach( $excludes as $exl ){ if( isset($post->$exl) ){ unset( $post->$exl ); } } $data['post'] = $post; // meta data $postmeta = $wpdb->get_results( $wpdb->prepare( "SELECT * FROM $wpdb->postmeta WHERE post_id = %d", $post->ID ) ); $exls = array( '_edit_last', '_edit_lock', '_elementor_version', '_menu_item_type', '_menu_item_menu_item_parent', '_menu_item_object_id', '_menu_item_object', '_menu_item_target', '_menu_item_classes', '_menu_item_xfn', '_menu_item_url', '_elementor_css' ); $tmp = array(); foreach( $postmeta as $key => $meta ){ unset( $postmeta[$key]->post_id ); unset( $postmeta[$key]->meta_id ); foreach( $exls as $exl ){ if( $meta->meta_key == $exl ){ unset( $postmeta[$key] ); } } } foreach( $postmeta as $key => $meta ){ $tmp[$meta->meta_key] = $meta->meta_value; } $data['postmeta'] = $tmp; if ( $post->post_type == 'attachment' ){ $data['attachment_url'] = wp_get_attachment_url( $post->ID ); } $data['thumbnail_id'] = get_post_meta( $post->ID, '_thumbnail_id', true ); // taxonomy $taxonomies = get_object_taxonomies( $post->post_type ); if ( !empty( $taxonomies ) ) { $data['taxonomy'] = array(); $terms = wp_get_object_terms( $post->ID, $taxonomies ); foreach ( (array) $terms as $term ) { if( $term->taxonomy == 'nav_menu' ){ continue; } $t = array( $term->taxonomy => array ( $term->slug => $term->name ) ); $data['taxonomy'][] = $t; } } $output [] = $data; } } $export['posts'] = $output; return $export; } /** * find attachment post id by guid */ private function find_image_id_byguid( $image_url ) { global $wpdb; $attachment = $wpdb->get_col( "SELECT ID FROM $wpdb->posts WHERE guid LIKE '%".$image_url."%';" ); return isset($attachment[0])?$attachment[0]:0; } /** * find all images:svg,git,png,jpg in data setting of elementor */ private function get_images_posts( $ids ){ $mids = array(); $images = array(); foreach( $ids as $id ){ if ( get_post_meta( $id, '_elementor_edit_mode', true ) === 'builder' ) { $data = json_decode( get_post_meta( $id, '_elementor_data', true ), ARRAY_A ); if( $data ){ $string = "start".print_r( $data , true )."end"; $pattern = '~(http.*\.)(jpe?g|png|svg|gif|[tg]iff?|svg)~i'; $m = preg_match_all($pattern,$string,$matches); if( $matches[0] ){ foreach( $matches[0] as $img ){ $pattern = '#(/\d+/\d+/(.*))$#'; $a = preg_match( $pattern , $img, $m ); if( isset($m[1]) ){ ///echo '<Pre>' . print_r( $data, 1 );die; $_id = $this->find_image_id_byguid( $m[1] ); if( $_id ) { $mids[$_id] = $_id; } else { $images[] = $img; } } } } } } } echo '<Pre> Missing Images:' . print_r( $images , 1 ); //die; return $mids; } public function sample(){ $data = array(); return $data; } public function download_images( $attachments, $jcontent ){ $folder = $this->path .'/'.$this->cfg->folder_source.'/images'; if( is_dir($folder) ){ $file = new Filesystem(); $file->deleteDirectory( $folder ); } if( !is_dir($folder) ){ mkdir( $folder ); } $url = $this->cfg->server_source.'/images/'; $replaces = array(); foreach( $attachments as $attachment ){ $guid = str_replace( $this->server , $this->oldurl, $attachment['guid'] ) ; // $image = file get contents( $guid ); $image = wp_remote_get( $guid ); $name = basename( $attachment['guid'] ); $path = $folder.'/'.$name; file_put_contents( $path, $image ); $guid = $attachment['guid']; $newurl = $url.$name; $replaces[$guid] = $newurl; } foreach( $replaces as $key => $replace ){ $jcontent = $this->_replace_uri( $jcontent, $key, $replace); } return $jcontent; } /** * export all sample data */ public function source(){ // $content = file get contents( $this->path.'/sample/data.json' ); $content = wp_remote_get( $this->path.'/sample/data.json' ); $data = json_decode( $content, true ); $file = new Filesystem(); $content = $this->download_images( $data['attachments'], $content ); $file = $this->path.'/'.$this->cfg->folder_source.'/data.json'; $this->output_file_content( $file, $content ); $zip = new ZipArchive; if ($zip->open( $this->path.'/'.$this->cfg->folder_source .'/data.zip', ZipArchive::CREATE | ZipArchive::OVERWRITE) === TRUE) { $zip->addFile( $file, 'data.json'); $zip->close(); echo 'ok'; } else { echo 'failed'; } } /** * export all sample data */ public function data(){ $this->fix_images_parents(); $data = $this->pages(); $data = array_merge_recursive( $data, $this->data_posttypes(), $this->options(), $this->get_more_options(), $this->sample() ); $data = apply_filters( 'opaltools_single_wp_cli_exporter', $data , $this->cfg ); $file = $this->path.'sample/data.json'; /// $attachments = array(); foreach ( $data['attachments'] as $key => $value ) { $attachments[$value['id']] = $value; } $data['attachments'] = $attachments; $content = $this->_replace_uri( json_encode($data , JSON_PRETTY_PRINT ), $this->oldurl, $this->server ); $content = str_replace( $this->cfg->theme, $this->cfg->domain, $content ); $this->output_file_content( $file, $content ); $this->config_samples(); $this->source(); } public function fix_images_parents(){ global $wpdb; $fixs = array( 'product-', 'bg-slider', 'slide-', 'bg-slide' ); foreach( $fixs as $fix ) { $wpdb->query( "UPDATE wp_posts SET post_parent=0 WHERE post_title LIKE '".$fix."%'" ); } } } WP_CLI::add_command( 'opalestate', new OpalEstate_Command ); ?>