HEX
Server: LiteSpeed
System: Linux server240.web-hosting.com 4.18.0-553.45.1.lve.el8.x86_64 #1 SMP Wed Mar 26 12:08:09 UTC 2025 x86_64
User: creaqbdc (8964)
PHP: 8.0.30
Disabled: NONE
Upload Files
File: //proc/self/cwd/wp-content/plugins/wordpress-seo-premium/src/integrations/third-party/mastodon.php
<?php

namespace Yoast\WP\SEO\Premium\Integrations\Third_Party;

use Yoast\WP\SEO\Conditionals\No_Conditionals;
use Yoast\WP\SEO\Helpers\Options_Helper;
use Yoast\WP\SEO\Helpers\Social_Profiles_Helper;
use Yoast\WP\SEO\Integrations\Integration_Interface;

/**
 * Mastodon integration.
 */
class Mastodon implements Integration_Interface {

	use No_Conditionals;

	/**
	 * Holds the options helper.
	 *
	 * @var Options_Helper
	 */
	protected $options_helper;

	/**
	 * Holds the social profiles helper.
	 *
	 * @var Social_Profiles_Helper
	 */
	protected $social_profiles_helper;

	/**
	 * Sets the helpers.
	 *
	 * @param Options_Helper         $options_helper         Options helper.
	 * @param Social_Profiles_Helper $social_profiles_helper Social Profiles helper.
	 */
	public function __construct( Options_Helper $options_helper, Social_Profiles_Helper $social_profiles_helper ) {
		$this->options_helper         = $options_helper;
		$this->social_profiles_helper = $social_profiles_helper;
	}

	/**
	 * Initializes the integration.
	 *
	 * This is the place to register hooks and filters.
	 *
	 * @return void
	 */
	public function register_hooks() {
		\add_filter( 'wpseo_frontend_presenter_classes', [ $this, 'add_social_link_tags' ], 10, 2 );
		\add_filter( 'wpseo_person_social_profile_fields', [ $this, 'add_mastodon_to_person_social_profile_fields' ], 11, 1 );
		\add_filter( 'wpseo_organization_social_profile_fields', [ $this, 'add_mastodon_to_organization_social_profile_fields' ], 11, 1 );
		\add_filter( 'wpseo_schema_person_social_profiles', [ $this, 'add_mastodon_to_person_schema' ], 10 );
		\add_filter( 'wpseo_mastodon_active', [ $this, 'check_mastodon_active' ], 10 );
	}

	/**
	 * Adds the social profiles presenter to the list of presenters to use.
	 *
	 * @param array  $presenters The list of presenters.
	 * @param string $page_type  The page type for which the presenters have been collected.
	 *
	 * @return array
	 */
	public function add_social_link_tags( $presenters, $page_type ) {
		// Bail out early if something's wrong with the presenters, let's not add any more confusion there.
		if ( ! \is_array( $presenters ) ) {
			return $presenters;
		}

		if ( \in_array( $page_type, [ 'Static_Home_Page', 'Home_Page' ], true ) ) {
			$presenters = \array_merge( $presenters, [ 'Yoast\WP\SEO\Premium\Presenters\Mastodon_Link_Presenter' ] );
		}

		return $presenters;
	}

	/**
	 * Adds Mastodon to the list of social profiles.
	 *
	 * @param array $social_profile_fields The social profiles array.
	 *
	 * @return array The updated social profiles array.
	 */
	public function add_mastodon_to_person_social_profile_fields( $social_profile_fields ) {
		// Bail out early if something's wrong with the social profiles, let's not add any more confusion there.
		if ( ! \is_array( $social_profile_fields ) ) {
			return $social_profile_fields;
		}
		$social_profile_fields['mastodon'] = 'get_non_valid_url';

		return $social_profile_fields;
	}

	/**
	 * Adds Mastodon to the list of social profiles.
	 *
	 * @param array $social_profile_fields The social profiles array.
	 *
	 * @return array The updated social profiles array.
	 */
	public function add_mastodon_to_organization_social_profile_fields( $social_profile_fields ) {
		// Bail out early if something's wrong with the social profiles, let's not add any more confusion there.
		if ( ! \is_array( $social_profile_fields ) ) {
			return $social_profile_fields;
		}
		$social_profile_fields['mastodon_url'] = 'get_non_valid_url';

		return $social_profile_fields;
	}

	/**
	 * Adds Mastodon to the list of social profiles to add to a Person's Schema.
	 *
	 * @param array $social_profiles The social profiles array.
	 *
	 * @return array
	 */
	public function add_mastodon_to_person_schema( $social_profiles ) {
		// Bail out early if something's wrong with the social profiles, let's not add any more confusion there.
		if ( ! \is_array( $social_profiles ) ) {
			return $social_profiles;
		}
		$social_profiles[] = 'mastodon';

		return $social_profiles;
	}

	/**
	 * Adds Mastodon to the list of contact methods for persons.
	 *
	 * @deprecated 22.6
	 * @codeCoverageIgnore
	 *
	 * @param array $contactmethods Currently set contactmethods.
	 *
	 * @return array
	 */
	public function add_mastodon_to_user_contactmethods( $contactmethods ) {
		\_deprecated_function( __METHOD__, 'Yoast SEO 22.6' );

		// Bail out early if something's wrong with the contact methods, let's not add any more confusion there.
		if ( ! \is_array( $contactmethods ) ) {
			return $contactmethods;
		}

		$contactmethods['mastodon'] = \__( 'Mastodon profile URL', 'wordpress-seo-premium' );

		return $contactmethods;
	}

	/**
	 * Checks if the Mastodon field is filled in.
	 *
	 * @param bool $state The current state of the integration.
	 *
	 * @return bool
	 */
	public function check_mastodon_active( $state ) {
		switch ( $this->options_helper->get( 'company_or_person', false ) ) {
			case 'company':
				$social_profiles = $this->social_profiles_helper->get_organization_social_profiles();
				if ( ! empty( $social_profiles['mastodon_url'] ) ) {
					return true;
				}
				break;

			case 'person':
				$company_or_person_id = $this->options_helper->get( 'company_or_person_user_id', 0 );
				$social_profiles      = $this->social_profiles_helper->get_person_social_profiles( $company_or_person_id );
				if ( ! empty( $social_profiles['mastodon'] ) ) {
					return true;
				}
				break;
		}

		return $state;
	}
}