123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 |
- <?php
- /**
- * WPSEO plugin file.
- *
- * @package WPSEO\Frontend\Schema
- */
- /**
- * Returns schema Person data.
- *
- * @since 10.2
- */
- class WPSEO_Schema_Person implements WPSEO_Graph_Piece {
- /**
- * A value object with context variables.
- *
- * @var WPSEO_Schema_Context
- */
- private $context;
- /**
- * Array of the social profiles we display for a Person.
- *
- * @var string[]
- */
- private $social_profiles = [
- 'facebook',
- 'instagram',
- 'linkedin',
- 'pinterest',
- 'twitter',
- 'myspace',
- 'youtube',
- 'soundcloud',
- 'tumblr',
- 'wikipedia',
- ];
- /**
- * The Schema type we use for this class.
- *
- * @var string[]
- */
- protected $type = [
- 'Person',
- 'Organization',
- ];
- /**
- * The hash used for images.
- *
- * @var string
- */
- protected $image_hash;
- /**
- * WPSEO_Schema_Person constructor.
- *
- * @param WPSEO_Schema_Context $context A value object with context variables.
- */
- public function __construct( WPSEO_Schema_Context $context ) {
- $this->image_hash = WPSEO_Schema_IDs::PERSON_LOGO_HASH;
- $this->context = $context;
- }
- /**
- * Determine whether we should return Person schema.
- *
- * @return bool
- */
- public function is_needed() {
- if ( ( $this->context->site_represents === 'person' ) || is_author() ) {
- 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 );
- return $data;
- }
- /**
- * Determines a User ID for the Person data.
- *
- * @return bool|int User ID or false upon return.
- */
- protected function determine_user_id() {
- $user_id = $this->context->site_user_id;
- /**
- * 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 );
- }
- /**
- * Retrieve a list of social profile URLs for Person.
- *
- * @param int $user_id User ID.
- *
- * @return string[] $output A list of social profiles.
- */
- protected function get_social_profiles( $user_id ) {
- /**
- * Filter: 'wpseo_schema_person_social_profiles' - Allows filtering of social profiles per user.
- *
- * @param int $user_id The current user we're grabbing social profiles for.
- *
- * @api string[] $social_profiles The array of social profiles to retrieve. Each should be a user meta field
- * key. As they are retrieved using the WordPress function `get_the_author_meta`.
- */
- $social_profiles = apply_filters( 'wpseo_schema_person_social_profiles', $this->social_profiles, $user_id );
- $output = [];
- foreach ( $social_profiles as $profile ) {
- $social_url = $this->url_social_site( $profile, $user_id );
- if ( $social_url ) {
- $output[] = $social_url;
- }
- }
- return $output;
- }
- /**
- * Builds our array of Schema Person data for a given user ID.
- *
- * @param int $user_id The user ID to use.
- *
- * @return array An array of Schema Person data.
- */
- protected function build_person_data( $user_id ) {
- $user_data = get_userdata( $user_id );
- $data = [
- '@type' => $this->type,
- '@id' => WPSEO_Schema_Utils::get_user_schema_id( $user_id, $this->context ),
- 'name' => $user_data->display_name,
- ];
- $data = $this->add_image( $data, $user_data );
- if ( ! empty( $user_data->description ) ) {
- $data['description'] = $user_data->description;
- }
- $social_profiles = $this->get_social_profiles( $user_id );
- if ( is_array( $social_profiles ) ) {
- $data['sameAs'] = $social_profiles;
- }
- return $data;
- }
- /**
- * Returns an ImageObject for the persons avatar.
- *
- * @param array $data The Person schema.
- * @param \WP_User $user_data User data.
- *
- * @return array $data The Person schema.
- */
- protected function add_image( $data, $user_data ) {
- $schema_id = $this->context->site_url . $this->image_hash;
- $data = $this->set_image_from_options( $data, $schema_id );
- if ( ! isset( $data['image'] ) ) {
- $data = $this->set_image_from_avatar( $data, $user_data, $schema_id );
- }
- if ( is_array( $this->type ) && in_array( 'Organization', $this->type ) ) {
- $data['logo'] = [ '@id' => $schema_id ];
- }
- return $data;
- }
- /**
- * Generate the person image from our settings.
- *
- * @param array $data The Person schema.
- * @param string $schema_id The string used in the `@id` for the schema.
- *
- * @return array $data The Person schema.
- */
- private function set_image_from_options( $data, $schema_id ) {
- if ( $this->context->site_represents !== 'person' ) {
- return $data;
- }
- $person_logo_id = WPSEO_Image_Utils::get_attachment_id_from_settings( 'person_logo' );
- if ( $person_logo_id ) {
- $image = new WPSEO_Schema_Image( $schema_id );
- $data['image'] = $image->generate_from_attachment_id( $person_logo_id, $data['name'] );
- }
- return $data;
- }
- /**
- * Generate the person logo from gravatar.
- *
- * @param array $data The Person schema.
- * @param \WP_User $user_data User data.
- * @param string $schema_id The string used in the `@id` for the schema.
- *
- * @return array $data The Person schema.
- */
- private function set_image_from_avatar( $data, $user_data, $schema_id ) {
- // If we don't have an image in our settings, fall back to an avatar, if we're allowed to.
- $show_avatars = get_option( 'show_avatars' );
- if ( ! $show_avatars ) {
- return $data;
- }
- $url = get_avatar_url( $user_data->user_email );
- if ( empty( $url ) ) {
- return $data;
- }
- $schema_image = new WPSEO_Schema_Image( $schema_id );
- $data['image'] = $schema_image->simple_image_object( $url, $user_data->display_name );
- return $data;
- }
- /**
- * Returns an author's social site URL.
- *
- * @param string $social_site The social site to retrieve the URL for.
- * @param mixed $user_id The user ID to use function outside of the loop.
- *
- * @return string
- */
- protected function url_social_site( $social_site, $user_id = false ) {
- $url = get_the_author_meta( $social_site, $user_id );
- if ( ! empty( $url ) ) {
- switch ( $social_site ) {
- case 'twitter':
- $url = 'https://twitter.com/' . $url;
- break;
- }
- }
- return $url;
- }
- }
|