🏨 Hotel Booking Enhancements: - Implemented Eagle Booking Advanced Pricing add-on - Added Booking.com-style rate management system - Created professional calendar interface for pricing - Integrated deals and discounts functionality 💰 Advanced Pricing Features: - Dynamic pricing models (per room, per person, per adult) - Base rates, adult rates, and child rates management - Length of stay discounts and early bird deals - Mobile rates and secret deals implementation - Seasonal promotions and flash sales 📅 Availability Management: - Real-time availability tracking - Stop sell and restriction controls - Closed to arrival/departure functionality - Minimum/maximum stay requirements - Automatic sold-out management 💳 Payment Integration: - Maintained Redsys payment gateway integration - Seamless integration with existing Eagle Booking - No modifications to core Eagle Booking plugin 🛠️ Technical Implementation: - Custom database tables for advanced pricing - WordPress hooks and filters integration - AJAX-powered admin interface - Data migration from existing Eagle Booking - Professional calendar view for revenue management 📊 Admin Interface: - Booking.com-style management dashboard - Visual rate and availability calendar - Bulk operations for date ranges - Statistics and analytics dashboard - Modal dialogs for quick editing 🔧 Code Quality: - WordPress coding standards compliance - Secure database operations with prepared statements - Proper input validation and sanitization - Error handling and logging - Responsive admin interface 🤖 Generated with Claude Code (https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
85 lines
2.0 KiB
PHP
85 lines
2.0 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 );
|
|
}
|
|
|
|
/** Load WordPress Bootstrap */
|
|
require_once dirname( __DIR__ ) . '/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'] ) ? sanitize_text_field( $_REQUEST['action'] ) : '';
|
|
|
|
// Reject invalid parameters.
|
|
if ( ! is_scalar( $action ) ) {
|
|
wp_die( '', 400 );
|
|
}
|
|
|
|
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 {
|
|
// If no action is registered, return a Bad Request response.
|
|
if ( ! has_action( "admin_post_nopriv_{$action}" ) ) {
|
|
wp_die( '', 400 );
|
|
}
|
|
|
|
/**
|
|
* 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 {
|
|
// If no action is registered, return a Bad Request response.
|
|
if ( ! has_action( "admin_post_{$action}" ) ) {
|
|
wp_die( '', 400 );
|
|
}
|
|
|
|
/**
|
|
* 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}" );
|
|
}
|
|
}
|