File: scripts.rb

package info (click to toggle)
ruby-html-proofer 3.19.4-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,040 kB
  • sloc: ruby: 3,203; sh: 9; makefile: 4; javascript: 1; php: 1
file content (42 lines) | stat: -rw-r--r-- 1,276 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# frozen_string_literal: true

class ScriptCheck < ::HTMLProofer::Check
  attr_reader :src

  def missing_src?
    !@script.src
  end

  def run
    @html.css('script').each do |node|
      @script = create_element(node)
      line = node.line
      content = node.content

      next if @script.ignore?
      next unless node.text.strip.empty?

      # does the script exist?
      if missing_src?
        add_issue('script is empty and has no src attribute', line: line, content: content)
      elsif @script.remote?
        add_to_external_urls(@script.src)
        check_sri(line, content) if @script.check_sri?
      elsif !@script.exists?
        add_issue("internal script #{@script.src} does not exist", line: line, content: content)
      end
    end

    external_urls
  end

  def check_sri(line, content)
    if !defined?(@script.integrity) && !defined?(@script.crossorigin)
      add_issue("SRI and CORS not provided in: #{@script.src}", line: line, content: content)
    elsif !defined?(@script.integrity)
      add_issue("Integrity is missing in: #{@script.src}", line: line, content: content)
    elsif !defined?(@script.crossorigin)
      add_issue("CORS not provided for external resource in: #{@script.src}", line: line, content: content)
    end
  end
end