mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-07 00:48:55 +01:00
dd21bf5f22
Introduces `wp_get_wp_version()` to get an unmodified value of `$wp_version` from `wp-includes/version.php`. Some plugins modify the global in an attempt to improve security through obscurity. This practice can cause errors in WordPress so the ability to get an unmodified version is needed. Replaces instances within the code base in which `version.php` was required in order to get an unmodified value. `script-loader.php` is intentionally excluded from the replacements as the function is not always available to the file. Props debarghyabanerjee, afragen, costdev. See #61627. Built from https://develop.svn.wordpress.org/trunk@58813 git-svn-id: http://core.svn.wordpress.org/trunk@58209 1a063a9b-81f0-0310-95a4-ce76da25c4cd
230 lines
6.5 KiB
PHP
230 lines
6.5 KiB
PHP
<?php
|
|
/**
|
|
* WordPress Administration Importer API.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
/**
|
|
* Retrieves the list of importers.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @global array $wp_importers
|
|
* @return array
|
|
*/
|
|
function get_importers() {
|
|
global $wp_importers;
|
|
if ( is_array( $wp_importers ) ) {
|
|
uasort( $wp_importers, '_usort_by_first_member' );
|
|
}
|
|
return $wp_importers;
|
|
}
|
|
|
|
/**
|
|
* Sorts a multidimensional array by first member of each top level member.
|
|
*
|
|
* Used by uasort() as a callback, should not be used directly.
|
|
*
|
|
* @since 2.9.0
|
|
* @access private
|
|
*
|
|
* @param array $a
|
|
* @param array $b
|
|
* @return int
|
|
*/
|
|
function _usort_by_first_member( $a, $b ) {
|
|
return strnatcasecmp( $a[0], $b[0] );
|
|
}
|
|
|
|
/**
|
|
* Registers importer for WordPress.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @global array $wp_importers
|
|
*
|
|
* @param string $id Importer tag. Used to uniquely identify importer.
|
|
* @param string $name Importer name and title.
|
|
* @param string $description Importer description.
|
|
* @param callable $callback Callback to run.
|
|
* @return void|WP_Error Void on success. WP_Error when $callback is WP_Error.
|
|
*/
|
|
function register_importer( $id, $name, $description, $callback ) {
|
|
global $wp_importers;
|
|
if ( is_wp_error( $callback ) ) {
|
|
return $callback;
|
|
}
|
|
$wp_importers[ $id ] = array( $name, $description, $callback );
|
|
}
|
|
|
|
/**
|
|
* Cleanup importer.
|
|
*
|
|
* Removes attachment based on ID.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @param string $id Importer ID.
|
|
*/
|
|
function wp_import_cleanup( $id ) {
|
|
wp_delete_attachment( $id );
|
|
}
|
|
|
|
/**
|
|
* Handles importer uploading and adds attachment.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @return array Uploaded file's details on success, error message on failure.
|
|
*/
|
|
function wp_import_handle_upload() {
|
|
if ( ! isset( $_FILES['import'] ) ) {
|
|
return array(
|
|
'error' => sprintf(
|
|
/* translators: 1: php.ini, 2: post_max_size, 3: upload_max_filesize */
|
|
__( 'File is empty. Please upload something more substantial. This error could also be caused by uploads being disabled in your %1$s file or by %2$s being defined as smaller than %3$s in %1$s.' ),
|
|
'php.ini',
|
|
'post_max_size',
|
|
'upload_max_filesize'
|
|
),
|
|
);
|
|
}
|
|
|
|
$overrides = array(
|
|
'test_form' => false,
|
|
'test_type' => false,
|
|
);
|
|
$_FILES['import']['name'] .= '.txt';
|
|
$upload = wp_handle_upload( $_FILES['import'], $overrides );
|
|
|
|
if ( isset( $upload['error'] ) ) {
|
|
return $upload;
|
|
}
|
|
|
|
// Construct the attachment array.
|
|
$attachment = array(
|
|
'post_title' => wp_basename( $upload['file'] ),
|
|
'post_content' => $upload['url'],
|
|
'post_mime_type' => $upload['type'],
|
|
'guid' => $upload['url'],
|
|
'context' => 'import',
|
|
'post_status' => 'private',
|
|
);
|
|
|
|
// Save the data.
|
|
$id = wp_insert_attachment( $attachment, $upload['file'] );
|
|
|
|
/*
|
|
* Schedule a cleanup for one day from now in case of failed
|
|
* import or missing wp_import_cleanup() call.
|
|
*/
|
|
wp_schedule_single_event( time() + DAY_IN_SECONDS, 'importer_scheduled_cleanup', array( $id ) );
|
|
|
|
return array(
|
|
'file' => $upload['file'],
|
|
'id' => $id,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Returns a list from WordPress.org of popular importer plugins.
|
|
*
|
|
* @since 3.5.0
|
|
*
|
|
* @return array Importers with metadata for each.
|
|
*/
|
|
function wp_get_popular_importers() {
|
|
$locale = get_user_locale();
|
|
$cache_key = 'popular_importers_' . md5( $locale . wp_get_wp_version() );
|
|
$popular_importers = get_site_transient( $cache_key );
|
|
|
|
if ( ! $popular_importers ) {
|
|
$url = add_query_arg(
|
|
array(
|
|
'locale' => $locale,
|
|
'version' => wp_get_wp_version(),
|
|
),
|
|
'http://api.wordpress.org/core/importers/1.1/'
|
|
);
|
|
$options = array( 'user-agent' => 'WordPress/' . wp_get_wp_version() . '; ' . home_url( '/' ) );
|
|
|
|
if ( wp_http_supports( array( 'ssl' ) ) ) {
|
|
$url = set_url_scheme( $url, 'https' );
|
|
}
|
|
|
|
$response = wp_remote_get( $url, $options );
|
|
$popular_importers = json_decode( wp_remote_retrieve_body( $response ), true );
|
|
|
|
if ( is_array( $popular_importers ) ) {
|
|
set_site_transient( $cache_key, $popular_importers, 2 * DAY_IN_SECONDS );
|
|
} else {
|
|
$popular_importers = false;
|
|
}
|
|
}
|
|
|
|
if ( is_array( $popular_importers ) ) {
|
|
// If the data was received as translated, return it as-is.
|
|
if ( $popular_importers['translated'] ) {
|
|
return $popular_importers['importers'];
|
|
}
|
|
|
|
foreach ( $popular_importers['importers'] as &$importer ) {
|
|
// phpcs:ignore WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
|
|
$importer['description'] = translate( $importer['description'] );
|
|
if ( 'WordPress' !== $importer['name'] ) {
|
|
// phpcs:ignore WordPress.WP.I18n.LowLevelTranslationFunction,WordPress.WP.I18n.NonSingularStringLiteralText
|
|
$importer['name'] = translate( $importer['name'] );
|
|
}
|
|
}
|
|
return $popular_importers['importers'];
|
|
}
|
|
|
|
return array(
|
|
// slug => name, description, plugin slug, and register_importer() slug.
|
|
'blogger' => array(
|
|
'name' => __( 'Blogger' ),
|
|
'description' => __( 'Import posts, comments, and users from a Blogger blog.' ),
|
|
'plugin-slug' => 'blogger-importer',
|
|
'importer-id' => 'blogger',
|
|
),
|
|
'wpcat2tag' => array(
|
|
'name' => __( 'Categories and Tags Converter' ),
|
|
'description' => __( 'Convert existing categories to tags or tags to categories, selectively.' ),
|
|
'plugin-slug' => 'wpcat2tag-importer',
|
|
'importer-id' => 'wp-cat2tag',
|
|
),
|
|
'livejournal' => array(
|
|
'name' => __( 'LiveJournal' ),
|
|
'description' => __( 'Import posts from LiveJournal using their API.' ),
|
|
'plugin-slug' => 'livejournal-importer',
|
|
'importer-id' => 'livejournal',
|
|
),
|
|
'movabletype' => array(
|
|
'name' => __( 'Movable Type and TypePad' ),
|
|
'description' => __( 'Import posts and comments from a Movable Type or TypePad blog.' ),
|
|
'plugin-slug' => 'movabletype-importer',
|
|
'importer-id' => 'mt',
|
|
),
|
|
'rss' => array(
|
|
'name' => __( 'RSS' ),
|
|
'description' => __( 'Import posts from an RSS feed.' ),
|
|
'plugin-slug' => 'rss-importer',
|
|
'importer-id' => 'rss',
|
|
),
|
|
'tumblr' => array(
|
|
'name' => __( 'Tumblr' ),
|
|
'description' => __( 'Import posts & media from Tumblr using their API.' ),
|
|
'plugin-slug' => 'tumblr-importer',
|
|
'importer-id' => 'tumblr',
|
|
),
|
|
'wordpress' => array(
|
|
'name' => 'WordPress',
|
|
'description' => __( 'Import posts, pages, comments, custom fields, categories, and tags from a WordPress export file.' ),
|
|
'plugin-slug' => 'wordpress-importer',
|
|
'importer-id' => 'wordpress',
|
|
),
|
|
);
|
|
}
|