<?php if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly } if ( ! class_exists( 'acf_validation' ) ) : #[AllowDynamicProperties] class acf_validation { /** * This function will setup the class functionality * * @type function * @date 5/03/2014 * @since 5.0.0 * * @param n/a * @return n/a */ function __construct() { // vars $this->errors = array(); // ajax add_action( 'wp_ajax_acf/validate_save_post', array( $this, 'ajax_validate_save_post' ) ); add_action( 'wp_ajax_nopriv_acf/validate_save_post', array( $this, 'ajax_validate_save_post' ) ); add_action( 'acf/validate_save_post', array( $this, 'acf_validate_save_post' ), 5 ); } /** * This function will add an error message for a field * * @type function * @date 25/11/2013 * @since 5.0.0 * * @param $input (string) name attribute of DOM elmenet * @param $message (string) error message * @return $post_id (int) */ function add_error( $input, $message ) { // add to array $this->errors[] = array( 'input' => $input, 'message' => $message, ); } /** * This function will return an error for a given input * * @type function * @date 5/03/2016 * @since 5.3.2 * * @param $input (string) name attribute of DOM elmenet * @return (mixed) */ function get_error( $input ) { // bail early if no errors if ( empty( $this->errors ) ) { return false; } // loop foreach ( $this->errors as $error ) { if ( $error['input'] === $input ) { return $error; } } // return return false; } /** * This function will return validation errors * * @type function * @date 25/11/2013 * @since 5.0.0 * * @param n/a * @return (array|boolean) */ function get_errors() { // bail early if no errors if ( empty( $this->errors ) ) { return false; } // return return $this->errors; } /** * This function will remove all errors * * @type function * @date 4/03/2016 * @since 5.3.2 * * @param n/a * @return n/a */ function reset_errors() { $this->errors = array(); } /** * Validates $_POST data via AJAX prior to save. * * @since 5.0.9 * * @return void */ public function ajax_validate_save_post() { if ( ! acf_verify_ajax() ) { wp_send_json_success( array( 'valid' => 0, 'errors' => array( array( 'input' => false, 'message' => __( 'ACF was unable to perform validation due to an invalid security nonce being provided.', 'acf' ), ), ), ) ); } $json = array( 'valid' => 1, 'errors' => 0, ); if ( acf_validate_save_post() ) { wp_send_json_success( $json ); } $json['valid'] = 0; $json['errors'] = acf_get_validation_errors(); wp_send_json_success( $json ); } /** * Loops over $_POST data and validates ACF values. * * @since 5.4.0 */ public function acf_validate_save_post() { // phpcs:disable WordPress.Security.NonceVerification.Missing -- Verified elsewhere. $post_type = acf_request_arg( 'post_type', false ); $screen = acf_request_arg( '_acf_screen', false ); if ( in_array( $screen, array( 'post_type', 'taxonomy', 'ui_options_page' ), true ) && in_array( $post_type, array( 'acf-post-type', 'acf-taxonomy', 'acf-ui-options-page' ), true ) ) { acf_validate_internal_post_type_values( $post_type ); } elseif ( acf_request_arg( 'acf_ui_options_page' ) ) { acf_validate_internal_post_type_values( 'acf-ui-options-page' ); } else { // Bail early if no matching $_POST. if ( empty( $_POST['acf'] ) ) { return; } acf_validate_values( $_POST['acf'], 'acf' ); // phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized } // phpcs:enable WordPress.Security.NonceVerification.Missing } } // initialize acf()->validation = new acf_validation(); endif; // class_exists check /** * Public functions * * alias of acf()->validation->function() * * @type function * @date 6/10/13 * @since 5.0.0 * * @param n/a * @return n/a */ function acf_add_validation_error( $input, $message = '' ) { return acf()->validation->add_error( $input, $message ); } function acf_get_validation_errors() { return acf()->validation->get_errors(); } function acf_get_validation_error() { return acf()->validation->get_error( $input ); } function acf_reset_validation_errors() { return acf()->validation->reset_errors(); } /** * This function will validate $_POST data and add errors * * @type function * @date 25/11/2013 * @since 5.0.0 * * @param $show_errors (boolean) if true, errors will be shown via a wp_die screen * @return (boolean) */ function acf_validate_save_post( $show_errors = false ) { // action do_action( 'acf/validate_save_post' ); // vars $errors = acf_get_validation_errors(); // bail early if no errors if ( ! $errors ) { return true; } // show errors if ( $show_errors ) { $message = '<h2>' . __( 'Validation failed', 'acf' ) . '</h2>'; $message .= '<ul>'; foreach ( $errors as $error ) { $message .= '<li>' . $error['message'] . '</li>'; } $message .= '</ul>'; // die wp_die( acf_esc_html( $message ), esc_html__( 'Validation failed', 'acf' ) ); } // return return false; } /** * This function will validate an array of field values * * @type function * @date 6/10/13 * @since 5.0.0 * * @param values (array) * @param $input_prefix (string) * @return n/a */ function acf_validate_values( $values, $input_prefix = '' ) { // bail early if empty if ( empty( $values ) ) { return; } // loop foreach ( $values as $key => $value ) { // vars $field = acf_get_field( $key ); $input = $input_prefix . '[' . $key . ']'; // bail early if not found if ( ! $field ) { continue; } // validate acf_validate_value( $value, $field, $input ); } } /** * This function will validate a field's value * * @type function * @date 6/10/13 * @since 5.0.0 * * @param n/a * @return n/a */ function acf_validate_value( $value, $field, $input ) { // vars $valid = true; $message = sprintf( __( '%s value is required', 'acf' ), $field['label'] ); // valid if ( $field['required'] ) { // valid is set to false if the value is empty, but allow 0 as a valid value if ( empty( $value ) && ! is_numeric( $value ) ) { $valid = false; } } /** * Filters whether the value is valid. * * @date 28/09/13 * @since 5.0.0 * * @param bool $valid The valid status. Return a string to display a custom error message. * @param mixed $value The value. * @param array $field The field array. * @param string $input The input element's name attribute. */ $valid = apply_filters( "acf/validate_value/type={$field['type']}", $valid, $value, $field, $input ); $valid = apply_filters( "acf/validate_value/name={$field['_name']}", $valid, $value, $field, $input ); $valid = apply_filters( "acf/validate_value/key={$field['key']}", $valid, $value, $field, $input ); $valid = apply_filters( 'acf/validate_value', $valid, $value, $field, $input ); // allow $valid to be a custom error message if ( ! empty( $valid ) && is_string( $valid ) ) { $message = $valid; $valid = false; } if ( ! $valid ) { acf_add_validation_error( $input, $message ); return false; } // return return true; }
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
Blocks | Folder | 0755 |
|
|
admin | Folder | 0755 |
|
|
ajax | Folder | 0755 |
|
|
api | Folder | 0755 |
|
|
fields | Folder | 0755 |
|
|
forms | Folder | 0755 |
|
|
legacy | Folder | 0755 |
|
|
locations | Folder | 0755 |
|
|
post-types | Folder | 0755 |
|
|
rest-api | Folder | 0755 |
|
|
walkers | Folder | 0755 |
|
|
acf-bidirectional-functions.php | File | 9.19 KB | 0644 |
|
acf-field-functions.php | File | 38.86 KB | 0644 |
|
acf-field-group-functions.php | File | 13.52 KB | 0644 |
|
acf-form-functions.php | File | 3.78 KB | 0644 |
|
acf-helper-functions.php | File | 16.14 KB | 0644 |
|
acf-hook-functions.php | File | 5.37 KB | 0644 |
|
acf-input-functions.php | File | 11.32 KB | 0644 |
|
acf-internal-post-type-functions.php | File | 18.2 KB | 0644 |
|
acf-meta-functions.php | File | 10.15 KB | 0644 |
|
acf-post-functions.php | File | 889 B | 0644 |
|
acf-post-type-functions.php | File | 7.25 KB | 0644 |
|
acf-taxonomy-functions.php | File | 6.3 KB | 0644 |
|
acf-user-functions.php | File | 2.32 KB | 0644 |
|
acf-utility-functions.php | File | 3.07 KB | 0644 |
|
acf-value-functions.php | File | 10.3 KB | 0644 |
|
acf-wp-functions.php | File | 6.53 KB | 0644 |
|
assets.php | File | 15.68 KB | 0644 |
|
class-acf-data.php | File | 6.68 KB | 0644 |
|
class-acf-internal-post-type.php | File | 22.65 KB | 0644 |
|
class-acf-site-health.php | File | 20.13 KB | 0644 |
|
compatibility.php | File | 12.32 KB | 0644 |
|
deprecated.php | File | 3.97 KB | 0644 |
|
fields.php | File | 12.29 KB | 0644 |
|
index.php | File | 43 B | 0644 |
|
l10n.php | File | 3.7 KB | 0644 |
|
local-fields.php | File | 15.96 KB | 0644 |
|
local-json.php | File | 14.3 KB | 0644 |
|
local-meta.php | File | 6.09 KB | 0644 |
|
locations.php | File | 8.19 KB | 0644 |
|
loop.php | File | 5.01 KB | 0644 |
|
media.php | File | 7.09 KB | 0644 |
|
rest-api.php | File | 383 B | 0644 |
|
revisions.php | File | 12.33 KB | 0644 |
|
third-party.php | File | 4.25 KB | 0644 |
|
upgrades.php | File | 11.13 KB | 0644 |
|
validation.php | File | 7.4 KB | 0644 |
|
wpml.php | File | 8 KB | 0644 |
|