id} Domain={$siteInfo->domain} Path={$siteInfo->path} Blogname={$siteInfo->blogname}"); } return $site_array; } /** * * @param int $subsiteId * * @return stdClass|bool false on failure */ public static function getSubsiteInfoById($subsiteId) { if (!is_multisite()) { $subsiteId = 1; } return self::getSubsiteInfo($subsiteId); } /** * Get subsite info * * @param int $siteId * @param array $filteredTables * @param array|false $filteredPaths return * * @return stdClass|bool false on failure */ public static function getSubsiteInfo($siteId = 1, $filteredTables = array(), $filteredPaths = array()) { if (is_multisite()) { if (($siteDetails = get_blog_details($siteId)) == false) { return false; } } else { $siteId = 1; $siteDetails = new stdClass(); $home = DUP_Archive::getOriginalUrls('home'); $parsedHome = SnapURL::parseUrl($home); $siteDetails->domain = $parsedHome['host']; $siteDetails->path = trailingslashit($parsedHome['path']); $siteDetails->blogname = sanitize_text_field(get_option('blogname')); } $subsiteID = $siteId; $siteInfo = new stdClass(); $siteInfo->id = $subsiteID; $siteInfo->domain = $siteDetails->domain; $siteInfo->path = $siteDetails->path; $siteInfo->blogname = $siteDetails->blogname; $siteInfo->blog_prefix = $GLOBALS['wpdb']->get_blog_prefix($subsiteID); if (count($filteredTables) > 0) { $siteInfo->filteredTables = array_values(array_intersect(self::getSubsiteTables($subsiteID), $filteredTables)); } else { $siteInfo->filteredTables = array(); } $siteInfo->adminUsers = SnapWP::getAdminUserLists($siteInfo->id); $siteInfo->fullHomeUrl = get_home_url($siteId); $siteInfo->fullSiteUrl = get_site_url($siteId); if ($siteId > 1) { switch_to_blog($siteId); } $uploadData = wp_upload_dir(); $uploadPath = $uploadData['basedir']; $siteInfo->uploadPath = SnapIO::getRelativePath($uploadPath, DUP_Archive::getTargetRootPath(), true); $siteInfo->fullUploadPath = untrailingslashit($uploadPath); $siteInfo->fullUploadSafePath = SnapIO::safePathUntrailingslashit($uploadPath); $siteInfo->fullUploadUrl = $uploadData['baseurl']; if (count($filteredPaths)) { $globalDirFilters = apply_filters('duplicator_global_file_filters', $GLOBALS['DUPLICATOR_GLOBAL_FILE_FILTERS']); $siteInfo->filteredPaths = array_values(array_filter($filteredPaths, function ($path) use ($uploadPath, $subsiteID, $globalDirFilters) { if ( ($relativeUpload = SnapIO::getRelativePath($path, $uploadPath)) === false || in_array($path, $globalDirFilters) ) { return false; } if ($subsiteID > 1) { return true; } else { // no check on blogs.dir because in wp-content/blogs.dir not in upload folder return !(strpos($relativeUpload, 'sites') === 0); } })); } else { $siteInfo->filteredPaths = array(); } if ($siteId > 1) { restore_current_blog(); } return $siteInfo; } /** * @param int $subsiteID * * @return array List of tables belonging to subsite */ public static function getSubsiteTables($subsiteID) { /** @var \wpdb $wpdb */ global $wpdb; $basePrefix = $wpdb->base_prefix; $subsitePrefix = $wpdb->get_blog_prefix($subsiteID); $sharedTables = array( $basePrefix . 'users', $basePrefix . 'usermeta' ); $multisiteOnlyTables = array( $basePrefix . 'blogmeta', $basePrefix . 'blogs', $basePrefix . 'blog_versions', $basePrefix . 'registration_log', $basePrefix . 'signups', $basePrefix . 'site', $basePrefix . 'sitemeta' ); $subsiteTables = array(); $sql = ""; $dbnameSafe = esc_sql(DB_NAME); if ($subsiteID != 1) { $regex = '^' . SnapDB::quoteRegex($subsitePrefix); $regexpSafe = esc_sql($regex); $sharedTablesSafe = "'" . implode( "', '", esc_sql($sharedTables) ) . "'"; $sql = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '$dbnameSafe' AND "; $sql .= "(TABLE_NAME REGEXP '$regexpSafe' OR TABLE_NAME IN ($sharedTablesSafe))"; } else { $regexMain = '^' . SnapDB::quoteRegex($basePrefix); $regexpMainSafe = esc_sql($regexMain); $regexNotSub = '^' . SnapDB::quoteRegex($basePrefix) . '[0-9]+_'; $regexpNotSubSafe = esc_sql($regexNotSub); $multisiteOnlyTablesSafe = "'" . implode( "', '", esc_sql($multisiteOnlyTables) ) . "'"; $sql = "SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '$dbnameSafe' AND "; $sql .= "TABLE_NAME REGEXP '$regexpMainSafe' AND "; $sql .= "TABLE_NAME NOT REGEXP '$regexpNotSubSafe' AND "; $sql .= "TABLE_NAME NOT IN ($multisiteOnlyTablesSafe)"; } $subsiteTables = $wpdb->get_col($sql); return $subsiteTables; } }