class AmpHtmlResponseMarkupProcessor in Accelerated Mobile Pages (AMP) 8
Same name and namespace in other branches
- 8.2 src/Render/AmpHtmlResponseMarkupProcessor.php \Drupal\amp\Render\AmpHtmlResponseMarkupProcessor
Processes markup of HTML responses.
Hierarchy
- class \Drupal\amp\Render\AmpHtmlResponseMarkupProcessor
Expanded class hierarchy of AmpHtmlResponseMarkupProcessor
1 file declares its use of AmpHtmlResponseMarkupProcessor
- AmpHtmlResponseSubscriber.php in src/EventSubscriber/ AmpHtmlResponseSubscriber.php 
- Contains \Drupal\amp\EventSubscriber\AmpHtmlResponseSubscriber.
1 string reference to 'AmpHtmlResponseMarkupProcessor'
1 service uses AmpHtmlResponseMarkupProcessor
File
- src/Render/ AmpHtmlResponseMarkupProcessor.php, line 20 
- Contains \Drupal\amp\Render\AmpHtmlResponseMarkupProcessor.
Namespace
Drupal\amp\RenderView source
class AmpHtmlResponseMarkupProcessor {
  /**
   * The original content.
   *
   * @var string
   */
  protected $content;
  /**
   * The AMP-processed content.
   *
   * @var string
   */
  protected $ampContent;
  /**
   * The AMP library service.
   *
   * @var AMPService
   */
  protected $ampLibraryService;
  /**
   * The AMP library converter.
   *
   * @var \Lullabot\AMP\AMP
   */
  protected $ampConverter;
  /**
   * @var LoggerInterface
   */
  protected $logger;
  /**
   * @var ConfigFactoryInterface
   */
  protected $configFactory;
  /**
   * @var \Drupal\Core\Config\ImmutableConfig
   */
  protected $ampConfig;
  /**
   * Constructs an AmpHtmlResponseMarkupProcessor object.
   *
   * @param AMPService $amp_library_service
   *   An amp library service.
   *
   */
  public function __construct(AMPService $amp_library_service, LoggerInterface $logger, ConfigFactoryInterface $configFactoryInterface) {
    $this->ampService = $amp_library_service;
    $this->logger = $logger;
    $this->configFactory = $configFactoryInterface;
    $this->ampConfig = $this->configFactory
      ->get('amp.settings');
  }
  /**
   * Processes the content of a response into amp html.
   *
   * @param \Drupal\Core\Render\HtmlResponse $response
   *   The response to process.
   *
   * @return \Symfony\Component\HttpFoundation\Response
   *   The processed response, with the content updated to amp markup.
   *
   * @throws \InvalidArgumentException
   *   Thrown when the $response parameter is not the type of response object
   *   the processor expects.
   */
  public function processMarkupToAmp(HtmlResponse $response) {
    if (!$response instanceof HtmlResponse) {
      throw new \InvalidArgumentException('\\Drupal\\Core\\Render\\HtmlResponse instance expected.');
    }
    // Get a reference to the content.
    $this->content = $response
      ->getContent();
    // First check the config if full html warnings are on, if not then exit with unaltered response
    if (!$this->ampConfig
      ->get('amp_library_process_full_html')) {
      return $response;
    }
    $options = [
      'scope' => Scope::HTML_SCOPE,
    ];
    if ($this->ampConfig
      ->get('amp_library_process_statistics')) {
      $options += [
        'add_stats_html_comment' => true,
      ];
    }
    $this->ampConverter = $this->ampService
      ->createAMPConverter();
    $this->ampConverter
      ->loadHtml($this->content, $options);
    $this->ampContent = $this->ampConverter
      ->convertToAmpHtml();
    $request_uri = \Drupal::request()
      ->getRequestUri();
    $heading = "<h3>AMP PHP Library messages for {$request_uri}</h3>" . PHP_EOL;
    $heading .= 'To disable these notices goto <a href="/admin/config/content/amp">AMP configuration</a> and uncheck ' . '<em>Debugging: Add a notice in the Drupal log ...</em> in the AMP PHP Library Configuration fieldset' . PHP_EOL;
    if ($this->ampConfig
      ->get('amp_library_process_full_html_warnings')) {
      // Add any warnings that were generated
      $this->logger
        ->notice("{$heading} <pre>" . $this->ampConverter
        ->warningsHumanHtml() . '</pre>');
    }
    // Return the processed content.
    $response
      ->setContent($this->ampContent);
    return $response;
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| AmpHtmlResponseMarkupProcessor:: | protected | property | ||
| AmpHtmlResponseMarkupProcessor:: | protected | property | The AMP-processed content. | |
| AmpHtmlResponseMarkupProcessor:: | protected | property | The AMP library converter. | |
| AmpHtmlResponseMarkupProcessor:: | protected | property | The AMP library service. | |
| AmpHtmlResponseMarkupProcessor:: | protected | property | ||
| AmpHtmlResponseMarkupProcessor:: | protected | property | The original content. | |
| AmpHtmlResponseMarkupProcessor:: | protected | property | ||
| AmpHtmlResponseMarkupProcessor:: | public | function | Processes the content of a response into amp html. | |
| AmpHtmlResponseMarkupProcessor:: | public | function | Constructs an AmpHtmlResponseMarkupProcessor object. | 
