C:\xampp\htdocs\landing\wp-content\plugins\wordpress-seo\src\surfaces\values\meta.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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
<?php

namespace Yoast\WP\SEO\Surfaces\Values;

use 
Exception;
use 
WPSEO_Replace_Vars;
use 
Yoast\WP\SEO\Context\Meta_Tags_Context;
use 
Yoast\WP\SEO\Integrations\Front_End_Integration;
use 
Yoast\WP\SEO\Presenters\Abstract_Indexable_Presenter;
use 
Yoast\WP\SEO\Presenters\Rel_Next_Presenter;
use 
Yoast\WP\SEO\Presenters\Rel_Prev_Presenter;
use 
Yoast\WP\SEO\Surfaces\Helpers_Surface;
use 
YoastSEO_Vendor\Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Meta value object.
 *
 * @property array       $breadcrumbs                       The breadcrumbs array for the current page.
 * @property string      $canonical                         The canonical URL for the current page.
 * @property string      $company_name                      The company name from the Knowledge graph settings.
 * @property int         $company_logo_id                   The attachment ID for the company logo.
 * @property string      $description                       The meta description for the current page, if set.
 * @property int         $estimated_reading_time_minutes    The estimated reading time in minutes for posts.
 * @property string      $main_schema_id                    Schema ID that points to the main Schema thing on the page, usually the webpage or article Schema piece.
 * @property string      $meta_description                  The meta description for the current page, if set.
 * @property string      $open_graph_article_author         The article:author value.
 * @property string      $open_graph_article_modified_time  The article:modified_time value.
 * @property string      $open_graph_article_published_time The article:published_time value.
 * @property string      $open_graph_article_publisher      The article:publisher value.
 * @property string      $open_graph_description            The og:description.
 * @property bool        $open_graph_enabled                Whether OpenGraph is enabled on this site.
 * @property string      $open_graph_fb_app_id              The Facebook App ID.
 * @property array       $open_graph_images                 The array of images we have for this page.
 * @property string      $open_graph_locale                 The og:locale for the current page.
 * @property string      $open_graph_publisher              The OpenGraph publisher reference.
 * @property string      $open_graph_site_name              The og:site_name.
 * @property string      $open_graph_title                  The og:title.
 * @property string      $open_graph_type                   The og:type.
 * @property string      $open_graph_url                    The og:url.
 * @property string      $page_type                         The Schema page type.
 * @property array       $robots                            An array of the robots values set for the current page.
 * @property string      $rel_next                          The next page in the series, if any.
 * @property string      $rel_prev                          The previous page in the series, if any.
 * @property array       $schema                            The entire Schema array for the current page.
 * @property string      $schema_page_type                  The Schema page type.
 * @property string      $site_name                         The site name from the Yoast SEO settings.
 * @property string      $site_represents                   Whether the site represents a 'person' or a 'company'.
 * @property array|false $site_represents_reference         The schema reference ID for what this site represents.
 * @property string      $site_url                          The site's main URL.
 * @property int         $site_user_id                      If the site represents a 'person', this is the ID of the accompanying user profile.
 * @property string      $title                             The SEO title for the current page.
 * @property string      $twitter_card                      The Twitter card type for the current page.
 * @property string      $twitter_creator                   The Twitter card author for the current page.
 * @property string      $twitter_description               The Twitter card description for the current page.
 * @property string      $twitter_image                     The Twitter card image for the current page.
 * @property string      $twitter_site                      The Twitter card site reference for the current page.
 * @property string      $twitter_title                     The Twitter card title for the current page.
 * @property string      $wordpress_site_name               The site name from the WordPress settings.
 */
class Meta {

    
/**
     * The container.
     *
     * @var ContainerInterface
     */
    
protected $container;

    
/**
     * The meta tags context.
     *
     * @var Meta_Tags_Context
     */
    
protected $context;

    
/**
     * The front end integration.
     *
     * @var Front_End_Integration
     */
    
protected $front_end;

    
/**
     * The helpers surface.
     *
     * @var Helpers_Surface
     */
    
protected $helpers;

    
/**
     * The replace vars helper
     *
     * @var WPSEO_Replace_Vars
     */
    
protected $replace_vars;

    
/**
     * Create a meta value object.
     *
     * @param Meta_Tags_Context  $context   The indexable presentation.
     * @param ContainerInterface $container The DI container.
     */
    
public function __construct(
        
Meta_Tags_Context $context,
        
ContainerInterface $container
    
) {
        
$this->container $container;
        
$this->context   $context;

        
$this->helpers      $this->container->getHelpers_Surface::class );
        
$this->replace_vars $this->container->getWPSEO_Replace_Vars::class );
        
$this->front_end    $this->container->getFront_End_Integration::class );
    }

    
/**
     * Returns the output as would be presented in the head.
     *
     * @return string The HTML output of the head.
     */
    
public function get_head() {
        
$presenters $this->front_end->get_presenters$this->context->page_type );

        if ( 
$this->context->page_type === 'Date_Archive' ) {
            
$callback   = function ( $presenter ) {
                return ! \
is_a$presenterRel_Next_Presenter::class )
                    && ! \
is_a$presenterRel_Prev_Presenter::class );
            };
            
$presenters = \array_filter$presenters$callback );
        }

        
$output '';

        
/** This filter is documented in src/integrations/front-end-integration.php */
        
$presentation = \apply_filters'wpseo_frontend_presentation'$this->context->presentation$this->context );
        foreach ( 
$presenters as $presenter ) {
            
$presenter->presentation $presentation;
            
$presenter->helpers      $this->helpers;
            
$presenter->replace_vars $this->replace_vars;

            
$presenter_output $presenter->present();
            if ( ! empty( 
$presenter_output ) ) {
                
$output .= $presenter_output . \PHP_EOL;
            }
        }

        return \
trim$output );
    }

    
/**
     * Magic getter for presenting values through the appropriate presenter, if it exists.
     *
     * @param string $name The property to get.
     *
     * @return mixed The value, as presented by teh appropriate presenter.
     *
     * @throws Exception If an invalid property is accessed.
     */
    
public function __get$name ) {
        
/** This filter is documented in src/integrations/front-end-integration.php */
        
$presentation = \apply_filters'wpseo_frontend_presentation'$this->context->presentation$this->context );

        if ( ! isset( 
$presentation->{$name} ) ) {
            if ( isset( 
$this->context->{$name} ) ) {
                
$this->{$name} = $this->context->{$name};
                return 
$this->{$name};
            }
            return 
null;
        }

        
$presenter_namespace 'Yoast\WP\SEO\Presenters\\';
        
$parts               = \explode'_'$name );
        if ( 
$parts[0] === 'twitter' ) {
            
$presenter_namespace .= 'Twitter\\';
            
$parts                = \array_slice$parts);
        }
        elseif ( 
$parts[0] === 'open' && $parts[1] === 'graph' ) {
            
$presenter_namespace .= 'Open_Graph\\';
            
$parts                = \array_slice$parts);
        }

        
$presenter_class $presenter_namespace . \implode'_', \array_map'ucfirst'$parts ) ) . '_Presenter';

        if ( \
class_exists$presenter_class ) ) {
            
/**
             * The indexable presenter.
             *
             * @var Abstract_Indexable_Presenter
             */
            
$presenter               = new $presenter_class();
            
$presenter->presentation $presentation;
            
$presenter->helpers      $this->helpers;
            
$presenter->replace_vars $this->replace_vars;
            
$value                   $presenter->get();
        }
        else {
            
$value $presentation->{$name};
        }

        
$this->{$name} = $value;
        return 
$this->{$name};
    }

    
/**
     * Magic isset for ensuring properties on the presentation are recognised.
     *
     * @param string $name The property to get.
     *
     * @return bool Whether or not the requested property exists.
     */
    
public function __isset$name ) {
        return isset( 
$this->context->presentation->{$name} );
    }

    
/**
     * Strips all nested dependencies from the debug info.
     *
     * @return array
     */
    
public function __debugInfo() {
        return [ 
'context' => $this->context ];
    }
}
x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586