WC_REST_Data_Countries_Controller
        
        extends WC_REST_Data_Controller
    
    
            
            in package
            
        
    
    
    
        
            REST API Data countries controller class.
Tags
Table of Contents
- $namespace : string
- Endpoint namespace.
- $rest_base : string
- Route base.
- $_fields : null|array<string|int, mixed>
- Used to cache computed return fields.
- $_request : null|WP_REST_Request
- Used to verify if cached fields are for correct request object.
- batch_items() : array<string|int, mixed>
- Bulk create, update and delete items.
- get_country() : array<string|int, mixed>|mixed
- Get a list of countries and states.
- get_endpoint_args_for_item_schema() : array<string|int, mixed>
- Compatibility functions for WP 5.5, since custom types are not supported anymore.
- get_fields_for_response() : array<string|int, mixed>
- Gets an array of fields to be included on the response.
- get_item() : WP_Error|WP_REST_Response
- Return the list of states for a given country.
- get_item_permissions_check() : WP_Error|bool
- Check whether a given request has permission to read site settings.
- get_item_schema() : array<string|int, mixed>
- Get the location schema, conforming to JSON Schema.
- get_items() : WP_Error|WP_REST_Response
- Return the list of states for all countries.
- get_items_permissions_check() : WP_Error|bool
- Check whether a given request has permission to read site data.
- get_public_batch_schema() : array<string|int, mixed>
- Get the batch schema, conforming to JSON Schema.
- prepare_item_for_response() : WP_REST_Response
- Prepare the data object for response.
- register_routes() : mixed
- Register routes.
- validate_setting_checkbox_field() : string|WP_Error
- Validate checkbox based settings.
- validate_setting_image_width_field() : string|WP_Error
- Validate image_width based settings.
- validate_setting_multiselect_field() : array<string|int, mixed>|WP_Error
- Validate multiselect based settings.
- validate_setting_radio_field() : string|WP_Error
- Validate radio based settings.
- validate_setting_select_field() : string|WP_Error
- Validate select based settings.
- validate_setting_text_field() : string
- Validate a text value for a text based setting.
- validate_setting_textarea_field() : string
- Validate textarea based settings.
- add_additional_fields_schema() : array<string|int, mixed>
- Add the schema from additional fields to an schema array.
- add_meta_query() : array<string|int, mixed>
- Add meta query.
- adjust_wp_5_5_datatype_compatibility() : mixed
- Change datatypes `date-time` to string, and `mixed` to composite of all built in types. This is required for maintaining forward compatibility with WP 5.5 since custom post types are not supported anymore.
- check_batch_limit() : bool|WP_Error
- Check batch limit.
- get_meta_data_for_response() : array<string|int, mixed>
- Limit the contents of the meta_data property based on certain request parameters.
- get_normalized_rest_base() : string
- Get normalized rest base.
- prepare_links() : array<string|int, mixed>
- Prepare links for the request.
Properties
$namespace
Endpoint namespace.
    protected
        string
    $namespace
     = 'wc/v3'
        
    
$rest_base
Route base.
    protected
        string
    $rest_base
     = 'data/countries'
        
    
$_fields
Used to cache computed return fields.
    private
        null|array<string|int, mixed>
    $_fields
     = 
ull
        
    
$_request
Used to verify if cached fields are for correct request object.
    private
        null|WP_REST_Request
    $_request
     = 
ull
        
    
Methods
batch_items()
Bulk create, update and delete items.
    public
                batch_items(WP_REST_Request $request) : array<string|int, mixed>
        
        Parameters
- $request : WP_REST_Request
- 
                    Full details about the request. 
Return values
array<string|int, mixed> — Of WP_Error or WP_REST_Response.get_country()
Get a list of countries and states.
    public
                get_country(string $country_code, WP_REST_Request $request) : array<string|int, mixed>|mixed
        
        Parameters
- $country_code : string
- 
                    Country code. 
- $request : WP_REST_Request
- 
                    Request data. 
Return values
array<string|int, mixed>|mixed — Response data, ready for insertion into collection data.get_endpoint_args_for_item_schema()
Compatibility functions for WP 5.5, since custom types are not supported anymore.
    public
                get_endpoint_args_for_item_schema([string $method = WP_REST_Server::CREATABLE ]) : array<string|int, mixed>
        See @link https://core.trac.wordpress.org/changeset/48306
Parameters
- $method : string = WP_REST_Server::CREATABLE
- 
                    Optional. HTTP method of the request. 
Return values
array<string|int, mixed> — Endpoint arguments.get_fields_for_response()
Gets an array of fields to be included on the response.
    public
                get_fields_for_response(WP_REST_Request $request) : array<string|int, mixed>
        Included fields are based on item schema and _fields= request argument.
Updated from WordPress 5.3, included into this class to support old versions.
Parameters
- $request : WP_REST_Request
- 
                    Full details about the request. 
Tags
Return values
array<string|int, mixed> — Fields to be included in the response.get_item()
Return the list of states for a given country.
    public
                get_item(WP_REST_Request $request) : WP_Error|WP_REST_Response
        
        Parameters
- $request : WP_REST_Request
- 
                    Request data. 
Tags
Return values
WP_Error|WP_REST_Response —get_item_permissions_check()
Check whether a given request has permission to read site settings.
    public
                get_item_permissions_check(WP_REST_Request $request) : WP_Error|bool
        
        Parameters
- $request : WP_REST_Request
- 
                    Full details about the request. 
Return values
WP_Error|bool —get_item_schema()
Get the location schema, conforming to JSON Schema.
    public
                get_item_schema() : array<string|int, mixed>
        
    
    
    Tags
Return values
array<string|int, mixed> —get_items()
Return the list of states for all countries.
    public
                get_items(WP_REST_Request $request) : WP_Error|WP_REST_Response
        
        Parameters
- $request : WP_REST_Request
- 
                    Request data. 
Tags
Return values
WP_Error|WP_REST_Response —get_items_permissions_check()
Check whether a given request has permission to read site data.
    public
                get_items_permissions_check(WP_REST_Request $request) : WP_Error|bool
        
        Parameters
- $request : WP_REST_Request
- 
                    Full details about the request. 
Return values
WP_Error|bool —get_public_batch_schema()
Get the batch schema, conforming to JSON Schema.
    public
                get_public_batch_schema() : array<string|int, mixed>
        
    
    
        Return values
array<string|int, mixed> —prepare_item_for_response()
Prepare the data object for response.
    public
                prepare_item_for_response(object $item, WP_REST_Request $request) : WP_REST_Response
        
        Parameters
- $item : object
- 
                    Data object. 
- $request : WP_REST_Request
- 
                    Request object. 
Tags
Return values
WP_REST_Response — $response Response data.register_routes()
Register routes.
    public
                register_routes() : mixed
        
    
    
    Tags
Return values
mixed —validate_setting_checkbox_field()
Validate checkbox based settings.
    public
                validate_setting_checkbox_field(string $value, array<string|int, mixed> $setting) : string|WP_Error
        
        Parameters
- $value : string
- 
                    Value. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string|WP_Error —validate_setting_image_width_field()
Validate image_width based settings.
    public
                validate_setting_image_width_field(array<string|int, mixed> $values, array<string|int, mixed> $setting) : string|WP_Error
        
        Parameters
- $values : array<string|int, mixed>
- 
                    Values. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string|WP_Error —validate_setting_multiselect_field()
Validate multiselect based settings.
    public
                validate_setting_multiselect_field(array<string|int, mixed> $values, array<string|int, mixed> $setting) : array<string|int, mixed>|WP_Error
        
        Parameters
- $values : array<string|int, mixed>
- 
                    Values. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
array<string|int, mixed>|WP_Error —validate_setting_radio_field()
Validate radio based settings.
    public
                validate_setting_radio_field(string $value, array<string|int, mixed> $setting) : string|WP_Error
        
        Parameters
- $value : string
- 
                    Value. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string|WP_Error —validate_setting_select_field()
Validate select based settings.
    public
                validate_setting_select_field(string $value, array<string|int, mixed> $setting) : string|WP_Error
        
        Parameters
- $value : string
- 
                    Value. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string|WP_Error —validate_setting_text_field()
Validate a text value for a text based setting.
    public
                validate_setting_text_field(string $value, array<string|int, mixed> $setting) : string
        
        Parameters
- $value : string
- 
                    Value. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string —validate_setting_textarea_field()
Validate textarea based settings.
    public
                validate_setting_textarea_field(string $value, array<string|int, mixed> $setting) : string
        
        Parameters
- $value : string
- 
                    Value. 
- $setting : array<string|int, mixed>
- 
                    Setting. 
Tags
Return values
string —add_additional_fields_schema()
Add the schema from additional fields to an schema array.
    protected
                add_additional_fields_schema(array<string|int, mixed> $schema) : array<string|int, mixed>
        The type of object is inferred from the passed schema.
Parameters
- $schema : array<string|int, mixed>
- 
                    Schema array. 
Return values
array<string|int, mixed> —add_meta_query()
Add meta query.
    protected
                add_meta_query(array<string|int, mixed> $args, array<string|int, mixed> $meta_query) : array<string|int, mixed>
        
        Parameters
- $args : array<string|int, mixed>
- 
                    Query args. 
- $meta_query : array<string|int, mixed>
- 
                    Meta query. 
Tags
Return values
array<string|int, mixed> —adjust_wp_5_5_datatype_compatibility()
Change datatypes `date-time` to string, and `mixed` to composite of all built in types. This is required for maintaining forward compatibility with WP 5.5 since custom post types are not supported anymore.
    protected
                adjust_wp_5_5_datatype_compatibility(array<string|int, mixed> $endpoint_args) : mixed
        See @link https://core.trac.wordpress.org/changeset/48306
We still use the 'mixed' type, since if we convert to composite type everywhere, it won't work in 5.4 anymore because they require to define the full schema.
Parameters
- $endpoint_args : array<string|int, mixed>
- 
                    Schema with datatypes to convert. 
Return values
mixed — Schema with converted datatype.check_batch_limit()
Check batch limit.
    protected
                check_batch_limit(array<string|int, mixed> $items) : bool|WP_Error
        
        Parameters
- $items : array<string|int, mixed>
- 
                    Request items. 
Return values
bool|WP_Error —get_meta_data_for_response()
Limit the contents of the meta_data property based on certain request parameters.
    protected
                get_meta_data_for_response(WP_REST_Request $request, array<string|int, mixed> $meta_data) : array<string|int, mixed>
        Note that if both include_meta and exclude_meta are present in the request,
include_meta will take precedence.
Parameters
- $request : WP_REST_Request
- 
                    The request. 
- $meta_data : array<string|int, mixed>
- 
                    All of the meta data for an object. 
Return values
array<string|int, mixed> —get_normalized_rest_base()
Get normalized rest base.
    protected
                get_normalized_rest_base() : string
        
    
    
        Return values
string —prepare_links()
Prepare links for the request.
    protected
                prepare_links(object $item) : array<string|int, mixed>
        
        Parameters
- $item : object
- 
                    Data object. 
