123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145 |
- <?php
- /**
- * WPSEO plugin file.
- *
- * @package WPSEO\Frontend\Schema
- */
- /**
- * Returns schema Person data.
- *
- * @since 10.2
- *
- * @property WPSEO_Schema_Context $context A value object with context variables.
- */
- class WPSEO_Schema_Author extends WPSEO_Schema_Person implements WPSEO_Graph_Piece {
- /**
- * A value object with context variables.
- *
- * @var WPSEO_Schema_Context
- */
- private $context;
- /**
- * The Schema type we use for this class.
- *
- * @var string[]
- */
- protected $type = [ 'Person' ];
- /**
- * WPSEO_Schema_Author constructor.
- *
- * @param WPSEO_Schema_Context $context A value object with context variables.
- */
- public function __construct( WPSEO_Schema_Context $context ) {
- parent::__construct( $context );
- $this->context = $context;
- $this->image_hash = WPSEO_Schema_IDs::AUTHOR_LOGO_HASH;
- }
- /**
- * Determine whether we should return Person schema.
- *
- * @return bool
- */
- public function is_needed() {
- if ( is_author() ) {
- return true;
- }
- if ( $this->is_post_author() ) {
- $post = get_post( $this->context->id );
- // If the author is the user the site represents, no need for an extra author block.
- if ( (int) $post->post_author === $this->context->site_user_id ) {
- return false;
- }
- return true;
- }
- return false;
- }
- /**
- * Returns Person Schema data.
- *
- * @return bool|array Person data on success, false on failure.
- */
- public function generate() {
- $user_id = $this->determine_user_id();
- if ( ! $user_id ) {
- return false;
- }
- $data = $this->build_person_data( $user_id );
- // If this is an author page, the Person object is the main object, so we set it as such here.
- if ( is_author() ) {
- $data['mainEntityOfPage'] = [
- '@id' => $this->context->canonical . WPSEO_Schema_IDs::WEBPAGE_HASH,
- ];
- }
- return $data;
- }
- /**
- * Determine whether the current URL is worthy of Article schema.
- *
- * @return bool
- */
- protected function is_post_author() {
- if ( is_singular() && WPSEO_Schema_Article::is_article_post_type() ) {
- return true;
- }
- return false;
- }
- /**
- * Determines a User ID for the Person data.
- *
- * @return bool|int User ID or false upon return.
- */
- protected function determine_user_id() {
- switch ( true ) {
- case is_author():
- $user_id = get_queried_object_id();
- break;
- default:
- $post = get_post( $this->context->id );
- $user_id = (int) $post->post_author;
- break;
- }
- /**
- * Filter: 'wpseo_schema_person_user_id' - Allows filtering of user ID used for person output.
- *
- * @api int|bool $user_id The user ID currently determined.
- */
- return apply_filters( 'wpseo_schema_person_user_id', $user_id );
- }
- /**
- * An author should not have an image from options, this only applies to persons.
- *
- * @param array $data The Person schema.
- * @param string $schema_id The string used in the `@id` for the schema.
- *
- * @return array The Person schema.
- */
- private function set_image_from_options( $data, $schema_id ) {
- return $data;
- }
- /**
- * Gets the Schema type we use for this class.
- *
- * @return string[] The schema type.
- */
- public static function get_type() {
- return self::$type;
- }
- }
|