2008-08-08 18:49:35 -04:00
< ? php
2008-08-14 02:30:38 -04:00
/**
* WordPress core upgrade functionality .
*
* @ package WordPress
* @ subpackage Administration
2008-10-01 21:03:26 -04:00
* @ since 2.7 . 0
2008-08-14 02:30:38 -04:00
*/
2008-08-08 18:49:35 -04:00
2008-08-14 02:30:38 -04:00
/**
* Stores files to be deleted .
*
2022-11-16 10:43:10 -05:00
* Bundled theme files should not be included in this list .
*
2008-10-01 21:03:26 -04:00
* @ since 2.7 . 0
2020-06-16 17:07:14 -04:00
*
2008-08-14 02:30:38 -04:00
* @ global array $_old_files
* @ var array
* @ name $_old_files
*/
2008-08-08 21:00:27 -04:00
global $_old_files ;
$_old_files = array (
2017-11-30 18:11:00 -05:00
// 2.0
'wp-admin/import-b2.php' ,
'wp-admin/import-blogger.php' ,
'wp-admin/import-greymatter.php' ,
'wp-admin/import-livejournal.php' ,
'wp-admin/import-mt.php' ,
'wp-admin/import-rss.php' ,
'wp-admin/import-textpattern.php' ,
'wp-admin/quicktags.js' ,
'wp-images/fade-butt.png' ,
'wp-images/get-firefox.png' ,
'wp-images/header-shadow.png' ,
'wp-images/smilies' ,
'wp-images/wp-small.png' ,
'wp-images/wpminilogo.png' ,
'wp.php' ,
// 2.1
'wp-admin/edit-form-ajax-cat.php' ,
'wp-admin/execute-pings.php' ,
'wp-admin/inline-uploading.php' ,
'wp-admin/link-categories.php' ,
'wp-admin/list-manipulation.js' ,
'wp-admin/list-manipulation.php' ,
'wp-includes/comment-functions.php' ,
'wp-includes/feed-functions.php' ,
'wp-includes/functions-compat.php' ,
'wp-includes/functions-formatting.php' ,
'wp-includes/functions-post.php' ,
'wp-includes/js/dbx-key.js' ,
'wp-includes/links.php' ,
'wp-includes/pluggable-functions.php' ,
'wp-includes/template-functions-author.php' ,
'wp-includes/template-functions-category.php' ,
'wp-includes/template-functions-general.php' ,
'wp-includes/template-functions-links.php' ,
'wp-includes/template-functions-post.php' ,
'wp-includes/wp-l10n.php' ,
// 2.2
'wp-admin/cat-js.php' ,
'wp-includes/js/autosave-js.php' ,
'wp-includes/js/list-manipulation-js.php' ,
'wp-includes/js/wp-ajax-js.php' ,
// 2.3
'wp-admin/admin-db.php' ,
'wp-admin/cat.js' ,
'wp-admin/categories.js' ,
'wp-admin/custom-fields.js' ,
'wp-admin/dbx-admin-key.js' ,
'wp-admin/edit-comments.js' ,
'wp-admin/install-rtl.css' ,
'wp-admin/install.css' ,
'wp-admin/upgrade-schema.php' ,
'wp-admin/upload-functions.php' ,
'wp-admin/upload-rtl.css' ,
'wp-admin/upload.css' ,
'wp-admin/upload.js' ,
'wp-admin/users.js' ,
'wp-admin/widgets-rtl.css' ,
'wp-admin/widgets.css' ,
'wp-admin/xfn.js' ,
'wp-includes/js/tinymce/license.html' ,
// 2.5
'wp-admin/css/upload.css' ,
'wp-admin/images/box-bg-left.gif' ,
'wp-admin/images/box-bg-right.gif' ,
'wp-admin/images/box-bg.gif' ,
'wp-admin/images/box-butt-left.gif' ,
'wp-admin/images/box-butt-right.gif' ,
'wp-admin/images/box-butt.gif' ,
'wp-admin/images/box-head-left.gif' ,
'wp-admin/images/box-head-right.gif' ,
'wp-admin/images/box-head.gif' ,
'wp-admin/images/heading-bg.gif' ,
'wp-admin/images/login-bkg-bottom.gif' ,
'wp-admin/images/login-bkg-tile.gif' ,
'wp-admin/images/notice.gif' ,
'wp-admin/images/toggle.gif' ,
'wp-admin/includes/upload.php' ,
'wp-admin/js/dbx-admin-key.js' ,
'wp-admin/js/link-cat.js' ,
'wp-admin/profile-update.php' ,
'wp-admin/templates.php' ,
'wp-includes/js/dbx.js' ,
'wp-includes/js/fat.js' ,
'wp-includes/js/list-manipulation.js' ,
'wp-includes/js/tinymce/langs/en.js' ,
'wp-includes/js/tinymce/plugins/directionality/images' ,
'wp-includes/js/tinymce/plugins/directionality/langs' ,
'wp-includes/js/tinymce/plugins/paste/images' ,
'wp-includes/js/tinymce/plugins/paste/jscripts' ,
'wp-includes/js/tinymce/plugins/paste/langs' ,
'wp-includes/js/tinymce/plugins/wordpress/images' ,
'wp-includes/js/tinymce/plugins/wordpress/langs' ,
'wp-includes/js/tinymce/plugins/wordpress/wordpress.css' ,
'wp-includes/js/tinymce/plugins/wphelp' ,
// 2.5.1
'wp-includes/js/tinymce/tiny_mce_gzip.php' ,
// 2.6
'wp-admin/bookmarklet.php' ,
'wp-includes/js/jquery/jquery.dimensions.min.js' ,
'wp-includes/js/tinymce/plugins/wordpress/popups.css' ,
'wp-includes/js/wp-ajax.js' ,
// 2.7
'wp-admin/css/press-this-ie-rtl.css' ,
'wp-admin/css/press-this-ie.css' ,
'wp-admin/css/upload-rtl.css' ,
'wp-admin/edit-form.php' ,
'wp-admin/images/comment-pill.gif' ,
'wp-admin/images/comment-stalk-classic.gif' ,
'wp-admin/images/comment-stalk-fresh.gif' ,
'wp-admin/images/comment-stalk-rtl.gif' ,
'wp-admin/images/del.png' ,
'wp-admin/images/gear.png' ,
'wp-admin/images/media-button-gallery.gif' ,
'wp-admin/images/media-buttons.gif' ,
'wp-admin/images/postbox-bg.gif' ,
'wp-admin/images/tab.png' ,
'wp-admin/images/tail.gif' ,
'wp-admin/js/forms.js' ,
'wp-admin/js/upload.js' ,
'wp-admin/link-import.php' ,
'wp-includes/images/audio.png' ,
'wp-includes/images/css.png' ,
'wp-includes/images/default.png' ,
'wp-includes/images/doc.png' ,
'wp-includes/images/exe.png' ,
'wp-includes/images/html.png' ,
'wp-includes/images/js.png' ,
'wp-includes/images/pdf.png' ,
'wp-includes/images/swf.png' ,
'wp-includes/images/tar.png' ,
'wp-includes/images/text.png' ,
'wp-includes/images/video.png' ,
'wp-includes/images/zip.png' ,
'wp-includes/js/tinymce/tiny_mce_config.php' ,
'wp-includes/js/tinymce/tiny_mce_ext.js' ,
// 2.8
'wp-admin/js/users.js' ,
'wp-includes/js/swfupload/swfupload_f9.swf' ,
'wp-includes/js/tinymce/plugins/autosave' ,
'wp-includes/js/tinymce/plugins/paste/css' ,
'wp-includes/js/tinymce/utils/mclayer.js' ,
'wp-includes/js/tinymce/wordpress.css' ,
// 2.9
'wp-admin/js/page.dev.js' ,
'wp-admin/js/page.js' ,
'wp-admin/js/set-post-thumbnail-handler.dev.js' ,
'wp-admin/js/set-post-thumbnail-handler.js' ,
'wp-admin/js/slug.dev.js' ,
'wp-admin/js/slug.js' ,
'wp-includes/gettext.php' ,
'wp-includes/js/tinymce/plugins/wordpress/js' ,
'wp-includes/streams.php' ,
// MU
'README.txt' ,
'htaccess.dist' ,
'index-install.php' ,
'wp-admin/css/mu-rtl.css' ,
'wp-admin/css/mu.css' ,
'wp-admin/images/site-admin.png' ,
'wp-admin/includes/mu.php' ,
'wp-admin/wpmu-admin.php' ,
'wp-admin/wpmu-blogs.php' ,
'wp-admin/wpmu-edit.php' ,
'wp-admin/wpmu-options.php' ,
'wp-admin/wpmu-themes.php' ,
'wp-admin/wpmu-upgrade-site.php' ,
'wp-admin/wpmu-users.php' ,
'wp-includes/images/wordpress-mu.png' ,
'wp-includes/wpmu-default-filters.php' ,
'wp-includes/wpmu-functions.php' ,
'wpmu-settings.php' ,
// 3.0
'wp-admin/categories.php' ,
'wp-admin/edit-category-form.php' ,
'wp-admin/edit-page-form.php' ,
'wp-admin/edit-pages.php' ,
'wp-admin/images/admin-header-footer.png' ,
'wp-admin/images/browse-happy.gif' ,
'wp-admin/images/ico-add.png' ,
'wp-admin/images/ico-close.png' ,
'wp-admin/images/ico-edit.png' ,
'wp-admin/images/ico-viewpage.png' ,
'wp-admin/images/fav-top.png' ,
'wp-admin/images/screen-options-left.gif' ,
'wp-admin/images/wp-logo-vs.gif' ,
'wp-admin/images/wp-logo.gif' ,
'wp-admin/import' ,
'wp-admin/js/wp-gears.dev.js' ,
'wp-admin/js/wp-gears.js' ,
'wp-admin/options-misc.php' ,
'wp-admin/page-new.php' ,
'wp-admin/page.php' ,
'wp-admin/rtl.css' ,
'wp-admin/rtl.dev.css' ,
'wp-admin/update-links.php' ,
'wp-admin/wp-admin.css' ,
'wp-admin/wp-admin.dev.css' ,
'wp-includes/js/codepress' ,
'wp-includes/js/jquery/autocomplete.dev.js' ,
'wp-includes/js/jquery/autocomplete.js' ,
'wp-includes/js/jquery/interface.js' ,
2020-01-28 19:45:18 -05:00
// Following file added back in 5.1, see #45645.
2019-01-19 05:23:50 -05:00
//'wp-includes/js/tinymce/wp-tinymce.js',
2017-11-30 18:11:00 -05:00
// 3.1
'wp-admin/edit-attachment-rows.php' ,
'wp-admin/edit-link-categories.php' ,
'wp-admin/edit-link-category-form.php' ,
'wp-admin/edit-post-rows.php' ,
'wp-admin/images/button-grad-active-vs.png' ,
'wp-admin/images/button-grad-vs.png' ,
'wp-admin/images/fav-arrow-vs-rtl.gif' ,
'wp-admin/images/fav-arrow-vs.gif' ,
'wp-admin/images/fav-top-vs.gif' ,
'wp-admin/images/list-vs.png' ,
'wp-admin/images/screen-options-right-up.gif' ,
'wp-admin/images/screen-options-right.gif' ,
'wp-admin/images/visit-site-button-grad-vs.gif' ,
'wp-admin/images/visit-site-button-grad.gif' ,
'wp-admin/link-category.php' ,
'wp-admin/sidebar.php' ,
'wp-includes/classes.php' ,
'wp-includes/js/tinymce/blank.htm' ,
'wp-includes/js/tinymce/plugins/media/img' ,
'wp-includes/js/tinymce/plugins/safari' ,
// 3.2
'wp-admin/images/logo-login.gif' ,
'wp-admin/images/star.gif' ,
'wp-admin/js/list-table.dev.js' ,
'wp-admin/js/list-table.js' ,
'wp-includes/default-embeds.php' ,
// 3.3
'wp-admin/css/colors-classic-rtl.css' ,
'wp-admin/css/colors-classic-rtl.dev.css' ,
'wp-admin/css/colors-fresh-rtl.css' ,
'wp-admin/css/colors-fresh-rtl.dev.css' ,
'wp-admin/css/dashboard-rtl.dev.css' ,
'wp-admin/css/dashboard.dev.css' ,
'wp-admin/css/global-rtl.css' ,
'wp-admin/css/global-rtl.dev.css' ,
'wp-admin/css/global.css' ,
'wp-admin/css/global.dev.css' ,
'wp-admin/css/install-rtl.dev.css' ,
'wp-admin/css/login-rtl.dev.css' ,
'wp-admin/css/login.dev.css' ,
'wp-admin/css/ms.css' ,
'wp-admin/css/ms.dev.css' ,
'wp-admin/css/nav-menu-rtl.css' ,
'wp-admin/css/nav-menu-rtl.dev.css' ,
'wp-admin/css/nav-menu.css' ,
'wp-admin/css/nav-menu.dev.css' ,
'wp-admin/css/plugin-install-rtl.css' ,
'wp-admin/css/plugin-install-rtl.dev.css' ,
'wp-admin/css/plugin-install.css' ,
'wp-admin/css/plugin-install.dev.css' ,
'wp-admin/css/press-this-rtl.dev.css' ,
'wp-admin/css/press-this.dev.css' ,
'wp-admin/css/theme-editor-rtl.css' ,
'wp-admin/css/theme-editor-rtl.dev.css' ,
'wp-admin/css/theme-editor.css' ,
'wp-admin/css/theme-editor.dev.css' ,
'wp-admin/css/theme-install-rtl.css' ,
'wp-admin/css/theme-install-rtl.dev.css' ,
'wp-admin/css/theme-install.css' ,
'wp-admin/css/theme-install.dev.css' ,
'wp-admin/css/widgets-rtl.dev.css' ,
'wp-admin/css/widgets.dev.css' ,
'wp-admin/includes/internal-linking.php' ,
'wp-includes/images/admin-bar-sprite-rtl.png' ,
'wp-includes/js/jquery/ui.button.js' ,
'wp-includes/js/jquery/ui.core.js' ,
'wp-includes/js/jquery/ui.dialog.js' ,
'wp-includes/js/jquery/ui.draggable.js' ,
'wp-includes/js/jquery/ui.droppable.js' ,
'wp-includes/js/jquery/ui.mouse.js' ,
'wp-includes/js/jquery/ui.position.js' ,
'wp-includes/js/jquery/ui.resizable.js' ,
'wp-includes/js/jquery/ui.selectable.js' ,
'wp-includes/js/jquery/ui.sortable.js' ,
'wp-includes/js/jquery/ui.tabs.js' ,
'wp-includes/js/jquery/ui.widget.js' ,
'wp-includes/js/l10n.dev.js' ,
'wp-includes/js/l10n.js' ,
'wp-includes/js/tinymce/plugins/wplink/css' ,
'wp-includes/js/tinymce/plugins/wplink/img' ,
'wp-includes/js/tinymce/plugins/wplink/js' ,
// Don't delete, yet: 'wp-rss.php',
// Don't delete, yet: 'wp-rdf.php',
// Don't delete, yet: 'wp-rss2.php',
// Don't delete, yet: 'wp-commentsrss2.php',
// Don't delete, yet: 'wp-atom.php',
// Don't delete, yet: 'wp-feed.php',
// 3.4
'wp-admin/images/gray-star.png' ,
'wp-admin/images/logo-login.png' ,
'wp-admin/images/star.png' ,
'wp-admin/index-extra.php' ,
'wp-admin/network/index-extra.php' ,
'wp-admin/user/index-extra.php' ,
'wp-includes/css/editor-buttons.css' ,
'wp-includes/css/editor-buttons.dev.css' ,
'wp-includes/js/tinymce/plugins/paste/blank.htm' ,
'wp-includes/js/tinymce/plugins/wordpress/css' ,
'wp-includes/js/tinymce/plugins/wordpress/editor_plugin.dev.js' ,
'wp-includes/js/tinymce/plugins/wpdialogs/editor_plugin.dev.js' ,
'wp-includes/js/tinymce/plugins/wpeditimage/editor_plugin.dev.js' ,
'wp-includes/js/tinymce/plugins/wpgallery/editor_plugin.dev.js' ,
'wp-includes/js/tinymce/plugins/wplink/editor_plugin.dev.js' ,
// Don't delete, yet: 'wp-pass.php',
// Don't delete, yet: 'wp-register.php',
// 3.5
'wp-admin/gears-manifest.php' ,
'wp-admin/includes/manifest.php' ,
'wp-admin/images/archive-link.png' ,
'wp-admin/images/blue-grad.png' ,
'wp-admin/images/button-grad-active.png' ,
'wp-admin/images/button-grad.png' ,
'wp-admin/images/ed-bg-vs.gif' ,
'wp-admin/images/ed-bg.gif' ,
'wp-admin/images/fade-butt.png' ,
'wp-admin/images/fav-arrow-rtl.gif' ,
'wp-admin/images/fav-arrow.gif' ,
'wp-admin/images/fav-vs.png' ,
'wp-admin/images/fav.png' ,
'wp-admin/images/gray-grad.png' ,
'wp-admin/images/loading-publish.gif' ,
'wp-admin/images/logo-ghost.png' ,
'wp-admin/images/logo.gif' ,
'wp-admin/images/menu-arrow-frame-rtl.png' ,
'wp-admin/images/menu-arrow-frame.png' ,
'wp-admin/images/menu-arrows.gif' ,
'wp-admin/images/menu-bits-rtl-vs.gif' ,
'wp-admin/images/menu-bits-rtl.gif' ,
'wp-admin/images/menu-bits-vs.gif' ,
'wp-admin/images/menu-bits.gif' ,
'wp-admin/images/menu-dark-rtl-vs.gif' ,
'wp-admin/images/menu-dark-rtl.gif' ,
'wp-admin/images/menu-dark-vs.gif' ,
'wp-admin/images/menu-dark.gif' ,
'wp-admin/images/required.gif' ,
'wp-admin/images/screen-options-toggle-vs.gif' ,
'wp-admin/images/screen-options-toggle.gif' ,
'wp-admin/images/toggle-arrow-rtl.gif' ,
'wp-admin/images/toggle-arrow.gif' ,
'wp-admin/images/upload-classic.png' ,
'wp-admin/images/upload-fresh.png' ,
'wp-admin/images/white-grad-active.png' ,
'wp-admin/images/white-grad.png' ,
'wp-admin/images/widgets-arrow-vs.gif' ,
'wp-admin/images/widgets-arrow.gif' ,
'wp-admin/images/wpspin_dark.gif' ,
'wp-includes/images/upload.png' ,
'wp-includes/js/prototype.js' ,
'wp-includes/js/scriptaculous' ,
'wp-admin/css/wp-admin-rtl.dev.css' ,
'wp-admin/css/wp-admin.dev.css' ,
'wp-admin/css/media-rtl.dev.css' ,
'wp-admin/css/media.dev.css' ,
'wp-admin/css/colors-classic.dev.css' ,
'wp-admin/css/customize-controls-rtl.dev.css' ,
'wp-admin/css/customize-controls.dev.css' ,
'wp-admin/css/ie-rtl.dev.css' ,
'wp-admin/css/ie.dev.css' ,
'wp-admin/css/install.dev.css' ,
'wp-admin/css/colors-fresh.dev.css' ,
'wp-includes/js/customize-base.dev.js' ,
'wp-includes/js/json2.dev.js' ,
'wp-includes/js/comment-reply.dev.js' ,
'wp-includes/js/customize-preview.dev.js' ,
'wp-includes/js/wplink.dev.js' ,
'wp-includes/js/tw-sack.dev.js' ,
'wp-includes/js/wp-list-revisions.dev.js' ,
'wp-includes/js/autosave.dev.js' ,
'wp-includes/js/admin-bar.dev.js' ,
'wp-includes/js/quicktags.dev.js' ,
'wp-includes/js/wp-ajax-response.dev.js' ,
'wp-includes/js/wp-pointer.dev.js' ,
'wp-includes/js/hoverIntent.dev.js' ,
'wp-includes/js/colorpicker.dev.js' ,
'wp-includes/js/wp-lists.dev.js' ,
'wp-includes/js/customize-loader.dev.js' ,
'wp-includes/js/jquery/jquery.table-hotkeys.dev.js' ,
'wp-includes/js/jquery/jquery.color.dev.js' ,
'wp-includes/js/jquery/jquery.color.js' ,
'wp-includes/js/jquery/jquery.hotkeys.dev.js' ,
'wp-includes/js/jquery/jquery.form.dev.js' ,
'wp-includes/js/jquery/suggest.dev.js' ,
'wp-admin/js/xfn.dev.js' ,
'wp-admin/js/set-post-thumbnail.dev.js' ,
'wp-admin/js/comment.dev.js' ,
'wp-admin/js/theme.dev.js' ,
'wp-admin/js/cat.dev.js' ,
'wp-admin/js/password-strength-meter.dev.js' ,
'wp-admin/js/user-profile.dev.js' ,
'wp-admin/js/theme-preview.dev.js' ,
'wp-admin/js/post.dev.js' ,
'wp-admin/js/media-upload.dev.js' ,
'wp-admin/js/word-count.dev.js' ,
'wp-admin/js/plugin-install.dev.js' ,
'wp-admin/js/edit-comments.dev.js' ,
'wp-admin/js/media-gallery.dev.js' ,
'wp-admin/js/custom-fields.dev.js' ,
'wp-admin/js/custom-background.dev.js' ,
'wp-admin/js/common.dev.js' ,
'wp-admin/js/inline-edit-tax.dev.js' ,
'wp-admin/js/gallery.dev.js' ,
'wp-admin/js/utils.dev.js' ,
'wp-admin/js/widgets.dev.js' ,
'wp-admin/js/wp-fullscreen.dev.js' ,
'wp-admin/js/nav-menu.dev.js' ,
'wp-admin/js/dashboard.dev.js' ,
'wp-admin/js/link.dev.js' ,
'wp-admin/js/user-suggest.dev.js' ,
'wp-admin/js/postbox.dev.js' ,
'wp-admin/js/tags.dev.js' ,
'wp-admin/js/image-edit.dev.js' ,
'wp-admin/js/media.dev.js' ,
'wp-admin/js/customize-controls.dev.js' ,
'wp-admin/js/inline-edit-post.dev.js' ,
'wp-admin/js/categories.dev.js' ,
'wp-admin/js/editor.dev.js' ,
'wp-includes/js/plupload/handlers.dev.js' ,
'wp-includes/js/plupload/wp-plupload.dev.js' ,
'wp-includes/js/swfupload/handlers.dev.js' ,
'wp-includes/js/jcrop/jquery.Jcrop.dev.js' ,
'wp-includes/js/jcrop/jquery.Jcrop.js' ,
'wp-includes/js/jcrop/jquery.Jcrop.css' ,
'wp-includes/js/imgareaselect/jquery.imgareaselect.dev.js' ,
'wp-includes/css/wp-pointer.dev.css' ,
'wp-includes/css/editor.dev.css' ,
'wp-includes/css/jquery-ui-dialog.dev.css' ,
'wp-includes/css/admin-bar-rtl.dev.css' ,
'wp-includes/css/admin-bar.dev.css' ,
'wp-includes/js/jquery/ui/jquery.effects.clip.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.scale.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.blind.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.core.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.shake.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.fade.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.explode.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.slide.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.drop.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.highlight.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.bounce.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.pulsate.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.transfer.min.js' ,
'wp-includes/js/jquery/ui/jquery.effects.fold.min.js' ,
'wp-admin/js/utils.js' ,
2020-01-28 19:45:18 -05:00
// Added back in 5.3 [45448], see #43895.
2019-05-26 23:03:52 -04:00
// 'wp-admin/options-privacy.php',
2017-11-30 18:11:00 -05:00
'wp-app.php' ,
'wp-includes/class-wp-atom-server.php' ,
// 3.5.2
'wp-includes/js/swfupload/swfupload-all.js' ,
// 3.6
'wp-admin/js/revisions-js.php' ,
'wp-admin/images/screenshots' ,
'wp-admin/js/categories.js' ,
'wp-admin/js/categories.min.js' ,
'wp-admin/js/custom-fields.js' ,
'wp-admin/js/custom-fields.min.js' ,
// 3.7
'wp-admin/js/cat.js' ,
'wp-admin/js/cat.min.js' ,
// 3.8
'wp-includes/js/thickbox/tb-close-2x.png' ,
'wp-includes/js/thickbox/tb-close.png' ,
'wp-includes/images/wpmini-blue-2x.png' ,
'wp-includes/images/wpmini-blue.png' ,
'wp-admin/css/colors-fresh.css' ,
'wp-admin/css/colors-classic.css' ,
'wp-admin/css/colors-fresh.min.css' ,
'wp-admin/css/colors-classic.min.css' ,
'wp-admin/js/about.min.js' ,
'wp-admin/js/about.js' ,
'wp-admin/images/arrows-dark-vs-2x.png' ,
'wp-admin/images/wp-logo-vs.png' ,
'wp-admin/images/arrows-dark-vs.png' ,
'wp-admin/images/wp-logo.png' ,
'wp-admin/images/arrows-pr.png' ,
'wp-admin/images/arrows-dark.png' ,
'wp-admin/images/press-this.png' ,
'wp-admin/images/press-this-2x.png' ,
'wp-admin/images/arrows-vs-2x.png' ,
'wp-admin/images/welcome-icons.png' ,
'wp-admin/images/wp-logo-2x.png' ,
'wp-admin/images/stars-rtl-2x.png' ,
'wp-admin/images/arrows-dark-2x.png' ,
'wp-admin/images/arrows-pr-2x.png' ,
'wp-admin/images/menu-shadow-rtl.png' ,
'wp-admin/images/arrows-vs.png' ,
'wp-admin/images/about-search-2x.png' ,
'wp-admin/images/bubble_bg-rtl-2x.gif' ,
'wp-admin/images/wp-badge-2x.png' ,
'wp-admin/images/wordpress-logo-2x.png' ,
'wp-admin/images/bubble_bg-rtl.gif' ,
'wp-admin/images/wp-badge.png' ,
'wp-admin/images/menu-shadow.png' ,
'wp-admin/images/about-globe-2x.png' ,
'wp-admin/images/welcome-icons-2x.png' ,
'wp-admin/images/stars-rtl.png' ,
'wp-admin/images/wp-logo-vs-2x.png' ,
'wp-admin/images/about-updates-2x.png' ,
// 3.9
'wp-admin/css/colors.css' ,
'wp-admin/css/colors.min.css' ,
'wp-admin/css/colors-rtl.css' ,
'wp-admin/css/colors-rtl.min.css' ,
2020-01-28 19:45:18 -05:00
// Following files added back in 4.5, see #36083.
2017-11-30 18:11:00 -05:00
// 'wp-admin/css/media-rtl.min.css',
// 'wp-admin/css/media.min.css',
// 'wp-admin/css/farbtastic-rtl.min.css',
'wp-admin/images/lock-2x.png' ,
'wp-admin/images/lock.png' ,
'wp-admin/js/theme-preview.js' ,
'wp-admin/js/theme-install.min.js' ,
'wp-admin/js/theme-install.js' ,
'wp-admin/js/theme-preview.min.js' ,
'wp-includes/js/plupload/plupload.html4.js' ,
'wp-includes/js/plupload/plupload.html5.js' ,
'wp-includes/js/plupload/changelog.txt' ,
'wp-includes/js/plupload/plupload.silverlight.js' ,
'wp-includes/js/plupload/plupload.flash.js' ,
2020-01-28 19:45:18 -05:00
// Added back in 4.9 [41328], see #41755.
2017-11-30 18:11:00 -05:00
// 'wp-includes/js/plupload/plupload.js',
'wp-includes/js/tinymce/plugins/spellchecker' ,
'wp-includes/js/tinymce/plugins/inlinepopups' ,
'wp-includes/js/tinymce/plugins/media/js' ,
'wp-includes/js/tinymce/plugins/media/css' ,
'wp-includes/js/tinymce/plugins/wordpress/img' ,
'wp-includes/js/tinymce/plugins/wpdialogs/js' ,
'wp-includes/js/tinymce/plugins/wpeditimage/img' ,
'wp-includes/js/tinymce/plugins/wpeditimage/js' ,
'wp-includes/js/tinymce/plugins/wpeditimage/css' ,
'wp-includes/js/tinymce/plugins/wpgallery/img' ,
'wp-includes/js/tinymce/plugins/paste/js' ,
'wp-includes/js/tinymce/themes/advanced' ,
'wp-includes/js/tinymce/tiny_mce.js' ,
'wp-includes/js/tinymce/mark_loaded_src.js' ,
'wp-includes/js/tinymce/wp-tinymce-schema.js' ,
'wp-includes/js/tinymce/plugins/media/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/media/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/media/media.htm' ,
'wp-includes/js/tinymce/plugins/wpview/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wpview/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/directionality/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/directionality/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wordpress/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/wordpress/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wpdialogs/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wpdialogs/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/wpeditimage/editimage.html' ,
'wp-includes/js/tinymce/plugins/wpeditimage/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/wpeditimage/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/fullscreen/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/fullscreen/fullscreen.htm' ,
'wp-includes/js/tinymce/plugins/fullscreen/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/wplink/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wplink/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/wpgallery/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/wpgallery/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/tabfocus/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/tabfocus/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/paste/editor_plugin.js' ,
'wp-includes/js/tinymce/plugins/paste/pasteword.htm' ,
'wp-includes/js/tinymce/plugins/paste/editor_plugin_src.js' ,
'wp-includes/js/tinymce/plugins/paste/pastetext.htm' ,
'wp-includes/js/tinymce/langs/wp-langs.php' ,
// 4.1
'wp-includes/js/jquery/ui/jquery.ui.accordion.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.autocomplete.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.button.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.core.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.datepicker.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.dialog.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.draggable.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.droppable.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-blind.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-bounce.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-clip.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-drop.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-explode.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-fade.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-fold.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-highlight.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-pulsate.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-scale.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-shake.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-slide.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect-transfer.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.effect.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.menu.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.mouse.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.position.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.progressbar.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.resizable.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.selectable.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.slider.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.sortable.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.spinner.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.tabs.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.tooltip.min.js' ,
'wp-includes/js/jquery/ui/jquery.ui.widget.min.js' ,
'wp-includes/js/tinymce/skins/wordpress/images/dashicon-no-alt.png' ,
// 4.3
'wp-admin/js/wp-fullscreen.js' ,
'wp-admin/js/wp-fullscreen.min.js' ,
'wp-includes/js/tinymce/wp-mce-help.php' ,
'wp-includes/js/tinymce/plugins/wpfullscreen' ,
// 4.5
'wp-includes/theme-compat/comments-popup.php' ,
// 4.6
'wp-admin/includes/class-wp-automatic-upgrader.php' , // Wrong file name, see #37628.
// 4.8
'wp-includes/js/tinymce/plugins/wpembed' ,
'wp-includes/js/tinymce/plugins/media/moxieplayer.swf' ,
'wp-includes/js/tinymce/skins/lightgray/fonts/readme.md' ,
'wp-includes/js/tinymce/skins/lightgray/fonts/tinymce-small.json' ,
'wp-includes/js/tinymce/skins/lightgray/fonts/tinymce.json' ,
'wp-includes/js/tinymce/skins/lightgray/skin.ie7.min.css' ,
// 4.9
'wp-admin/css/press-this-editor-rtl.css' ,
'wp-admin/css/press-this-editor-rtl.min.css' ,
'wp-admin/css/press-this-editor.css' ,
'wp-admin/css/press-this-editor.min.css' ,
'wp-admin/css/press-this-rtl.css' ,
'wp-admin/css/press-this-rtl.min.css' ,
'wp-admin/css/press-this.css' ,
'wp-admin/css/press-this.min.css' ,
'wp-admin/includes/class-wp-press-this.php' ,
'wp-admin/js/bookmarklet.js' ,
'wp-admin/js/bookmarklet.min.js' ,
'wp-admin/js/press-this.js' ,
'wp-admin/js/press-this.min.js' ,
'wp-includes/js/mediaelement/background.png' ,
'wp-includes/js/mediaelement/bigplay.png' ,
'wp-includes/js/mediaelement/bigplay.svg' ,
'wp-includes/js/mediaelement/controls.png' ,
'wp-includes/js/mediaelement/controls.svg' ,
'wp-includes/js/mediaelement/flashmediaelement.swf' ,
'wp-includes/js/mediaelement/froogaloop.min.js' ,
'wp-includes/js/mediaelement/jumpforward.png' ,
'wp-includes/js/mediaelement/loading.gif' ,
'wp-includes/js/mediaelement/silverlightmediaelement.xap' ,
'wp-includes/js/mediaelement/skipback.png' ,
'wp-includes/js/plupload/plupload.flash.swf' ,
'wp-includes/js/plupload/plupload.full.min.js' ,
'wp-includes/js/plupload/plupload.silverlight.xap' ,
'wp-includes/js/swfupload/plugins' ,
'wp-includes/js/swfupload/swfupload.swf' ,
2018-01-16 01:28:43 -05:00
// 4.9.2
'wp-includes/js/mediaelement/lang' ,
'wp-includes/js/mediaelement/mediaelement-flash-audio-ogg.swf' ,
'wp-includes/js/mediaelement/mediaelement-flash-audio.swf' ,
'wp-includes/js/mediaelement/mediaelement-flash-video-hls.swf' ,
'wp-includes/js/mediaelement/mediaelement-flash-video-mdash.swf' ,
'wp-includes/js/mediaelement/mediaelement-flash-video.swf' ,
'wp-includes/js/mediaelement/renderers/dailymotion.js' ,
'wp-includes/js/mediaelement/renderers/dailymotion.min.js' ,
'wp-includes/js/mediaelement/renderers/facebook.js' ,
'wp-includes/js/mediaelement/renderers/facebook.min.js' ,
'wp-includes/js/mediaelement/renderers/soundcloud.js' ,
'wp-includes/js/mediaelement/renderers/soundcloud.min.js' ,
'wp-includes/js/mediaelement/renderers/twitch.js' ,
'wp-includes/js/mediaelement/renderers/twitch.min.js' ,
Remove JSHint due to license compatibility
JSHint inherits a license from JSLint that includes the clause "The Software shall be used for Good, not Evil." WordPress's license specifically allows grants the freedom to run the program, for any purpose. Please note, this is not an encouragement of evil. Rather than doing something evil, how about learning to love those around you. Instead of tweeting lies and saying people are "Not Good!", help your neighbor. In the words of Lin Manual Miranda, "Love is love is love is love is love is love is love is love, cannot be killed or swept aside."
This replaces JSHint with esprima, a part of the larger jQuery project, and a custom wrapper for some basic error checking within codemirror.
The existing JSHint configuration is kept in place in case someone wants to use that, but they can only do so for Good.
Fixes #42850
Props netweb for a spelling fix on a comment.
Built from https://develop.svn.wordpress.org/trunk@42547
git-svn-id: http://core.svn.wordpress.org/trunk@42376 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2018-01-22 20:29:32 -05:00
// 5.0
'wp-includes/js/codemirror/jshint.js' ,
2019-01-19 05:23:50 -05:00
// 5.1
'wp-includes/js/tinymce/wp-tinymce.js.gz' ,
2019-09-18 13:41:55 -04:00
// 5.3
2020-01-28 19:45:18 -05:00
'wp-includes/js/wp-a11y.js' , // Moved to: wp-includes/js/dist/a11y.js
2019-09-18 13:41:55 -04:00
'wp-includes/js/wp-a11y.min.js' , // Moved to: wp-includes/js/dist/a11y.min.js
2020-02-01 23:15:03 -05:00
// 5.4
'wp-admin/js/wp-fullscreen-stub.js' ,
'wp-admin/js/wp-fullscreen-stub.min.js' ,
Administration: Remove any CSS related to Internet Explorer versions 6 – 10.
In WordPress 3.2 support for IE6 was dropped, IE7 followed a few versions later. With the 4.8 release, WordPress officially ended support for Internet Explorer versions 8, 9, and 10. Yet, we still have shipped CSS for the unsupported IE versions....until now! Goodbye to ie.css and star hacks!
* Removes ie.css and `ie` style handle.
* Removes IE specific class names and any related CSS.
* Drops support for IE8 and older in `wp_customize_support_script()`.
* Updates compatibility mode for CSS minification to `ie11`.
Props ayeshrajans, isabel_brison, afercia, netweb, peterwilsoncc, ocean90.
Fixes #17232, #46015.
Built from https://develop.svn.wordpress.org/trunk@47771
git-svn-id: http://core.svn.wordpress.org/trunk@47547 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2020-05-06 16:15:07 -04:00
// 5.5
'wp-admin/css/ie.css' ,
'wp-admin/css/ie.min.css' ,
'wp-admin/css/ie-rtl.css' ,
'wp-admin/css/ie-rtl.min.css' ,
2020-12-08 16:50:07 -05:00
// 5.6
'wp-includes/js/jquery/ui/position.min.js' ,
'wp-includes/js/jquery/ui/widget.min.js' ,
2021-03-08 13:30:07 -05:00
// 5.7
'wp-includes/blocks/classic/block.json' ,
2021-06-09 11:54:57 -04:00
// 5.8
2021-07-18 20:59:57 -04:00
'wp-admin/images/freedoms.png' ,
'wp-admin/images/privacy.png' ,
'wp-admin/images/about-badge.svg' ,
'wp-admin/images/about-color-palette.svg' ,
'wp-admin/images/about-color-palette-vert.svg' ,
'wp-admin/images/about-header-brushes.svg' ,
2021-06-09 11:54:57 -04:00
'wp-includes/block-patterns/large-header.php' ,
'wp-includes/block-patterns/heading-paragraph.php' ,
'wp-includes/block-patterns/quote.php' ,
'wp-includes/block-patterns/text-three-columns-buttons.php' ,
'wp-includes/block-patterns/two-buttons.php' ,
'wp-includes/block-patterns/two-images.php' ,
'wp-includes/block-patterns/three-buttons.php' ,
'wp-includes/block-patterns/text-two-columns-with-images.php' ,
'wp-includes/block-patterns/text-two-columns.php' ,
'wp-includes/block-patterns/large-header-button.php' ,
'wp-includes/blocks/subhead' ,
2021-07-27 09:57:57 -04:00
'wp-includes/css/dist/editor/editor-styles.css' ,
'wp-includes/css/dist/editor/editor-styles.min.css' ,
'wp-includes/css/dist/editor/editor-styles-rtl.css' ,
'wp-includes/css/dist/editor/editor-styles-rtl.min.css' ,
2022-01-24 13:24:02 -05:00
// 5.9
'wp-includes/blocks/heading/editor.css' ,
'wp-includes/blocks/heading/editor.min.css' ,
'wp-includes/blocks/heading/editor-rtl.css' ,
'wp-includes/blocks/heading/editor-rtl.min.css' ,
'wp-includes/blocks/query-title/editor.css' ,
'wp-includes/blocks/query-title/editor.min.css' ,
'wp-includes/blocks/query-title/editor-rtl.css' ,
'wp-includes/blocks/query-title/editor-rtl.min.css' ,
'wp-includes/blocks/tag-cloud/editor.css' ,
'wp-includes/blocks/tag-cloud/editor.min.css' ,
'wp-includes/blocks/tag-cloud/editor-rtl.css' ,
'wp-includes/blocks/tag-cloud/editor-rtl.min.css' ,
2022-10-31 11:18:14 -04:00
// 6.1
'wp-includes/blocks/post-comments.php' ,
'wp-includes/blocks/post-comments' ,
2022-11-14 13:24:12 -05:00
'wp-includes/blocks/comments-query-loop' ,
2023-04-04 13:37:25 -04:00
// 6.3
'wp-includes/images/wlw' ,
'wp-includes/wlwmanifest.xml' ,
2023-08-07 13:21:29 -04:00
'wp-includes/random_compat' ,
Editor: Move `wp_navigation` schema updating to `WP_Navigation_Fallback` class.
This aims to better align the navigation fallback implementation with core architecture and best practices.
The function that updates the `wp_navigation` post response schema is now a public method of the `WP_Navigation_Fallback` class, so an extra file previously used for that specific function is no longer necessary.
Follow-up to [56052].
Props ramonopoly, scruffian, isabel_brison, mukesh27, swissspidy, rajinsharwar, afercia, audrasjb, mikeschroder, JeffPaul, johnjamesjacoby, TimothyBlynJacobs, oglekler, SergeyBiryukov.
Fixes #58910.
Built from https://develop.svn.wordpress.org/trunk@56793
git-svn-id: http://core.svn.wordpress.org/trunk@56305 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2023-10-06 10:06:22 -04:00
// 6.4
'wp-includes/navigation-fallback.php' ,
2023-11-06 12:49:25 -05:00
'wp-includes/blocks/navigation/view-modal.min.js' ,
'wp-includes/blocks/navigation/view-modal.js' ,
2024-04-01 12:38:18 -04:00
// 6.5
'wp-includes/ID3/license.commercial.txt' ,
'wp-includes/blocks/query/style-rtl.min.css' ,
'wp-includes/blocks/query/style.min.css' ,
'wp-includes/blocks/query/style-rtl.css' ,
'wp-includes/blocks/query/style.css' ,
'wp-admin/images/about-header-privacy.svg' ,
'wp-admin/images/about-header-about.svg' ,
'wp-admin/images/about-header-credits.svg' ,
'wp-admin/images/about-header-freedoms.svg' ,
'wp-admin/images/about-header-contribute.svg' ,
'wp-admin/images/about-header-background.svg' ,
2024-07-17 09:35:15 -04:00
// 6.6
'wp-includes/blocks/block/editor.css' ,
'wp-includes/blocks/block/editor.min.css' ,
'wp-includes/blocks/block/editor-rtl.css' ,
'wp-includes/blocks/block/editor-rtl.min.css' ,
2008-08-08 21:00:27 -04:00
);
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
/**
* Stores Requests files to be preloaded and deleted .
*
* For classes / interfaces , use the class / interface name
* as the array key .
*
* All other files / directories should not have a key .
*
* @ since 6.2 . 0
*
* @ global array $_old_requests_files
* @ var array
* @ name $_old_requests_files
*/
global $_old_requests_files ;
$_old_requests_files = array (
// Interfaces.
'Requests_Auth' => 'wp-includes/Requests/Auth.php' ,
'Requests_Hooker' => 'wp-includes/Requests/Hooker.php' ,
'Requests_Proxy' => 'wp-includes/Requests/Proxy.php' ,
'Requests_Transport' => 'wp-includes/Requests/Transport.php' ,
// Classes.
'Requests_Auth_Basic' => 'wp-includes/Requests/Auth/Basic.php' ,
'Requests_Cookie_Jar' => 'wp-includes/Requests/Cookie/Jar.php' ,
'Requests_Exception_HTTP' => 'wp-includes/Requests/Exception/HTTP.php' ,
'Requests_Exception_Transport' => 'wp-includes/Requests/Exception/Transport.php' ,
'Requests_Exception_HTTP_304' => 'wp-includes/Requests/Exception/HTTP/304.php' ,
'Requests_Exception_HTTP_305' => 'wp-includes/Requests/Exception/HTTP/305.php' ,
'Requests_Exception_HTTP_306' => 'wp-includes/Requests/Exception/HTTP/306.php' ,
'Requests_Exception_HTTP_400' => 'wp-includes/Requests/Exception/HTTP/400.php' ,
'Requests_Exception_HTTP_401' => 'wp-includes/Requests/Exception/HTTP/401.php' ,
'Requests_Exception_HTTP_402' => 'wp-includes/Requests/Exception/HTTP/402.php' ,
'Requests_Exception_HTTP_403' => 'wp-includes/Requests/Exception/HTTP/403.php' ,
'Requests_Exception_HTTP_404' => 'wp-includes/Requests/Exception/HTTP/404.php' ,
'Requests_Exception_HTTP_405' => 'wp-includes/Requests/Exception/HTTP/405.php' ,
'Requests_Exception_HTTP_406' => 'wp-includes/Requests/Exception/HTTP/406.php' ,
'Requests_Exception_HTTP_407' => 'wp-includes/Requests/Exception/HTTP/407.php' ,
'Requests_Exception_HTTP_408' => 'wp-includes/Requests/Exception/HTTP/408.php' ,
'Requests_Exception_HTTP_409' => 'wp-includes/Requests/Exception/HTTP/409.php' ,
'Requests_Exception_HTTP_410' => 'wp-includes/Requests/Exception/HTTP/410.php' ,
'Requests_Exception_HTTP_411' => 'wp-includes/Requests/Exception/HTTP/411.php' ,
'Requests_Exception_HTTP_412' => 'wp-includes/Requests/Exception/HTTP/412.php' ,
'Requests_Exception_HTTP_413' => 'wp-includes/Requests/Exception/HTTP/413.php' ,
'Requests_Exception_HTTP_414' => 'wp-includes/Requests/Exception/HTTP/414.php' ,
'Requests_Exception_HTTP_415' => 'wp-includes/Requests/Exception/HTTP/415.php' ,
'Requests_Exception_HTTP_416' => 'wp-includes/Requests/Exception/HTTP/416.php' ,
'Requests_Exception_HTTP_417' => 'wp-includes/Requests/Exception/HTTP/417.php' ,
'Requests_Exception_HTTP_418' => 'wp-includes/Requests/Exception/HTTP/418.php' ,
'Requests_Exception_HTTP_428' => 'wp-includes/Requests/Exception/HTTP/428.php' ,
'Requests_Exception_HTTP_429' => 'wp-includes/Requests/Exception/HTTP/429.php' ,
'Requests_Exception_HTTP_431' => 'wp-includes/Requests/Exception/HTTP/431.php' ,
'Requests_Exception_HTTP_500' => 'wp-includes/Requests/Exception/HTTP/500.php' ,
'Requests_Exception_HTTP_501' => 'wp-includes/Requests/Exception/HTTP/501.php' ,
'Requests_Exception_HTTP_502' => 'wp-includes/Requests/Exception/HTTP/502.php' ,
'Requests_Exception_HTTP_503' => 'wp-includes/Requests/Exception/HTTP/503.php' ,
'Requests_Exception_HTTP_504' => 'wp-includes/Requests/Exception/HTTP/504.php' ,
'Requests_Exception_HTTP_505' => 'wp-includes/Requests/Exception/HTTP/505.php' ,
'Requests_Exception_HTTP_511' => 'wp-includes/Requests/Exception/HTTP/511.php' ,
'Requests_Exception_HTTP_Unknown' => 'wp-includes/Requests/Exception/HTTP/Unknown.php' ,
'Requests_Exception_Transport_cURL' => 'wp-includes/Requests/Exception/Transport/cURL.php' ,
'Requests_Proxy_HTTP' => 'wp-includes/Requests/Proxy/HTTP.php' ,
'Requests_Response_Headers' => 'wp-includes/Requests/Response/Headers.php' ,
'Requests_Transport_cURL' => 'wp-includes/Requests/Transport/cURL.php' ,
'Requests_Transport_fsockopen' => 'wp-includes/Requests/Transport/fsockopen.php' ,
'Requests_Utility_CaseInsensitiveDictionary' => 'wp-includes/Requests/Utility/CaseInsensitiveDictionary.php' ,
'Requests_Utility_FilteredIterator' => 'wp-includes/Requests/Utility/FilteredIterator.php' ,
'Requests_Cookie' => 'wp-includes/Requests/Cookie.php' ,
'Requests_Exception' => 'wp-includes/Requests/Exception.php' ,
'Requests_Hooks' => 'wp-includes/Requests/Hooks.php' ,
'Requests_IDNAEncoder' => 'wp-includes/Requests/IDNAEncoder.php' ,
'Requests_IPv6' => 'wp-includes/Requests/IPv6.php' ,
'Requests_IRI' => 'wp-includes/Requests/IRI.php' ,
'Requests_Response' => 'wp-includes/Requests/Response.php' ,
'Requests_SSL' => 'wp-includes/Requests/SSL.php' ,
'Requests_Session' => 'wp-includes/Requests/Session.php' ,
// Directories.
'wp-includes/Requests/Auth/' ,
'wp-includes/Requests/Cookie/' ,
'wp-includes/Requests/Exception/HTTP/' ,
'wp-includes/Requests/Exception/Transport/' ,
'wp-includes/Requests/Exception/' ,
'wp-includes/Requests/Proxy/' ,
'wp-includes/Requests/Response/' ,
'wp-includes/Requests/Transport/' ,
'wp-includes/Requests/Utility/' ,
);
2011-03-31 09:28:36 -04:00
/**
* Stores new files in wp - content to copy
*
* The contents of this array indicate any new bundled plugins / themes which
* should be installed with the WordPress Upgrade . These items will not be
2022-10-21 17:12:14 -04:00
* re - installed in future upgrades , this behavior is controlled by the
2011-03-31 09:28:36 -04:00
* introduced version present here being older than the current installed version .
*
* The content of this array should follow the following format :
2011-12-14 12:36:38 -05:00
* Filename ( relative to wp - content ) => Introduced version
2011-03-31 09:28:36 -04:00
* Directories should be noted by suffixing it with a trailing slash ( / )
*
2011-06-11 00:40:18 -04:00
* @ since 3.2 . 0
2016-10-31 21:24:35 -04:00
* @ since 4.7 . 0 New themes were not automatically installed for 4.4 - 4.6 on
* upgrade . New themes are now installed again . To disable new
* themes from being installed on upgrade , explicitly define
2019-12-23 13:00:02 -05:00
* CORE_UPGRADE_SKIP_NEW_BUNDLED as true .
2011-03-31 09:28:36 -04:00
* @ global array $_new_bundled_files
* @ var array
* @ name $_new_bundled_files
*/
global $_new_bundled_files ;
$_new_bundled_files = array (
2022-09-19 21:36:09 -04:00
'plugins/akismet/' => '2.0' ,
'themes/twentyten/' => '3.0' ,
'themes/twentyeleven/' => '3.2' ,
'themes/twentytwelve/' => '3.5' ,
'themes/twentythirteen/' => '3.6' ,
'themes/twentyfourteen/' => '3.8' ,
'themes/twentyfifteen/' => '4.1' ,
'themes/twentysixteen/' => '4.4' ,
'themes/twentyseventeen/' => '4.7' ,
'themes/twentynineteen/' => '5.0' ,
'themes/twentytwenty/' => '5.3' ,
'themes/twentytwentyone/' => '5.6' ,
'themes/twentytwentytwo/' => '5.9' ,
'themes/twentytwentythree/' => '6.1' ,
2023-09-26 13:33:20 -04:00
'themes/twentytwentyfour/' => '6.4' ,
2011-03-31 09:28:36 -04:00
);
2008-08-14 02:30:38 -04:00
/**
2016-05-22 13:22:27 -04:00
* Upgrades the core of WordPress .
2008-08-14 02:30:38 -04:00
*
* This will create a . maintenance file at the base of the WordPress directory
2023-11-22 12:44:24 -05:00
* to ensure that people can not access the website , when the files are being
2008-08-14 02:30:38 -04:00
* copied to their locations .
*
2016-05-22 13:22:27 -04:00
* The files in the `$_old_files` list will be removed and the new files
2008-08-14 02:30:38 -04:00
* copied from the zip file after the database is upgraded .
*
2016-05-22 13:22:27 -04:00
* The files in the `$_new_bundled_files` list will be added to the installation
2011-03-31 09:28:36 -04:00
* if the version is greater than or equal to the old version being upgraded .
*
2008-08-14 02:30:38 -04:00
* The steps for the upgrader for after the new release is downloaded and
* unzipped is :
* 1. Test unzipped location for select files to ensure that unzipped worked .
* 2. Create the . maintenance file in current WordPress base .
* 3. Copy new WordPress directory over old WordPress files .
* 4. Upgrade WordPress to new version .
2011-03-31 09:28:36 -04:00
* 4.1 . Copy all files / folders other than wp - content
* 4.2 . Copy any language files to WP_LANG_DIR ( which may differ from WP_CONTENT_DIR
* 4.3 . Copy any new bundled themes / plugins to their respective locations
2008-08-14 02:30:38 -04:00
* 5. Delete new WordPress directory path .
* 6. Delete . maintenance file .
* 7. Remove old files .
* 8. Delete 'update_core' option .
*
* There are several areas of failure . For instance if PHP times out before step
* 6 , then you will not be able to access any portion of your site . Also , since
* the upgrade will not continue where it left off , you will not be able to
* automatically remove old files and remove the 'update_core' option . This
* isn ' t that bad .
*
* If the copy of the new WordPress over the old fails , then the worse is that
* the new WordPress directory will remain .
*
* If it is assumed that every file will be copied over , including plugins and
* themes , then if you edit the default theme , you should rename it , so that
* your changes remain .
*
2008-10-01 21:03:26 -04:00
* @ since 2.7 . 0
*
2018-03-04 16:58:30 -05:00
* @ global WP_Filesystem_Base $wp_filesystem WordPress filesystem subclass .
2015-05-28 22:06:31 -04:00
* @ global array $_old_files
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
* @ global array $_old_requests_files
2015-05-28 22:06:31 -04:00
* @ global array $_new_bundled_files
2019-08-03 21:12:56 -04:00
* @ global wpdb $wpdb WordPress database abstraction object .
2015-05-28 22:06:31 -04:00
* @ global string $wp_version
* @ global string $required_php_version
* @ global string $required_mysql_version
*
2008-08-14 02:30:38 -04:00
* @ param string $from New release unzipped path .
2015-05-29 16:17:26 -04:00
* @ param string $to Path to old WordPress installation .
2020-01-21 19:19:04 -05:00
* @ return string | WP_Error New WordPress version on success , WP_Error on failure .
2008-08-14 02:30:38 -04:00
*/
2017-11-30 18:11:00 -05:00
function update_core ( $from , $to ) {
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
global $wp_filesystem , $_old_files , $_old_requests_files , $_new_bundled_files , $wpdb ;
2008-08-08 18:49:35 -04:00
2023-02-07 08:28:18 -05:00
if ( function_exists ( 'set_time_limit' ) ) {
set_time_limit ( 300 );
}
2008-10-14 12:36:43 -04:00
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
/*
* Merge the old Requests files and directories into the `$_old_files` .
* Then preload these Requests files first , before the files are deleted
* and replaced to ensure the code is in memory if needed .
*/
$_old_files = array_merge ( $_old_files , array_values ( $_old_requests_files ) );
_preload_old_requests_classes_and_interfaces ( $to );
2014-01-28 03:02:14 -05:00
/**
2016-05-22 14:01:30 -04:00
* Filters feedback messages displayed during the core update process .
2014-01-28 03:02:14 -05:00
*
* The filter is first evaluated after the zip file for the latest version
* has been downloaded and unzipped . It is evaluated five more times during
* the process :
*
* 1. Before WordPress begins the core upgrade process .
* 2. Before Maintenance Mode is enabled .
* 3. Before WordPress begins copying over the necessary files .
* 4. Before Maintenance Mode is disabled .
* 5. Before the database is upgraded .
*
* @ since 2.5 . 0
*
* @ param string $feedback The core update feedback messages .
*/
apply_filters ( 'update_feedback' , __ ( 'Verifying the unpacked files…' ) );
Docs: Replace "sanity" with "confidence" for inclusive language.
The phrase "sanity check" unnecessarily references mental health. It's an old phrase used to denote an extra step in verifying code works as expected.
“The WordPress open source community cares about diversity. We strive to maintain a welcoming environment where everyone can feel included.”
While "sanity check" is a well-known phrase with a specific meaning, "confidence check" is a direct replacement that is more clear of its intent while being more inclusive.
Words matter.
Follow-up to [49216], [46271], [40583], [38832], [38637], [37409], [33359], [32162], [30346], [30345], [30238], [30055], [29902], [28763], [26141], [25002], [22227], [13428], [12148], [11025], [8927].
Props dartiss, hellofromTonya.
Fixes #60187.
Built from https://develop.svn.wordpress.org/trunk@57239
git-svn-id: http://core.svn.wordpress.org/trunk@56745 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2024-01-03 16:59:19 -05:00
// Confidence check the unzipped distribution.
2012-10-13 23:47:36 -04:00
$distro = '' ;
2017-11-30 18:11:00 -05:00
$roots = array ( '/wordpress/' , '/wordpress-mu/' );
2021-04-23 10:51:05 -04:00
2012-10-13 23:47:36 -04:00
foreach ( $roots as $root ) {
2021-04-23 10:51:05 -04:00
if ( $wp_filesystem -> exists ( $from . $root . 'readme.html' )
&& $wp_filesystem -> exists ( $from . $root . 'wp-includes/version.php' )
) {
2012-10-13 23:47:36 -04:00
$distro = $root ;
break ;
}
}
2021-04-23 10:51:05 -04:00
2012-10-13 23:47:36 -04:00
if ( ! $distro ) {
$wp_filesystem -> delete ( $from , true );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
return new WP_Error ( 'insane_distro' , __ ( 'The update could not be unpacked' ) );
2012-10-13 23:47:36 -04:00
}
2017-01-05 01:13:41 -05:00
/*
* Import $wp_version , $required_php_version , and $required_mysql_version from the new version .
2022-01-25 08:55:05 -05:00
* DO NOT globalize any variables imported from `version-current.php` in this function .
2015-05-28 22:06:31 -04:00
*
2021-03-01 05:38:05 -05:00
* BC Note : $wp_filesystem -> wp_content_dir () returned unslashed pre - 2.8 .
2015-05-28 22:06:31 -04:00
*/
2013-01-11 05:16:45 -05:00
$versions_file = trailingslashit ( $wp_filesystem -> wp_content_dir () ) . 'upgrade/version-current.php' ;
2021-04-23 10:51:05 -04:00
2012-10-13 23:47:36 -04:00
if ( ! $wp_filesystem -> copy ( $from . $distro . 'wp-includes/version.php' , $versions_file ) ) {
2014-03-01 01:02:15 -05:00
$wp_filesystem -> delete ( $from , true );
2021-04-23 10:51:05 -04:00
return new WP_Error (
'copy_failed_for_version_file' ,
2022-04-11 07:50:01 -04:00
__ ( 'The update cannot be installed because some files could not be copied. This is usually due to inconsistent file permissions.' ),
2021-04-23 10:51:05 -04:00
'wp-includes/version.php'
);
2012-10-13 23:47:36 -04:00
}
$wp_filesystem -> chmod ( $versions_file , FS_CHMOD_FILE );
2021-03-02 12:13:03 -05:00
/*
* `wp_opcache_invalidate()` only exists in WordPress 5.5 or later ,
* so don ' t run it when upgrading from older versions .
*/
if ( function_exists ( 'wp_opcache_invalidate' ) ) {
wp_opcache_invalidate ( $versions_file );
}
2020-02-06 01:33:11 -05:00
require WP_CONTENT_DIR . '/upgrade/version-current.php' ;
2012-10-13 23:47:36 -04:00
$wp_filesystem -> delete ( $versions_file );
2023-06-28 06:09:29 -04:00
$php_version = PHP_VERSION ;
$mysql_version = $wpdb -> db_version ();
$old_wp_version = $GLOBALS [ 'wp_version' ]; // The version of WordPress we're updating from.
/*
* Note : str_contains () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
$development_build = ( false !== strpos ( $old_wp_version . $wp_version , '-' ) ); // A dash in the version indicates a development release.
2017-11-30 18:11:00 -05:00
$php_compat = version_compare ( $php_version , $required_php_version , '>=' );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( file_exists ( WP_CONTENT_DIR . '/db.php' ) && empty ( $wpdb -> is_mysql ) ) {
2011-10-25 01:29:28 -04:00
$mysql_compat = true ;
2017-11-30 18:11:00 -05:00
} else {
2011-10-25 01:29:28 -04:00
$mysql_compat = version_compare ( $mysql_version , $required_mysql_version , '>=' );
2017-11-30 18:11:00 -05:00
}
2009-12-17 13:46:19 -05:00
2017-11-30 18:11:00 -05:00
if ( ! $mysql_compat || ! $php_compat ) {
$wp_filesystem -> delete ( $from , true );
}
2009-12-28 12:19:04 -05:00
2019-05-20 10:29:55 -04:00
$php_update_message = '' ;
2020-06-25 20:27:09 -04:00
2019-05-20 10:29:55 -04:00
if ( function_exists ( 'wp_get_update_php_url' ) ) {
2020-06-25 20:27:09 -04:00
$php_update_message = '</p><p>' . sprintf (
2021-03-21 09:13:03 -04:00
/* translators: %s: URL to Update PHP page. */
2020-06-25 20:27:09 -04:00
__ ( '<a href="%s">Learn more about updating PHP</a>.' ),
esc_url ( wp_get_update_php_url () )
);
2019-05-17 14:11:51 -04:00
2019-05-20 10:29:55 -04:00
if ( function_exists ( 'wp_get_update_php_annotation' ) ) {
$annotation = wp_get_update_php_annotation ();
2020-06-25 20:27:09 -04:00
2019-05-20 10:29:55 -04:00
if ( $annotation ) {
$php_update_message .= '</p><p><em>' . $annotation . '</em>' ;
}
}
2019-05-17 14:11:51 -04:00
}
2017-11-30 18:11:00 -05:00
if ( ! $mysql_compat && ! $php_compat ) {
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
return new WP_Error (
'php_mysql_not_compatible' ,
sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: WordPress version number, 2: Minimum required PHP version number, 3: Minimum required MySQL version number, 4: Current PHP version number, 5: Current MySQL version number. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'The update cannot be installed because WordPress %1$s requires PHP version %2$s or higher and MySQL version %3$s or higher. You are running PHP version %4$s and MySQL version %5$s.' ),
$wp_version ,
$required_php_version ,
$required_mysql_version ,
$php_version ,
$mysql_version
) . $php_update_message
);
2017-11-30 18:11:00 -05:00
} elseif ( ! $php_compat ) {
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
return new WP_Error (
'php_not_compatible' ,
sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: WordPress version number, 2: Minimum required PHP version number, 3: Current PHP version number. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'The update cannot be installed because WordPress %1$s requires PHP version %2$s or higher. You are running version %3$s.' ),
$wp_version ,
$required_php_version ,
$php_version
) . $php_update_message
);
2017-11-30 18:11:00 -05:00
} elseif ( ! $mysql_compat ) {
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
return new WP_Error (
'mysql_not_compatible' ,
sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: WordPress version number, 2: Minimum required MySQL version number, 3: Current MySQL version number. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'The update cannot be installed because WordPress %1$s requires MySQL version %2$s or higher. You are running version %3$s.' ),
$wp_version ,
$required_mysql_version ,
$mysql_version
)
);
2017-11-30 18:11:00 -05:00
}
2009-12-17 13:46:19 -05:00
2019-10-11 22:42:01 -04:00
// Add a warning when the JSON PHP extension is missing.
2019-10-09 18:22:04 -04:00
if ( ! extension_loaded ( 'json' ) ) {
return new WP_Error (
2019-10-16 17:03:02 -04:00
'php_not_compatible_json' ,
2019-10-09 18:22:04 -04:00
sprintf (
2019-10-11 22:42:01 -04:00
/* translators: 1: WordPress version number, 2: The PHP extension name needed. */
__ ( 'The update cannot be installed because WordPress %1$s requires the %2$s PHP extension.' ),
2019-10-09 18:22:04 -04:00
$wp_version ,
'JSON'
)
);
}
2014-01-28 03:02:14 -05:00
/** This filter is documented in wp-admin/includes/update-core.php */
2013-09-21 02:49:11 -04:00
apply_filters ( 'update_feedback' , __ ( 'Preparing to install the latest version…' ) );
2023-07-09 16:07:22 -04:00
/*
* Don 't copy wp-content, we' ll deal with that below .
* We also copy version . php last so failed updates report their old version .
*/
2017-11-30 18:11:00 -05:00
$skip = array ( 'wp-content' , 'wp-includes/version.php' );
2013-10-15 15:18:10 -04:00
$check_is_writable = array ();
2013-09-21 02:49:11 -04:00
2020-01-28 19:45:18 -05:00
// Check to see which files don't really need updating - only available for 3.7 and higher.
2013-09-21 02:49:11 -04:00
if ( function_exists ( 'get_core_checksums' ) ) {
2020-01-28 19:45:18 -05:00
// Find the local version of the working directory.
2013-11-05 00:43:09 -05:00
$working_dir_local = WP_CONTENT_DIR . '/upgrade/' . basename ( $from ) . $distro ;
2013-10-15 19:03:10 -04:00
$checksums = get_core_checksums ( $wp_version , isset ( $wp_local_package ) ? $wp_local_package : 'en_US' );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( is_array ( $checksums ) && isset ( $checksums [ $wp_version ] ) ) {
2020-01-28 19:45:18 -05:00
$checksums = $checksums [ $wp_version ]; // Compat code for 3.7-beta2.
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
2013-10-15 19:03:10 -04:00
if ( is_array ( $checksums ) ) {
2015-08-25 16:28:22 -04:00
foreach ( $checksums as $file => $checksum ) {
2023-06-28 06:09:29 -04:00
/*
* Note : str_starts_with () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
if ( 'wp-content' === substr ( $file , 0 , 10 ) ) {
2013-09-29 19:08:09 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( ! file_exists ( ABSPATH . $file ) ) {
2013-10-15 19:03:10 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( ! file_exists ( $working_dir_local . $file ) ) {
2013-11-05 00:43:09 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
if ( '.' === dirname ( $file )
&& in_array ( pathinfo ( $file , PATHINFO_EXTENSION ), array ( 'html' , 'txt' ), true )
) {
2016-10-24 22:24:31 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( md5_file ( ABSPATH . $file ) === $checksum ) {
2013-09-21 02:49:11 -04:00
$skip [] = $file ;
2017-11-30 18:11:00 -05:00
} else {
2013-10-15 15:18:10 -04:00
$check_is_writable [ $file ] = ABSPATH . $file ;
2017-11-30 18:11:00 -05:00
}
2013-09-21 02:49:11 -04:00
}
}
}
2008-08-08 18:49:35 -04:00
2013-10-15 15:18:10 -04:00
// If we're using the direct method, we can predict write failures that are due to permissions.
2013-10-15 16:35:10 -04:00
if ( $check_is_writable && 'direct' === $wp_filesystem -> method ) {
2013-10-15 15:18:10 -04:00
$files_writable = array_filter ( $check_is_writable , array ( $wp_filesystem , 'is_writable' ) );
2021-04-23 10:51:05 -04:00
2013-10-15 15:18:10 -04:00
if ( $files_writable !== $check_is_writable ) {
$files_not_writable = array_diff_key ( $check_is_writable , $files_writable );
2021-04-23 10:51:05 -04:00
2013-10-15 15:18:10 -04:00
foreach ( $files_not_writable as $relative_file_not_writable => $file_not_writable ) {
// If the writable check failed, chmod file to 0644 and try again, same as copy_dir().
$wp_filesystem -> chmod ( $file_not_writable , FS_CHMOD_FILE );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( $wp_filesystem -> is_writable ( $file_not_writable ) ) {
2013-10-15 15:18:10 -04:00
unset ( $files_not_writable [ $relative_file_not_writable ] );
2017-11-30 18:11:00 -05:00
}
2013-10-15 15:18:10 -04:00
}
// Store package-relative paths (the key) of non-writable files in the WP_Error object.
2013-10-15 16:01:09 -04:00
$error_data = version_compare ( $old_wp_version , '3.7-beta2' , '>' ) ? array_keys ( $files_not_writable ) : '' ;
2017-11-30 18:11:00 -05:00
if ( $files_not_writable ) {
2021-04-23 10:51:05 -04:00
return new WP_Error (
'files_not_writable' ,
2022-09-19 04:59:11 -04:00
__ ( 'The update cannot be installed because your site is unable to copy some files. This is usually due to inconsistent file permissions.' ),
2021-04-23 10:51:05 -04:00
implode ( ', ' , $error_data )
);
2017-11-30 18:11:00 -05:00
}
2013-10-15 15:18:10 -04:00
}
}
2014-01-28 03:02:14 -05:00
/** This filter is documented in wp-admin/includes/update-core.php */
2013-09-21 02:49:11 -04:00
apply_filters ( 'update_feedback' , __ ( 'Enabling Maintenance mode…' ) );
2021-04-23 10:51:05 -04:00
2020-01-28 19:45:18 -05:00
// Create maintenance file to signal that we are upgrading.
2008-08-08 18:49:35 -04:00
$maintenance_string = '<?php $upgrading = ' . time () . '; ?>' ;
2017-11-30 18:11:00 -05:00
$maintenance_file = $to . '.maintenance' ;
$wp_filesystem -> delete ( $maintenance_file );
$wp_filesystem -> put_contents ( $maintenance_file , $maintenance_string , FS_CHMOD_FILE );
2008-08-08 18:49:35 -04:00
2014-01-28 03:02:14 -05:00
/** This filter is documented in wp-admin/includes/update-core.php */
2013-09-21 02:49:11 -04:00
apply_filters ( 'update_feedback' , __ ( 'Copying the required files…' ) );
2021-04-23 10:51:05 -04:00
2008-08-08 18:49:35 -04:00
// Copy new versions of WP files into place.
Upgrade/Install: Remove `_copy_dir()` function as originally intended.
WordPress 3.2 introduced several enhancements to the `copy_dir()` function:
* No more re-installing Akismet upon upgrade.
* Respect custom `WP_CONTENT_DIR` for bundled plugins/theme installation.
* Respect custom `WP_CONTENT_DIR`/`WP_LANG_DIR` for language files when upgrading.
* Add an exclusion list to `copy_dir()` as well as `WP_Filesystem_Base::wp_lang_dir()`.
* Standardize `WP_Filesystem` path method returns.
However, the version of `copy_dir()` that runs during the upgrade process is the one from the older install, not the newer, which means that these enhancements would only be available after upgrading to WordPress 3.2 first, e.g. in a subsequent upgrade to WordPress 3.3.
In order to make these enhancements immediately available in WordPress 3.2, specifically to take advantage of skip lists and avoid re-installing Akismet if it was previously deleted, a temporary copy of the function was utilized, with the intention to remove it in WordPress 3.3 or a later release.
With further enhancements made to the Upgrade API to support partial and no-content builds, this temporary copy is no longer relevant and can be safely removed.
Follow-up to [17576], [17580], [17581], [18225].
Props afragen, costdev, dd32, peterwilsoncc, SergeyBiryukov.
Fixes #55712. See #17173.
Built from https://develop.svn.wordpress.org/trunk@54143
git-svn-id: http://core.svn.wordpress.org/trunk@53702 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-13 12:57:10 -04:00
$result = copy_dir ( $from . $distro , $to , $skip );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $result ) ) {
2021-04-23 10:51:05 -04:00
$result = new WP_Error (
$result -> get_error_code (),
$result -> get_error_message (),
substr ( $result -> get_error_data (), strlen ( $to ) )
);
2017-11-30 18:11:00 -05:00
}
2013-09-21 02:49:11 -04:00
2020-01-28 19:45:18 -05:00
// Since we know the core files have copied over, we can now copy the version file.
2014-03-01 01:01:16 -05:00
if ( ! is_wp_error ( $result ) ) {
2014-03-01 01:04:14 -05:00
if ( ! $wp_filesystem -> copy ( $from . $distro . 'wp-includes/version.php' , $to . 'wp-includes/version.php' , true /* overwrite */ ) ) {
2014-03-01 01:01:16 -05:00
$wp_filesystem -> delete ( $from , true );
2021-04-23 10:51:05 -04:00
$result = new WP_Error (
'copy_failed_for_version_file' ,
2022-09-19 04:59:11 -04:00
__ ( 'The update cannot be installed because your site is unable to copy some files. This is usually due to inconsistent file permissions.' ),
2021-04-23 10:51:05 -04:00
'wp-includes/version.php'
);
2014-03-01 01:01:16 -05:00
}
2021-04-23 10:51:05 -04:00
2014-03-01 01:01:16 -05:00
$wp_filesystem -> chmod ( $to . 'wp-includes/version.php' , FS_CHMOD_FILE );
2021-03-02 12:13:03 -05:00
/*
* `wp_opcache_invalidate()` only exists in WordPress 5.5 or later ,
* so don ' t run it when upgrading from older versions .
*/
if ( function_exists ( 'wp_opcache_invalidate' ) ) {
wp_opcache_invalidate ( $to . 'wp-includes/version.php' );
}
2014-03-01 01:01:16 -05:00
}
2020-01-28 19:45:18 -05:00
// Check to make sure everything copied correctly, ignoring the contents of wp-content.
2017-11-30 18:11:00 -05:00
$skip = array ( 'wp-content' );
2013-09-21 02:49:11 -04:00
$failed = array ();
2021-04-23 10:51:05 -04:00
2013-10-25 16:15:10 -04:00
if ( isset ( $checksums ) && is_array ( $checksums ) ) {
2013-10-15 19:03:10 -04:00
foreach ( $checksums as $file => $checksum ) {
2023-06-28 06:09:29 -04:00
/*
* Note : str_starts_with () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
if ( 'wp-content' === substr ( $file , 0 , 10 ) ) {
2013-11-05 00:43:09 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( ! file_exists ( $working_dir_local . $file ) ) {
2013-09-21 02:49:11 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
if ( '.' === dirname ( $file )
&& in_array ( pathinfo ( $file , PATHINFO_EXTENSION ), array ( 'html' , 'txt' ), true )
) {
2016-10-24 22:24:31 -04:00
$skip [] = $file ;
continue ;
}
2021-04-23 10:51:05 -04:00
if ( file_exists ( ABSPATH . $file ) && md5_file ( ABSPATH . $file ) === $checksum ) {
2013-09-21 02:49:11 -04:00
$skip [] = $file ;
2017-11-30 18:11:00 -05:00
} else {
2013-09-21 02:49:11 -04:00
$failed [] = $file ;
2017-11-30 18:11:00 -05:00
}
2013-09-21 02:49:11 -04:00
}
}
2020-01-28 19:45:18 -05:00
// Some files didn't copy properly.
2013-09-21 02:49:11 -04:00
if ( ! empty ( $failed ) ) {
$total_size = 0 ;
2021-04-23 10:51:05 -04:00
2013-10-16 11:20:10 -04:00
foreach ( $failed as $file ) {
2017-11-30 18:11:00 -05:00
if ( file_exists ( $working_dir_local . $file ) ) {
2013-10-16 11:20:10 -04:00
$total_size += filesize ( $working_dir_local . $file );
2017-11-30 18:11:00 -05:00
}
2013-10-16 11:20:10 -04:00
}
2013-09-21 02:49:11 -04:00
2023-07-09 16:07:22 -04:00
/*
* If we don 't have enough free space, it isn' t worth trying again .
* Unlikely to be hit due to the check in unzip_file () .
*/
Upgrade/Install: Check if the `disk_free_space()` function exists before calling it.
In PHP 8+, `@` no longer suppresses fatal errors:
> The `@` operator will no longer silence fatal errors (`E_ERROR`, `E_CORE_ERROR`, `E_COMPILE_ERROR`, `E_USER_ERROR`, `E_RECOVERABLE_ERROR`, `E_PARSE`).
Reference: [https://www.php.net/manual/en/migration80.incompatible.php PHP 8: Backward Incompatible Changes].
`disk_free_space()` may be disabled by hosts, which will throw a fatal error on a call to undefined function.
This change prevents the fatal error, and falls back to `false` when `disk_free_space()` is unavailable.
Follow-up to [25540], [25774], [25776], [25831], [25869].
Props costdev, jrf, swb1192, SergeyBiryukov.
Fixes #54826. See #54730.
Built from https://develop.svn.wordpress.org/trunk@52585
git-svn-id: http://core.svn.wordpress.org/trunk@52175 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-01-17 06:41:03 -05:00
$available_space = function_exists ( 'disk_free_space' ) ? @ disk_free_space ( ABSPATH ) : false ;
2021-04-23 10:51:05 -04:00
2013-10-14 17:15:10 -04:00
if ( $available_space && $total_size >= $available_space ) {
2013-10-14 18:25:08 -04:00
$result = new WP_Error ( 'disk_full' , __ ( 'There is not enough free disk space to complete the update.' ) );
2013-10-11 12:06:11 -04:00
} else {
Upgrade/Install: Remove `_copy_dir()` function as originally intended.
WordPress 3.2 introduced several enhancements to the `copy_dir()` function:
* No more re-installing Akismet upon upgrade.
* Respect custom `WP_CONTENT_DIR` for bundled plugins/theme installation.
* Respect custom `WP_CONTENT_DIR`/`WP_LANG_DIR` for language files when upgrading.
* Add an exclusion list to `copy_dir()` as well as `WP_Filesystem_Base::wp_lang_dir()`.
* Standardize `WP_Filesystem` path method returns.
However, the version of `copy_dir()` that runs during the upgrade process is the one from the older install, not the newer, which means that these enhancements would only be available after upgrading to WordPress 3.2 first, e.g. in a subsequent upgrade to WordPress 3.3.
In order to make these enhancements immediately available in WordPress 3.2, specifically to take advantage of skip lists and avoid re-installing Akismet if it was previously deleted, a temporary copy of the function was utilized, with the intention to remove it in WordPress 3.3 or a later release.
With further enhancements made to the Upgrade API to support partial and no-content builds, this temporary copy is no longer relevant and can be safely removed.
Follow-up to [17576], [17580], [17581], [18225].
Props afragen, costdev, dd32, peterwilsoncc, SergeyBiryukov.
Fixes #55712. See #17173.
Built from https://develop.svn.wordpress.org/trunk@54143
git-svn-id: http://core.svn.wordpress.org/trunk@53702 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-09-13 12:57:10 -04:00
$result = copy_dir ( $from . $distro , $to , $skip );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $result ) ) {
2021-04-23 10:51:05 -04:00
$result = new WP_Error (
$result -> get_error_code () . '_retry' ,
$result -> get_error_message (),
substr ( $result -> get_error_data (), strlen ( $to ) )
);
2017-11-30 18:11:00 -05:00
}
2013-10-11 12:06:11 -04:00
}
2013-09-21 02:49:11 -04:00
}
2011-03-31 09:28:36 -04:00
2023-07-09 16:07:22 -04:00
/*
* Custom content directory needs updating now .
* Copy languages .
*/
2017-11-30 18:11:00 -05:00
if ( ! is_wp_error ( $result ) && $wp_filesystem -> is_dir ( $from . $distro . 'wp-content/languages' ) ) {
2021-04-23 10:51:05 -04:00
if ( WP_LANG_DIR !== ABSPATH . WPINC . '/languages' || @ is_dir ( WP_LANG_DIR ) ) {
2011-04-01 05:13:50 -04:00
$lang_dir = WP_LANG_DIR ;
2017-11-30 18:11:00 -05:00
} else {
2011-04-01 05:13:50 -04:00
$lang_dir = WP_CONTENT_DIR . '/languages' ;
2017-11-30 18:11:00 -05:00
}
2023-08-18 19:25:24 -04:00
/*
* Note : str_starts_with () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
2020-01-28 19:45:18 -05:00
// Check if the language directory exists first.
2023-08-18 19:25:24 -04:00
if ( ! @ is_dir ( $lang_dir ) && 0 === strpos ( $lang_dir , ABSPATH ) ) {
2020-01-28 19:45:18 -05:00
// If it's within the ABSPATH we can handle it here, otherwise they're out of luck.
$wp_filesystem -> mkdir ( $to . str_replace ( ABSPATH , '' , $lang_dir ), FS_CHMOD_DIR );
clearstatcache (); // For FTP, need to clear the stat cache.
2011-03-31 09:28:36 -04:00
}
2017-11-30 18:11:00 -05:00
if ( @ is_dir ( $lang_dir ) ) {
$wp_lang_dir = $wp_filesystem -> find_folder ( $lang_dir );
2021-04-23 10:51:05 -04:00
2013-10-14 15:38:10 -04:00
if ( $wp_lang_dir ) {
2017-11-30 18:11:00 -05:00
$result = copy_dir ( $from . $distro . 'wp-content/languages/' , $wp_lang_dir );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $result ) ) {
2021-04-23 10:51:05 -04:00
$result = new WP_Error (
$result -> get_error_code () . '_languages' ,
$result -> get_error_message (),
substr ( $result -> get_error_data (), strlen ( $wp_lang_dir ) )
);
2017-11-30 18:11:00 -05:00
}
2013-10-14 15:38:10 -04:00
}
2011-03-31 09:28:36 -04:00
}
}
2014-01-28 03:02:14 -05:00
/** This filter is documented in wp-admin/includes/update-core.php */
2013-10-24 18:59:05 -04:00
apply_filters ( 'update_feedback' , __ ( 'Disabling Maintenance mode…' ) );
2021-04-23 10:51:05 -04:00
2020-01-28 19:45:18 -05:00
// Remove maintenance file, we're done with potential site-breaking changes.
2013-10-24 18:59:05 -04:00
$wp_filesystem -> delete ( $maintenance_file );
2023-07-09 16:07:22 -04:00
/*
* 3.5 -> 3.5 + - an empty twentytwelve directory was created upon upgrade to 3.5 for some users ,
* preventing installation of Twenty Twelve .
*/
2020-05-16 14:42:12 -04:00
if ( '3.5' === $old_wp_version ) {
2021-04-23 10:51:05 -04:00
if ( is_dir ( WP_CONTENT_DIR . '/themes/twentytwelve' )
&& ! file_exists ( WP_CONTENT_DIR . '/themes/twentytwelve/style.css' )
) {
2013-01-03 02:42:16 -05:00
$wp_filesystem -> delete ( $wp_filesystem -> wp_themes_dir () . 'twentytwelve/' );
}
}
2020-01-28 19:45:18 -05:00
/*
* Copy new bundled plugins & themes .
* This gives us the ability to install new plugins & themes bundled with
* future versions of WordPress whilst avoiding the re - install upon upgrade issue .
* $development_build controls us overwriting bundled themes and plugins when a non - stable release is being updated .
*/
2021-04-23 10:51:05 -04:00
if ( ! is_wp_error ( $result )
&& ( ! defined ( 'CORE_UPGRADE_SKIP_NEW_BUNDLED' ) || ! CORE_UPGRADE_SKIP_NEW_BUNDLED )
) {
2011-03-31 09:28:36 -04:00
foreach ( ( array ) $_new_bundled_files as $file => $introduced_version ) {
2020-01-28 19:45:18 -05:00
// If a $development_build or if $introduced version is greater than what the site was previously running.
2012-10-13 22:14:17 -04:00
if ( $development_build || version_compare ( $introduced_version , $old_wp_version , '>' ) ) {
2020-05-16 14:42:12 -04:00
$directory = ( '/' === $file [ strlen ( $file ) - 1 ] );
list ( $type , $filename ) = explode ( '/' , $file , 2 );
2011-04-01 05:50:01 -04:00
2020-01-28 19:45:18 -05:00
// Check to see if the bundled items exist before attempting to copy them.
2017-11-30 18:11:00 -05:00
if ( ! $wp_filesystem -> exists ( $from . $distro . 'wp-content/' . $file ) ) {
2012-12-14 22:09:50 -05:00
continue ;
2017-11-30 18:11:00 -05:00
}
2012-12-14 22:09:50 -05:00
2020-05-16 14:42:12 -04:00
if ( 'plugins' === $type ) {
2011-03-31 09:28:36 -04:00
$dest = $wp_filesystem -> wp_plugins_dir ();
2020-05-16 14:42:12 -04:00
} elseif ( 'themes' === $type ) {
2020-01-28 19:45:18 -05:00
// Back-compat, ::wp_themes_dir() did not return trailingslash'd pre-3.2.
$dest = trailingslashit ( $wp_filesystem -> wp_themes_dir () );
2017-11-30 18:11:00 -05:00
} else {
2011-04-01 05:50:01 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2011-03-31 09:28:36 -04:00
if ( ! $directory ) {
2017-11-30 18:11:00 -05:00
if ( ! $development_build && $wp_filesystem -> exists ( $dest . $filename ) ) {
2011-03-31 09:28:36 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2011-03-31 09:28:36 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $wp_filesystem -> copy ( $from . $distro . 'wp-content/' . $file , $dest . $filename , FS_CHMOD_FILE ) ) {
2013-10-14 15:38:10 -04:00
$result = new WP_Error ( " copy_failed_for_new_bundled_ $type " , __ ( 'Could not copy file.' ), $dest . $filename );
2017-11-30 18:11:00 -05:00
}
2011-03-31 09:28:36 -04:00
} else {
2017-11-30 18:11:00 -05:00
if ( ! $development_build && $wp_filesystem -> is_dir ( $dest . $filename ) ) {
2011-03-31 09:28:36 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2011-03-31 09:28:36 -04:00
2017-11-30 18:11:00 -05:00
$wp_filesystem -> mkdir ( $dest . $filename , FS_CHMOD_DIR );
$_result = copy_dir ( $from . $distro . 'wp-content/' . $file , $dest . $filename );
2013-10-14 15:38:10 -04:00
2023-05-18 08:36:24 -04:00
/*
* If an error occurs partway through this final step ,
* keep the error flowing through , but keep the process going .
*/
2013-10-14 15:38:10 -04:00
if ( is_wp_error ( $_result ) ) {
2017-11-30 18:11:00 -05:00
if ( ! is_wp_error ( $result ) ) {
2022-11-29 10:51:14 -05:00
$result = new WP_Error ();
2017-11-30 18:11:00 -05:00
}
2021-04-23 10:51:05 -04:00
$result -> add (
$_result -> get_error_code () . " _ $type " ,
$_result -> get_error_message (),
substr ( $_result -> get_error_data (), strlen ( $dest ) )
);
2013-10-14 15:38:10 -04:00
}
2011-03-31 09:28:36 -04:00
}
}
2020-01-28 19:45:18 -05:00
} // End foreach.
2011-03-31 09:28:36 -04:00
}
2020-01-28 19:45:18 -05:00
// Handle $result error from the above blocks.
2017-11-30 18:11:00 -05:00
if ( is_wp_error ( $result ) ) {
$wp_filesystem -> delete ( $from , true );
2021-04-23 10:51:05 -04:00
2008-08-08 18:49:35 -04:00
return $result ;
}
2020-01-28 19:45:18 -05:00
// Remove old files.
2008-08-08 21:00:27 -04:00
foreach ( $_old_files as $old_file ) {
$old_file = $to . $old_file ;
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
if ( ! $wp_filesystem -> exists ( $old_file ) ) {
2008-08-08 21:00:27 -04:00
continue ;
2017-11-30 18:11:00 -05:00
}
2018-01-10 01:10:47 -05:00
// If the file isn't deleted, try writing an empty string to the file instead.
if ( ! $wp_filesystem -> delete ( $old_file , true ) && $wp_filesystem -> is_file ( $old_file ) ) {
$wp_filesystem -> put_contents ( $old_file , '' );
}
2008-08-08 21:00:27 -04:00
}
2020-01-28 19:45:18 -05:00
// Remove any Genericons example.html's from the filesystem.
2015-05-06 14:37:25 -04:00
_upgrade_422_remove_genericons ();
2021-06-18 08:14:01 -04:00
// Deactivate the REST API plugin if its version is 2.0 Beta 4 or lower.
2015-11-08 20:22:28 -05:00
_upgrade_440_force_deactivate_incompatible_plugins ();
Update/Install: Deactivate Gutenberg plugin version older than 14.1.
Resolves a fatal error due to `get_template_hierarchy()` due to incompatible older Gutenberg versions.
[54269] introduced this new function for 6.1. The function was introduced in Gutenberg 13.9.0. However, it was not guarded to protect the plugin from when the function was loaded in Core. Gutenberg 14.1.0 added the `function_exists()` guard to protect the plugin from the fatal error.
Minimum compatible version:
This commit changes the Gutenberg minimum compatible version number to 14.1. For versions older than 14.1, the plugin will deactivate when upgrading Core to 6.1 or newer.
Function rename:
Past commits renamed the upgrade function by changing Core's version number. This commit renames the function to be generic, i.e. `_upgrade_core_deactivate_incompatible_plugins()` and adopts the `@since [reason]` strategy to track historical changes to the function.
Follow-up to [54269], [52199], [52166], [52165], [51180].
Props namithjawahar, hellofromTonya, azaozz, desrosj, ironprogrammer.
Fixes #56985.
Built from https://develop.svn.wordpress.org/trunk@54789
git-svn-id: http://core.svn.wordpress.org/trunk@54341 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-10 07:22:18 -05:00
// Deactivate incompatible plugins.
_upgrade_core_deactivate_incompatible_plugins ();
2021-11-15 14:59:03 -05:00
2020-01-28 19:45:18 -05:00
// Upgrade DB with separate request.
2014-01-28 03:02:14 -05:00
/** This filter is documented in wp-admin/includes/update-core.php */
apply_filters ( 'update_feedback' , __ ( 'Upgrading database…' ) );
2021-04-23 10:51:05 -04:00
2017-11-30 18:11:00 -05:00
$db_upgrade_url = admin_url ( 'upgrade.php?step=upgrade_db' );
wp_remote_post ( $db_upgrade_url , array ( 'timeout' => 60 ) );
2008-10-05 02:00:24 -04:00
2020-01-28 19:45:18 -05:00
// Clear the cache to prevent an update_option() from saving a stale db_version to the cache.
2013-11-27 21:16:09 -05:00
wp_cache_flush ();
2020-01-28 19:45:18 -05:00
// Not all cache back ends listen to 'flush'.
2013-12-06 14:00:10 -05:00
wp_cache_delete ( 'alloptions' , 'options' );
2013-11-27 21:16:09 -05:00
2020-01-28 19:45:18 -05:00
// Remove working directory.
2017-11-30 18:11:00 -05:00
$wp_filesystem -> delete ( $from , true );
2008-10-05 01:45:34 -04:00
2020-01-28 19:45:18 -05:00
// Force refresh of update information.
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'delete_site_transient' ) ) {
delete_site_transient ( 'update_core' );
} else {
delete_option ( 'update_core' );
}
2008-10-05 01:45:34 -04:00
2014-01-28 03:02:14 -05:00
/**
* Fires after WordPress core has been successfully updated .
*
* @ since 3.3 . 0
*
* @ param string $wp_version The current WordPress version .
*/
2011-11-30 23:38:51 -05:00
do_action ( '_core_updated_successfully' , $wp_version );
2020-07-06 15:15:03 -04:00
// Clear the option that blocks auto-updates after failures, now that we've been successful.
2017-11-30 18:11:00 -05:00
if ( function_exists ( 'delete_site_option' ) ) {
2015-10-07 13:11:25 -04:00
delete_site_option ( 'auto_core_update_failed' );
2017-11-30 18:11:00 -05:00
}
2013-10-24 18:55:30 -04:00
2011-11-30 23:38:51 -05:00
return $wp_version ;
2008-08-08 18:49:35 -04:00
}
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
/**
* Preloads old Requests classes and interfaces .
*
* This function preloads the old Requests code into memory before the
* upgrade process deletes the files . Why ? Requests code is loaded into
* memory via an autoloader , meaning when a class or interface is needed
* If a request is in process , Requests could attempt to access code . If
* the file is not there , a fatal error could occur . If the file was
* replaced , the new code is not compatible with the old , resulting in
* a fatal error . Preloading ensures the code is in memory before the
* code is updated .
*
* @ since 6.2 . 0
*
* @ global array $_old_requests_files Requests files to be preloaded .
* @ global WP_Filesystem_Base $wp_filesystem WordPress filesystem subclass .
2023-02-08 10:03:19 -05:00
* @ global string $wp_version The WordPress version string .
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
*
* @ param string $to Path to old WordPress installation .
*/
function _preload_old_requests_classes_and_interfaces ( $to ) {
2023-02-08 10:03:19 -05:00
global $_old_requests_files , $wp_filesystem , $wp_version ;
/*
* Requests was introduced in WordPress 4.6 .
*
* Skip preloading if the website was previously using
* an earlier version of WordPress .
*/
if ( version_compare ( $wp_version , '4.6' , '<' ) ) {
return ;
}
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
2023-02-04 19:20:15 -05:00
if ( ! defined ( 'REQUESTS_SILENCE_PSR0_DEPRECATIONS' ) ) {
define ( 'REQUESTS_SILENCE_PSR0_DEPRECATIONS' , true );
}
External Libraries: Update Requests library to version 2.0.0.
This is a major release and contains breaking changes.
Most important changes to be aware of for this release:
* All code is now namespaced. Though there is a full backward compatibility layer available and the old class names are still supported, using them will generate a deprecation notice (which can be silenced by plugins if they'd need to support multiple WP versions). See the [https://requests.ryanmccue.info/docs/upgrading.html upgrade guide] for more details.
* A lot of classes have been marked `final`. This should generally not affect userland code as care has been taken to not apply the `final` keyword to classes which are known to be extended in userland code.
* Extensive input validation has been added to Requests. When Requests is used as documented though, this will be unnoticable.
* A new `WpOrg\Requests\Requests::has_capabilities()` method has been introduced which can be used to address #37708.
* A new `WpOrg\Requests\Response::decode_body()` method has been introduced which may be usable to simplify some of the WP native wrapper code.
* Remaining PHP 8.0 compatibility fixed (support for named parameters).
* PHP 8.1 compatibility.
Release notes: https://github.com/WordPress/Requests/releases/tag/v2.0.0
For a full list of changes in this update, see the Requests GitHub:
https://github.com/WordPress/Requests/compare/v1.8.1...v2.0.0
This commit also resolves 2 blocking issues which previously caused the revert of [52244]:
* New Requests files are loaded into `wp-includes/Requests/src/`, matching the location of the library. In doing so, filesystems that are case-insensitive are not impacted (see #54582).
* Preload: During a Core update, the old Requests files are preloaded into memory before the update deletes the files. Preloading avoids fatal errors noted in #54562.
Follow-up to [50842], [51078], [52244], [52315], [52327], [52328].
Props jrf, schlessera, datagutten, wojsmol, dustinrue, soulseekah, szepeviktor. costdev, sergeybiryukov, peterwilsoncc, ironprogrammer, antonvlasenko, hellofromTonya, swissspidy, dd32, azaozz, TobiasBg, audrasjb.
Fixes #54504.
See #54582, #54562.
Built from https://develop.svn.wordpress.org/trunk@54997
git-svn-id: http://core.svn.wordpress.org/trunk@54530 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-12-15 16:32:17 -05:00
foreach ( $_old_requests_files as $name => $file ) {
// Skip files that aren't interfaces or classes.
if ( is_int ( $name ) ) {
continue ;
}
// Skip if it's already loaded.
if ( class_exists ( $name ) || interface_exists ( $name ) ) {
continue ;
}
// Skip if the file is missing.
if ( ! $wp_filesystem -> is_file ( $to . $file ) ) {
continue ;
}
require_once $to . $file ;
}
}
2011-11-23 18:38:36 -05:00
/**
* Redirect to the About WordPress page after a successful upgrade .
*
2017-08-22 07:52:48 -04:00
* This function is only needed when the existing installation is older than 3.4 . 0.
2011-11-30 23:38:51 -05:00
*
2011-11-23 18:38:36 -05:00
* @ since 3.3 . 0
*
2020-02-09 22:30:06 -05:00
* @ global string $wp_version The WordPress version string .
2022-04-04 14:26:06 -04:00
* @ global string $pagenow The filename of the current screen .
2015-05-28 22:06:31 -04:00
* @ global string $action
2015-05-29 16:17:26 -04:00
*
* @ param string $new_version
2011-11-23 18:38:36 -05:00
*/
2011-12-01 01:02:18 -05:00
function _redirect_to_about_wordpress ( $new_version ) {
2011-12-01 00:03:11 -05:00
global $wp_version , $pagenow , $action ;
2017-11-30 18:11:00 -05:00
if ( version_compare ( $wp_version , '3.4-RC1' , '>=' ) ) {
2012-05-25 14:12:29 -04:00
return ;
2017-11-30 18:11:00 -05:00
}
2011-12-01 00:03:11 -05:00
2013-09-09 02:45:08 -04:00
// Ensure we only run this on the update-core.php page. The Core_Upgrader may be used in other contexts.
2020-05-16 14:42:12 -04:00
if ( 'update-core.php' !== $pagenow ) {
2011-12-01 00:03:11 -05:00
return ;
2017-11-30 18:11:00 -05:00
}
2011-12-01 00:03:11 -05:00
2020-05-16 14:42:12 -04:00
if ( 'do-core-upgrade' !== $action && 'do-core-reinstall' !== $action ) {
2017-11-30 18:11:00 -05:00
return ;
}
2011-12-08 18:02:33 -05:00
2014-07-17 05:14:16 -04:00
// Load the updated default text localization domain for new strings.
2011-11-30 23:38:51 -05:00
load_default_textdomain ();
2020-01-28 19:45:18 -05:00
// See do_core_upgrade().
2020-07-23 17:08:01 -04:00
show_message ( __ ( 'WordPress updated successfully.' ) );
2012-09-03 17:56:12 -04:00
// self_admin_url() won't exist when upgrading from <= 3.0, so relative URLs are intentional.
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
show_message (
'<span class="hide-if-no-js">' . sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: WordPress version, 2: URL to About screen. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'Welcome to WordPress %1$s. You will be redirected to the About WordPress screen. If not, click <a href="%2$s">here</a>.' ),
$new_version ,
'about.php?updated'
) . '</span>'
);
show_message (
'<span class="hide-if-js">' . sprintf (
2019-09-02 20:41:05 -04:00
/* translators: 1: WordPress version, 2: URL to About screen. */
I18N: Improve translator comments.
* Add missing translator comments.
* Fix placement of some translator comments. Translator comments should be on the line directly above the line containing the translation function call for optimal compatibility with various `.pot` file generation tools. The CS auto-fixing, which changed some inconsistent function calls to multi-line function calls, is part of the reason why this was no longer the case for a select group of translator comments.
Includes minor code layout fixes.
Polyglots, rejoice! All WordPress core files now have translator comments for all strings with placeholders!
Props jrf, subrataemfluence, GaryJ, webdados, Dency, swissspidy, alvarogois, marcomartins, mihaiiceyro, vladwtz, niq1982, flipkeijzer, michielatyoast, chandrapatel, thrijith, joshuanoyce, FesoVik, tessak22, bhaktirajdev, cleancoded, dhavalkasvala, garrett-eclipse, bibliofille, socalchristina, priyankkpatel, 5hel2l2y, adamsilverstein, JeffPaul, pierlo, SergeyBiryukov.
Fixes #44360.
Built from https://develop.svn.wordpress.org/trunk@45926
git-svn-id: http://core.svn.wordpress.org/trunk@45737 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2019-09-01 13:13:59 -04:00
__ ( 'Welcome to WordPress %1$s. <a href="%2$s">Learn more</a>.' ),
$new_version ,
'about.php?updated'
) . '</span>'
);
2011-11-30 23:38:51 -05:00
echo '</div>' ;
?>
2011-11-23 18:38:36 -05:00
< script type = " text/javascript " >
2012-09-03 17:56:12 -04:00
window . location = 'about.php?updated' ;
2011-11-23 18:38:36 -05:00
</ script >
2011-11-30 23:38:51 -05:00
< ? php
2011-11-23 18:38:36 -05:00
2014-07-17 05:14:16 -04:00
// Include admin-footer.php and exit.
2020-02-06 01:33:11 -05:00
require_once ABSPATH . 'wp-admin/admin-footer.php' ;
2020-05-26 05:37:10 -04:00
exit ;
2011-11-30 23:38:51 -05:00
}
2015-05-06 14:37:25 -04:00
/**
* Cleans up Genericons example files .
*
* @ since 4.2 . 2
2015-05-28 22:06:31 -04:00
*
* @ global array $wp_theme_directories
* @ global WP_Filesystem_Base $wp_filesystem
2015-05-06 14:37:25 -04:00
*/
function _upgrade_422_remove_genericons () {
global $wp_theme_directories , $wp_filesystem ;
// A list of the affected files using the filesystem absolute paths.
$affected_files = array ();
2020-01-28 19:45:18 -05:00
// Themes.
2015-05-06 14:37:25 -04:00
foreach ( $wp_theme_directories as $directory ) {
$affected_theme_files = _upgrade_422_find_genericons_files_in_folder ( $directory );
$affected_files = array_merge ( $affected_files , $affected_theme_files );
}
2020-01-28 19:45:18 -05:00
// Plugins.
2015-05-06 14:37:25 -04:00
$affected_plugin_files = _upgrade_422_find_genericons_files_in_folder ( WP_PLUGIN_DIR );
$affected_files = array_merge ( $affected_files , $affected_plugin_files );
foreach ( $affected_files as $file ) {
$gen_dir = $wp_filesystem -> find_folder ( trailingslashit ( dirname ( $file ) ) );
2021-04-23 10:51:05 -04:00
2015-05-06 14:37:25 -04:00
if ( empty ( $gen_dir ) ) {
continue ;
}
2020-01-28 19:45:18 -05:00
// The path when the file is accessed via WP_Filesystem may differ in the case of FTP.
2015-05-06 14:37:25 -04:00
$remote_file = $gen_dir . basename ( $file );
if ( ! $wp_filesystem -> exists ( $remote_file ) ) {
continue ;
}
if ( ! $wp_filesystem -> delete ( $remote_file , false , 'f' ) ) {
$wp_filesystem -> put_contents ( $remote_file , '' );
}
}
}
/**
* Recursively find Genericons example files in a given folder .
*
* @ ignore
* @ since 4.2 . 2
*
* @ param string $directory Directory path . Expects trailingslashed .
* @ return array
*/
function _upgrade_422_find_genericons_files_in_folder ( $directory ) {
$directory = trailingslashit ( $directory );
$files = array ();
2021-04-23 10:51:05 -04:00
if ( file_exists ( " { $directory } example.html " )
2023-06-28 06:09:29 -04:00
/*
* Note : str_contains () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
&& false !== strpos ( file_get_contents ( " { $directory } example.html " ), '<title>Genericons</title>' )
2021-04-23 10:51:05 -04:00
) {
2015-05-06 14:37:25 -04:00
$files [] = " { $directory } example.html " ;
}
2015-07-27 14:05:24 -04:00
$dirs = glob ( $directory . '*' , GLOB_ONLYDIR );
2021-07-31 06:32:56 -04:00
$dirs = array_filter (
$dirs ,
2023-09-12 11:23:18 -04:00
static function ( $dir ) {
2023-06-28 06:09:29 -04:00
/*
* Skip any node_modules directories .
*
* Note : str_contains () is not used here , as this file is included
* when updating from older WordPress versions , in which case
* the polyfills from wp - includes / compat . php may not be available .
*/
return false === strpos ( $dir , 'node_modules' );
2021-07-31 06:32:56 -04:00
}
);
2021-04-23 10:51:05 -04:00
2015-07-27 14:05:24 -04:00
if ( $dirs ) {
foreach ( $dirs as $dir ) {
$files = array_merge ( $files , _upgrade_422_find_genericons_files_in_folder ( $dir ) );
}
2015-05-06 14:37:25 -04:00
}
return $files ;
}
2015-11-08 20:22:28 -05:00
/**
* @ ignore
* @ since 4.4 . 0
*/
function _upgrade_440_force_deactivate_incompatible_plugins () {
if ( defined ( 'REST_API_VERSION' ) && version_compare ( REST_API_VERSION , '2.0-beta4' , '<=' ) ) {
deactivate_plugins ( array ( 'rest-api/plugin.php' ), true );
}
}
2021-06-18 08:14:01 -04:00
2021-11-15 14:59:03 -05:00
/**
* @ access private
* @ ignore
Update/Install: Deactivate Gutenberg plugin version older than 14.1.
Resolves a fatal error due to `get_template_hierarchy()` due to incompatible older Gutenberg versions.
[54269] introduced this new function for 6.1. The function was introduced in Gutenberg 13.9.0. However, it was not guarded to protect the plugin from when the function was loaded in Core. Gutenberg 14.1.0 added the `function_exists()` guard to protect the plugin from the fatal error.
Minimum compatible version:
This commit changes the Gutenberg minimum compatible version number to 14.1. For versions older than 14.1, the plugin will deactivate when upgrading Core to 6.1 or newer.
Function rename:
Past commits renamed the upgrade function by changing Core's version number. This commit renames the function to be generic, i.e. `_upgrade_core_deactivate_incompatible_plugins()` and adopts the `@since [reason]` strategy to track historical changes to the function.
Follow-up to [54269], [52199], [52166], [52165], [51180].
Props namithjawahar, hellofromTonya, azaozz, desrosj, ironprogrammer.
Fixes #56985.
Built from https://develop.svn.wordpress.org/trunk@54789
git-svn-id: http://core.svn.wordpress.org/trunk@54341 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-10 07:22:18 -05:00
* @ since 5.8 . 0
* @ since 5.9 . 0 The minimum compatible version of Gutenberg is 11.9 .
* @ since 6.1 . 1 The minimum compatible version of Gutenberg is 14.1 .
2023-10-10 11:07:24 -04:00
* @ since 6.4 . 0 The minimum compatible version of Gutenberg is 16.5 .
2024-01-30 06:41:17 -05:00
* @ since 6.5 . 0 The minimum compatible version of Gutenberg is 17.6 .
2021-11-15 14:59:03 -05:00
*/
Update/Install: Deactivate Gutenberg plugin version older than 14.1.
Resolves a fatal error due to `get_template_hierarchy()` due to incompatible older Gutenberg versions.
[54269] introduced this new function for 6.1. The function was introduced in Gutenberg 13.9.0. However, it was not guarded to protect the plugin from when the function was loaded in Core. Gutenberg 14.1.0 added the `function_exists()` guard to protect the plugin from the fatal error.
Minimum compatible version:
This commit changes the Gutenberg minimum compatible version number to 14.1. For versions older than 14.1, the plugin will deactivate when upgrading Core to 6.1 or newer.
Function rename:
Past commits renamed the upgrade function by changing Core's version number. This commit renames the function to be generic, i.e. `_upgrade_core_deactivate_incompatible_plugins()` and adopts the `@since [reason]` strategy to track historical changes to the function.
Follow-up to [54269], [52199], [52166], [52165], [51180].
Props namithjawahar, hellofromTonya, azaozz, desrosj, ironprogrammer.
Fixes #56985.
Built from https://develop.svn.wordpress.org/trunk@54789
git-svn-id: http://core.svn.wordpress.org/trunk@54341 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2022-11-10 07:22:18 -05:00
function _upgrade_core_deactivate_incompatible_plugins () {
2024-01-30 06:41:17 -05:00
if ( defined ( 'GUTENBERG_VERSION' ) && version_compare ( GUTENBERG_VERSION , '17.6' , '<' ) ) {
2021-11-17 12:45:00 -05:00
$deactivated_gutenberg [ 'gutenberg' ] = array (
'plugin_name' => 'Gutenberg' ,
'version_deactivated' => GUTENBERG_VERSION ,
2024-01-30 06:41:17 -05:00
'version_compatible' => '17.6' ,
2021-11-17 12:45:00 -05:00
);
if ( is_plugin_active_for_network ( 'gutenberg/gutenberg.php' ) ) {
$deactivated_plugins = get_site_option ( 'wp_force_deactivated_plugins' , array () );
$deactivated_plugins = array_merge ( $deactivated_plugins , $deactivated_gutenberg );
update_site_option ( 'wp_force_deactivated_plugins' , $deactivated_plugins );
} else {
$deactivated_plugins = get_option ( 'wp_force_deactivated_plugins' , array () );
$deactivated_plugins = array_merge ( $deactivated_plugins , $deactivated_gutenberg );
Options, Meta APIs: Explicitly pass `$autoload` parameter to when potentially adding new options.
It is recommended that for every option it is explicitly set whether to autoload it or not. This changeset updates relevant `update_option()` and `add_option()` calls.
Note that the `$autoload` parameter is only needed for `update_option()` if the option is potentially not present yet, i.e. the call will pass through to `add_option()`. Since WordPress core adds the majority of its options to the database during installation, only `update_option()` calls for dynamically added options need to be modified, which is what this changeset does.
As part of revisiting the autoload values for dynamically added WordPress core options, this changeset modifies some options to no longer be autoloaded, since they are only accessed in a few specific places that are not relevant for a regular request. These options are:
* `recently_activated`
* `_wp_suggested_policy_text_has_changed`
* `{upgradeLock}.lock`
* `dashboard_widget_options`
* `ftp_credentials`
* `adminhash`
* `nav_menu_options`
* `wp_force_deactivated_plugins`
* `delete_blog_hash`
* `allowedthemes`
* `{sessionId}_paused_extensions`
* `recovery_keys`
* `https_detection_errors`
* `fresh_site`
An upgrade routine is present as well that sets those options to no longer autoload for existing sites.
Props pbearne, flixos90, mukesh27, swissspidy, SergeyBiryukov, joemcgill, adamsilverstein.
Fixes #61103.
Built from https://develop.svn.wordpress.org/trunk@58975
git-svn-id: http://core.svn.wordpress.org/trunk@58371 1a063a9b-81f0-0310-95a4-ce76da25c4cd
2024-09-03 14:19:14 -04:00
update_option ( 'wp_force_deactivated_plugins' , $deactivated_plugins , false );
2021-11-17 12:45:00 -05:00
}
deactivate_plugins ( array ( 'gutenberg/gutenberg.php' ), true );
2021-06-18 08:14:01 -04:00
}
}