You are here

class InvalidCertificatesRequirement in Acquia Content Hub 8

Defines a requirement to check for invalid certificates.

Plugin annotation


@ContentHubRequirement(
  id = "invalid_certificates",
  title = @Translation("Invalid certificates"),
)

Hierarchy

Expanded class hierarchy of InvalidCertificatesRequirement

File

acquia_contenthub_diagnostic/src/Plugin/ContentHubRequirement/InvalidCertificatesRequirement.php, line 15

Namespace

Drupal\acquia_contenthub_diagnostic\Plugin\ContentHubRequirement
View source
class InvalidCertificatesRequirement extends ContentHubRequirementBase {

  /**
   * Verify SSL certificates.
   *
   * Request to the HTTPS version of the site. If it fails at all or the
   * response status is not 200 then the requirement fails.
   */
  public function verify() {
    $domain = $this
      ->getDomain();
    try {
      $client = \Drupal::httpClient();
      $request = $client
        ->get($domain);
      if ($request
        ->getStatusCode() != 200) {
        throw new \Exception($this
          ->t('Status 200 not returned.'));
      }
    } catch (\Exception $e) {
      $this
        ->setValue($this
        ->t('Certificate cannot be validated'));
      $this
        ->setDescription($this
        ->t("Your site's homepage could not be reached over HTTPS. Verify your server configuration to ensure the site is reachable via HTTPS and uses valid SSL certificates. Error: @error", [
        '@error' => $e
          ->getMessage(),
      ]));
      return REQUIREMENT_ERROR;
    }
    return REQUIREMENT_OK;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
ContentHubRequirementBase::$description protected property The description of the requirement/status. 1
ContentHubRequirementBase::$moduleHandler protected property The module handler.
ContentHubRequirementBase::$severity protected property The requirement's result/severity level.
ContentHubRequirementBase::$value protected property The current value.
ContentHubRequirementBase::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create
ContentHubRequirementBase::description public function Returns the description of the requirement/status. Overrides ContentHubRequirementInterface::description 1
ContentHubRequirementBase::getDomain protected function Get the domain to run the tests on.
ContentHubRequirementBase::setDescription protected function Sets the description of the requirement/status.
ContentHubRequirementBase::setValue protected function Sets the current value.
ContentHubRequirementBase::severity public function Returns the requirement's result/severity level. Overrides ContentHubRequirementInterface::severity
ContentHubRequirementBase::title public function Returns the name of the requirement. Overrides ContentHubRequirementInterface::title
ContentHubRequirementBase::value public function Returns the current value. Overrides ContentHubRequirementInterface::value
ContentHubRequirementBase::__construct public function Constructs a new ContentHubRequirementBase. Overrides PluginBase::__construct
DependencySerializationTrait::$_entityStorages protected property An array of entity type IDs keyed by the property name of their storages.
DependencySerializationTrait::$_serviceIds protected property An array of service IDs keyed by property name used for serialization.
DependencySerializationTrait::__sleep public function 1
DependencySerializationTrait::__wakeup public function 2
InvalidCertificatesRequirement::verify public function Verify SSL certificates. Overrides ContentHubRequirementBase::verify
MessengerTrait::$messenger protected property The messenger. 29
MessengerTrait::messenger public function Gets the messenger. 29
MessengerTrait::setMessenger public function Sets the messenger.
PluginBase::$configuration protected property Configuration information passed into the plugin. 1
PluginBase::$pluginDefinition protected property The plugin implementation definition. 1
PluginBase::$pluginId protected property The plugin_id.
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition 3
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.
StringTranslationTrait::$stringTranslation protected property The string translation service. 1
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.