/var/www/hkosl.com/aga/wp-content/plugins/wordpress-seo/admin/services/class-indexable.php


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
<?php
/**
 * WPSEO plugin file.
 *
 * @package WPSEO\Admin\Services
 */

/**
 * Represents the indexable service.
 */
class WPSEO_Indexable_Service {

    
/**
     * Retrieves an indexable.
     *
     * @param WP_REST_Request $request The request object.
     *
     * @return WP_REST_Response The response.
     */
    
public function get_indexableWP_REST_Request $request ) {
        
$object_type $request->get_param'object_type' );
        
$object_id   $request->get_param'object_id' );

        try {
            
$provider  $this->get_provider$object_type );
            
$indexable $provider->get$object_id );

            return new 
WP_REST_Response$indexable );
        }
        catch ( 
Exception $exception ) {
            return new 
WP_REST_Response$exception->getMessage(), 500 );
        }
    }

    
/**
     * Patches an indexable with the request parameters.
     *
     * @param WP_REST_Request $request The REST API request to process.
     *
     * @return WP_REST_Response The REST response.
     */
    
public function patch_indexableWP_REST_Request $request ) {
        
$object_type $request->get_param'object_type' );
        
$object_id   $request->get_param'object_id' );

        try {
            
$provider       $this->get_provider$object_type );
            
$patched_result $provider->patch$object_id$request->get_params() );

            return new 
WP_REST_Response$patched_result );
        }
        catch ( 
Exception $exception ) {
            return new 
WP_REST_Response$exception->getMessage(), 500 );
        }
    }

    
/**
     * Returns a provider based on the given object type.
     *
     * @param string $object_type The object type to get the provider for.
     *
     * @return WPSEO_Indexable_Service_Provider Instance of the service provider.
     *
     * @throws WPSEO_Invalid_Argument_Exception The invalid argument exception.
     */
    
protected function get_provider$object_type ) {
        
$object_type strtolower$object_type );

        if ( 
$object_type === 'post' ) {
            return new 
WPSEO_Indexable_Service_Post_Provider();
        }

        if ( 
$object_type === 'term' ) {
            return new 
WPSEO_Indexable_Service_Term_Provider();

        }

        throw 
WPSEO_Invalid_Argument_Exception::invalid_callable_parameter$object_type'provider' );
    }

    
/**
     * Handles the situation when the object type is unknown.
     *
     * @param string $object_type The unknown object type.
     *
     * @return WP_REST_Response The response.
     */
    
protected function handle_unknown_object_type$object_type ) {
        return new 
WP_REST_Response(
            
sprintf(
                
/* translators: %1$s expands to the requested indexable type  */
                
__'Unknown type %1$s''wordpress-seo' ),
                
$object_type
            
),
            
400
        
);
    }
}