<?php /** * Option management for the plugin */ if ( ! class_exists('MUCD_Option') ) { class MUCD_Option { /** * Init 'mucd_duplicable' options * * @param string $blogs_value the value for blogs options * @param string $network_value the value for site option * @since 0.2.0 */ public static function init_duplicable_option($blogs_value = 'no', $network_value = 'all'): void { $network_blogs = MUCD_Functions::get_sites(); foreach ( $network_blogs as $blog ) { $blog_id = $blog['blog_id']; add_blog_option($blog_id, 'mucd_duplicable', $blogs_value); } add_site_option('mucd_duplicables', $network_value); } /** * Delete 'mucd_duplicable' option for all sites * * @since 0.2.0 */ public static function delete_duplicable_option(): void { $network_blogs = MUCD_Functions::get_sites(); foreach ( $network_blogs as $blog ) { $blog_id = $blog['blog_id']; delete_blog_option($blog_id, 'mucd_duplicable'); } delete_site_option('mucd_duplicables'); } /** * Set 'mucd_duplicable' option to "yes" for the list of blogs, other to "no" * * @since 0.2.0 * @param array $blogs list of blogs we want the option set to "yes" */ public static function set_duplicable_option($blogs): void { $network_blogs = MUCD_Functions::get_sites(); foreach ( $network_blogs as $blog ) { if (in_array($blog['blog_id'], $blogs)) { update_blog_option($blog['blog_id'], 'mucd_duplicable', 'yes'); } else { update_blog_option($blog['blog_id'], 'mucd_duplicable', 'no'); } } } /** * Add plugin default options * * @since 1.3.0 */ public static function init_options(): void { add_site_option('mucd_copy_files', 'yes'); add_site_option('mucd_keep_users', 'yes'); add_site_option('mucd_log', 'no'); $upload_dir = wp_upload_dir(); add_site_option('mucd_log_dir', $upload_dir['basedir'] . '/multisite-clone-duplicator-logs/'); add_site_option('mucd_disable_enhanced_site_select', 'no'); self::init_duplicable_option(); } /** * Removes plugin options * * @since 1.3.0 */ public static function delete_options(): void { delete_site_option('mucd_copy_files'); delete_site_option('mucd_keep_users'); delete_site_option('mucd_log'); delete_site_option('mucd_log_dir'); delete_site_option('mucd_disable_enhanced_site_select'); self::delete_duplicable_option(); } /** * Get log directory option * * @since 0.2.0 * @return string the path */ public static function get_option_log_directory() { $upload_dir = wp_upload_dir(); return get_site_option('mucd_log_dir', $upload_dir['basedir'] . '/multisite-clone-duplicator-logs/'); } /** * Get directories to exclude from file copy when duplicated site is primary site * * @since 0.2.0 * @return array of string */ public static function get_primary_dir_exclude() { return [ 'sites', ]; } /** * Get default options that should be preserved in the new blog. * * @since 0.2.0 * @return array of string */ public static function get_default_saved_option() { return [ 'siteurl' => '', 'home' => '', 'upload_path' => '', 'fileupload_url' => '', 'upload_url_path' => '', 'admin_email' => '', 'blogname' => '', 'schema-ActionScheduler_Abstract_Schema' => '', 'action_scheduler_hybrid_store_demarkation' => '', 'schema-ActionScheduler_StoreSchema' => '', 'schema-ActionScheduler_LoggerSchema' => '', 'action_scheduler_lock_async-request-runner' => '', ]; } /** * Get filtered options that should be preserved in the new blog. * * @since 0.2.0 * @return array of string (filtered) */ public static function get_saved_option() { return apply_filters('mucd_copy_blog_data_saved_options', self::get_default_saved_option()); } /** * Get default fields to scan for an update after data copy * * @since 0.2.0 * @return array '%table_name' => array('%field_name_1','%field_name_2','%field_name_3', ...) */ public static function get_default_fields_to_update() { return [ 'commentmeta' => [], 'comments' => [], 'links' => ['link_url', 'link_image'], 'options' => ['option_name', 'option_value'], 'postmeta' => ['meta_value'], 'posts' => ['post_content', 'guid', 'post_title', 'post_name'], 'terms' => [], 'term_relationships' => [], 'term_taxonomy' => [], ]; } /** * Get filtered fields to scan for an update after data copy * * @since 0.2.0 * @return array of string (filtered) */ public static function get_fields_to_update() { return apply_filters('mucd_default_fields_to_update', self::get_default_fields_to_update()); } /** * Get default tables to duplicate when duplicated site is primary site * * @since 0.2.0 * @return array of string */ public static function get_default_primary_tables_to_copy() { return [ 'commentmeta', 'comments', 'links', 'options', 'postmeta', 'posts', 'terms', 'term_relationships', 'term_taxonomy', 'termmeta', ]; } /** * Get filtered tables to duplicate when duplicated site is primary site * * @since 0.2.0 * @return array of string (filtered) */ public static function get_primary_tables_to_copy() { return apply_filters('mucd_default_primary_tables_to_copy', self::get_default_primary_tables_to_copy()); } } }