mirror of
https://github.com/WordPress/WordPress.git
synced 2025-01-03 15:08:10 +01:00
4fa5437fc1
This matches the authentication check in `admin-ajax.php`, and allows the authentication method to be filtered. Props jmdodd. Fixes #45475. Built from https://develop.svn.wordpress.org/trunk@44615 git-svn-id: http://core.svn.wordpress.org/trunk@44446 1a063a9b-81f0-0310-95a4-ce76da25c4cd
73 lines
1.7 KiB
PHP
73 lines
1.7 KiB
PHP
<?php
|
|
/**
|
|
* WordPress Generic Request (POST/GET) Handler
|
|
*
|
|
* Intended for form submission handling in themes and plugins.
|
|
*
|
|
* @package WordPress
|
|
* @subpackage Administration
|
|
*/
|
|
|
|
/** We are located in WordPress Administration Screens */
|
|
if ( ! defined( 'WP_ADMIN' ) ) {
|
|
define( 'WP_ADMIN', true );
|
|
}
|
|
|
|
if ( defined( 'ABSPATH' ) ) {
|
|
require_once( ABSPATH . 'wp-load.php' );
|
|
} else {
|
|
require_once( dirname( dirname( __FILE__ ) ) . '/wp-load.php' );
|
|
}
|
|
|
|
/** Allow for cross-domain requests (from the front end). */
|
|
send_origin_headers();
|
|
|
|
require_once( ABSPATH . 'wp-admin/includes/admin.php' );
|
|
|
|
nocache_headers();
|
|
|
|
/** This action is documented in wp-admin/admin.php */
|
|
do_action( 'admin_init' );
|
|
|
|
$action = empty( $_REQUEST['action'] ) ? '' : $_REQUEST['action'];
|
|
|
|
if ( ! is_user_logged_in() ) {
|
|
if ( empty( $action ) ) {
|
|
/**
|
|
* Fires on a non-authenticated admin post request where no action is supplied.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( 'admin_post_nopriv' );
|
|
} else {
|
|
/**
|
|
* Fires on a non-authenticated admin post request for the given action.
|
|
*
|
|
* The dynamic portion of the hook name, `$action`, refers to the given
|
|
* request action.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( "admin_post_nopriv_{$action}" );
|
|
}
|
|
} else {
|
|
if ( empty( $action ) ) {
|
|
/**
|
|
* Fires on an authenticated admin post request where no action is supplied.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( 'admin_post' );
|
|
} else {
|
|
/**
|
|
* Fires on an authenticated admin post request for the given action.
|
|
*
|
|
* The dynamic portion of the hook name, `$action`, refers to the given
|
|
* request action.
|
|
*
|
|
* @since 2.6.0
|
|
*/
|
|
do_action( "admin_post_{$action}" );
|
|
}
|
|
}
|