From ee55a1de9b1e33c4fc9a49c1a34ae165382a51d5 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Mon, 8 Apr 2024 17:21:34 -0500 Subject: [PATCH 01/21] add check for cname->domain->pages --- lib/github-pages-health-check/domain.rb | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 4826f65..a6ec949 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -240,7 +240,18 @@ def non_github_pages_ip_present? # Is the domain's first response a CNAME to a pages domain? def cname_to_github_user_domain? - cname? && !cname_to_pages_dot_github_dot_com? && cname.pages_domain? + # If the domain does not match check if the host value points to a pages + # domain. + # + # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid + if cname? && !cname_to_pages_dot_github_dot_com? && !cname.pages_domain? + # Check if the host does point to 'Pages' + if !cname.pages_domain? + return self.redundant(host) + end + # CNAME points to 'Pages' nothing left to do + return true + end end # Is the given domain a CNAME to pages.github.(io|com) From 010b0372f94b4b8005f440733d09af7ae28742e1 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Mon, 8 Apr 2024 17:50:17 -0500 Subject: [PATCH 02/21] start testing --- lib/github-pages-health-check/domain.rb | 9 ++++----- spec/github_pages_health_check/domain_spec.rb | 16 ++++++++++++++++ 2 files changed, 20 insertions(+), 5 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index a6ec949..f8d75ec 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -238,19 +238,18 @@ def non_github_pages_ip_present? .any? { |a| !github_pages_ip?(a.address.to_s) } end - # Is the domain's first response a CNAME to a pages domain? + # Is the domain's first response a CNAME to a pages domain or a domain to pages? def cname_to_github_user_domain? # If the domain does not match check if the host value points to a pages # domain. # # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid - if cname? && !cname_to_pages_dot_github_dot_com? && !cname.pages_domain? + if cname? && !cname_to_pages_dot_github_dot_com? # Check if the host does point to 'Pages' - if !cname.pages_domain? - return self.redundant(host) + if cname.pages_domain? + return true end # CNAME points to 'Pages' nothing left to do - return true end end diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 878eda1..1777dbc 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -429,6 +429,22 @@ expect(subject).to be_a_cname_to_github_user_domain end end + + focus + context "to domain that points to pages" do + let(:cname) { "octocat.com" } + before do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME example.com"), + Dnsruby::RR.create("example.com 1000 IN A 192.168.0.1") + ] + end + end + + it "follows the CNAME all the way down" do + end + end end end From 2eea686bc165bad5b1f8f2852c3b9d31ffe8d2ae Mon Sep 17 00:00:00 2001 From: tsusdere Date: Tue, 9 Apr 2024 11:23:28 -0500 Subject: [PATCH 03/21] add check for CNAME host --- lib/github-pages-health-check/domain.rb | 6 ++++-- spec/github_pages_health_check/domain_spec.rb | 16 ---------------- 2 files changed, 4 insertions(+), 18 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index f8d75ec..6b8fb93 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -245,11 +245,13 @@ def cname_to_github_user_domain? # # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid if cname? && !cname_to_pages_dot_github_dot_com? - # Check if the host does point to 'Pages' + # CNAME points to Pages if cname.pages_domain? return true + # CNAME points to a domain which might point to Pages + else + return Domain.redundant(host) end - # CNAME points to 'Pages' nothing left to do end end diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 1777dbc..878eda1 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -429,22 +429,6 @@ expect(subject).to be_a_cname_to_github_user_domain end end - - focus - context "to domain that points to pages" do - let(:cname) { "octocat.com" } - before do - allow(subject).to receive(:dns) do - [ - Dnsruby::RR.create("#{cname}. 1000 IN CNAME example.com"), - Dnsruby::RR.create("example.com 1000 IN A 192.168.0.1") - ] - end - end - - it "follows the CNAME all the way down" do - end - end end end From 0ea9a331eb5e439cae4340fb95081b34a7d655e2 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Tue, 9 Apr 2024 11:36:12 -0500 Subject: [PATCH 04/21] simplify check --- lib/github-pages-health-check/domain.rb | 12 ++---------- 1 file changed, 2 insertions(+), 10 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 6b8fb93..ffb10b1 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -238,21 +238,13 @@ def non_github_pages_ip_present? .any? { |a| !github_pages_ip?(a.address.to_s) } end - # Is the domain's first response a CNAME to a pages domain or a domain to pages? + # Is the domain's first response a CNAME to a pages domain? def cname_to_github_user_domain? # If the domain does not match check if the host value points to a pages # domain. # # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid - if cname? && !cname_to_pages_dot_github_dot_com? - # CNAME points to Pages - if cname.pages_domain? - return true - # CNAME points to a domain which might point to Pages - else - return Domain.redundant(host) - end - end + cname? && !cname_to_pages_dot_github_dot_com? && (cname.pages_domain? || Domain.redundant(host)) end # Is the given domain a CNAME to pages.github.(io|com) From e12ea4334a8fe686aaa3d075fd00b22b80569e94 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Tue, 9 Apr 2024 13:29:26 -0500 Subject: [PATCH 05/21] add test to check CNAMe points to pages IP --- lib/github-pages-health-check/domain.rb | 3 ++- spec/github_pages_health_check/domain_spec.rb | 23 +++++++++++++++++++ 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index ffb10b1..2fef2c6 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -244,7 +244,8 @@ def cname_to_github_user_domain? # domain. # # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid - cname? && !cname_to_pages_dot_github_dot_com? && (cname.pages_domain? || Domain.redundant(host)) + binding.pry + cname? && !cname_to_pages_dot_github_dot_com? && (cname.pages_domain?) end # Is the given domain a CNAME to pages.github.(io|com) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 878eda1..190e9cc 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -240,6 +240,29 @@ end end + context "CNAME to Domain to Pages", focus: true do + let(:cname) { "www.fontawesome.it" } + let(:domain) { "fontawesome.it" } + let(:ip) { "185.199.108.153" } + before do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), + a_packet, + ] + end + end + + it "follows the CNAMEs all the way down" do + expect(subject.cname.host).to eq("fontawesome.it") + end + + it "knows it's a Pages IP at the end" do + binding.require 'pry'; binding.pry + end + end + + context "broken CNAMEs" do before do allow(subject).to receive(:dns) do From d02c892f38303e82cd681c8a57ac1fc58bd73e3c Mon Sep 17 00:00:00 2001 From: tsusdere Date: Tue, 9 Apr 2024 15:02:11 -0500 Subject: [PATCH 06/21] get the domain that points to pages --- lib/github-pages-health-check/domain.rb | 21 +++++++++++-------- spec/github_pages_health_check/domain_spec.rb | 2 +- 2 files changed, 13 insertions(+), 10 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 2fef2c6..69c130d 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -91,7 +91,7 @@ class Domain < Checkable host uri nameservers dns_resolves? proxied? cloudflare_ip? fastly_ip? old_ip_address? a_record? aaaa_record? a_record_present? aaaa_record_present? cname_record? mx_records_present? valid_domain? apex_domain? - should_be_a_record? cname_to_github_user_domain? + should_be_a_record? cname_to_github_user_domain? cname_to_domain_to_pages? cname_to_pages_dot_github_dot_com? cname_to_fastly? pointed_to_github_pages_ip? non_github_pages_ip_present? pages_domain? served_by_pages? valid? reason valid_domain? https? @@ -240,12 +240,15 @@ def non_github_pages_ip_present? # Is the domain's first response a CNAME to a pages domain? def cname_to_github_user_domain? - # If the domain does not match check if the host value points to a pages - # domain. - # - # e.g 'www.domain.com' -> 'domain.com' -> 'Pages' is valid - binding.pry - cname? && !cname_to_pages_dot_github_dot_com? && (cname.pages_domain?) + cname? && !cname_to_pages_dot_github_dot_com? && cname.pages_domain? + end + + # Check if the CNAME points to a Domain that points to pages + # e.g. CNAME -> Domain -> Pages + def cname_to_domain_to_pages? + a_record_to_pages = dns.select { |d| d.type == Dnsruby::Types::A && d.name.to_s == host }.first + return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? + CURRENT_IP_ADDRESSES.include?(a_record_to_pages.address.to_s.downcase) end # Is the given domain a CNAME to pages.github.(io|com) @@ -309,6 +312,7 @@ def proxied? return true if cloudflare_ip? return false if pointed_to_github_pages_ip? return false if cname_to_github_user_domain? + return false if cname_to_domain_to_pages? return false if cname_to_pages_dot_github_dot_com? return false if cname_to_fastly? || fastly_ip? @@ -459,8 +463,7 @@ def https_eligible? return false if host.include?("_") # Must be a CNAME or point to our IPs. - # Only check the one domain if a CNAME. Don't check the parent domain. - return true if cname_to_github_user_domain? + return true if cname_to_github_user_domain? || cname_to_domain_to_pages? # Check CAA records for the full domain and its parent domain. pointed_to_github_pages_ip? && caa.lets_encrypt_allowed? diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 190e9cc..04cbedd 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -258,7 +258,7 @@ end it "knows it's a Pages IP at the end" do - binding.require 'pry'; binding.pry + expect(subject).to be_a_cname_to_domain_to_pages end end From 3f7dfc56451da427bed018e204ee7d55a0430892 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Wed, 10 Apr 2024 10:54:46 -0500 Subject: [PATCH 07/21] fix linting --- lib/github-pages-health-check/domain.rb | 6 ++++-- spec/github_pages_health_check/domain_spec.rb | 4 ++-- 2 files changed, 6 insertions(+), 4 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 69c130d..924b45a 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -243,11 +243,13 @@ def cname_to_github_user_domain? cname? && !cname_to_pages_dot_github_dot_com? && cname.pages_domain? end - # Check if the CNAME points to a Domain that points to pages - # e.g. CNAME -> Domain -> Pages + # Check if the CNAME points to a Domain that points to pages + # e.g. CNAME -> Domain -> Pages def cname_to_domain_to_pages? a_record_to_pages = dns.select { |d| d.type == Dnsruby::Types::A && d.name.to_s == host }.first + return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? + CURRENT_IP_ADDRESSES.include?(a_record_to_pages.address.to_s.downcase) end diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 04cbedd..0308036 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -240,7 +240,7 @@ end end - context "CNAME to Domain to Pages", focus: true do + context "CNAME to Domain to Pages" do let(:cname) { "www.fontawesome.it" } let(:domain) { "fontawesome.it" } let(:ip) { "185.199.108.153" } @@ -248,7 +248,7 @@ allow(subject).to receive(:dns) do [ Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), - a_packet, + a_packet ] end end From 8d25b396063aab1fdf5a2a9ec294287eddb0937b Mon Sep 17 00:00:00 2001 From: tsusdere Date: Wed, 10 Apr 2024 10:58:00 -0500 Subject: [PATCH 08/21] remove extra line --- spec/github_pages_health_check/domain_spec.rb | 1 - 1 file changed, 1 deletion(-) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 0308036..7a7a03f 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -262,7 +262,6 @@ end end - context "broken CNAMEs" do before do allow(subject).to receive(:dns) do From 54a4d605575439aee94fc8716b92d9321b224b6a Mon Sep 17 00:00:00 2001 From: tsusdere Date: Wed, 10 Apr 2024 11:36:36 -0500 Subject: [PATCH 09/21] add test to check not pages --- spec/github_pages_health_check/domain_spec.rb | 20 ++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 7a7a03f..4c049f5 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -244,7 +244,7 @@ let(:cname) { "www.fontawesome.it" } let(:domain) { "fontawesome.it" } let(:ip) { "185.199.108.153" } - before do + before(:each) do allow(subject).to receive(:dns) do [ Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), @@ -262,6 +262,24 @@ end end + context "CNAME to Domain that doesn't go to Pages" do + let(:cname) { "www.fontawesome.it" } + let(:domain) { "fontawesome.it" } + let(:ip) { "127.0.0.1" } + before(:each) do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), + a_packet + ] + end + end + + if "knows it's not a Pages IP at the end" do + expect(subject).to_not be_a_cname_to_domain_to_pages + end + end + context "broken CNAMEs" do before do allow(subject).to receive(:dns) do From 7034496a1d83f380ac7b1da30f4674f9cf1c353c Mon Sep 17 00:00:00 2001 From: tsusdere Date: Wed, 10 Apr 2024 11:38:39 -0500 Subject: [PATCH 10/21] fix typo --- spec/github_pages_health_check/domain_spec.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 4c049f5..46ace83 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -275,7 +275,7 @@ end end - if "knows it's not a Pages IP at the end" do + it "knows it's not a Pages IP at the end" do expect(subject).to_not be_a_cname_to_domain_to_pages end end From 5442f62f912b1ce32e829c9a7a81d4980fdf1285 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Wed, 10 Apr 2024 11:41:37 -0500 Subject: [PATCH 11/21] add random CNAME test --- spec/github_pages_health_check/domain_spec.rb | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 46ace83..c1e8f41 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -262,6 +262,24 @@ end end + context "Random CNAME to Domain that goes to Pages" do + let(:cname) { "monalisa" } + let(:domain) { "fontawesome.it" } + let(:ip) { "185.199.108.153" } + before(:each) do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), + a_packet + ] + end + end + + it "knows it's a Pages IP at the end" do + expect(subject).to be_a_cname_to_domain_to_pages + end + end + context "CNAME to Domain that doesn't go to Pages" do let(:cname) { "www.fontawesome.it" } let(:domain) { "fontawesome.it" } From b3c9a7a74e3ae84ebd2973c8ddfecb8036c66d34 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Fri, 12 Apr 2024 13:19:59 -0500 Subject: [PATCH 12/21] only support `www` cnames and bump version --- lib/github-pages-health-check/domain.rb | 4 +++- lib/github-pages-health-check/version.rb | 2 +- spec/github_pages_health_check/domain_spec.rb | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 924b45a..15db5fe 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -248,7 +248,7 @@ def cname_to_github_user_domain? def cname_to_domain_to_pages? a_record_to_pages = dns.select { |d| d.type == Dnsruby::Types::A && d.name.to_s == host }.first - return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? + return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? && @wwwcname CURRENT_IP_ADDRESSES.include?(a_record_to_pages.address.to_s.downcase) end @@ -410,6 +410,8 @@ def cname cnames = dns.take_while { |answer| answer.type == Dnsruby::Types::CNAME } return if cnames.empty? + # check to see if the CNAME starts with www + @wwwcname ||= cnames.last.name.to_s.start_with?("www") @cname ||= Domain.new(cnames.last.cname.to_s) end diff --git a/lib/github-pages-health-check/version.rb b/lib/github-pages-health-check/version.rb index 1271218..1d44c63 100644 --- a/lib/github-pages-health-check/version.rb +++ b/lib/github-pages-health-check/version.rb @@ -2,6 +2,6 @@ module GitHubPages module HealthCheck - VERSION = "1.18.2" + VERSION = "1.18.3" end end diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index c1e8f41..e8afde4 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -276,7 +276,7 @@ end it "knows it's a Pages IP at the end" do - expect(subject).to be_a_cname_to_domain_to_pages + expect(subject).to_not be_a_cname_to_domain_to_pages end end From e2ba6435197d2a69416c68ad554a1963435ddd1b Mon Sep 17 00:00:00 2001 From: Fabian Aguilar Gomez Date: Fri, 12 Apr 2024 13:22:04 -0500 Subject: [PATCH 13/21] Update domain_spec.rb --- spec/github_pages_health_check/domain_spec.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index e8afde4..47333a6 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -275,7 +275,7 @@ end end - it "knows it's a Pages IP at the end" do + it "CNAME does not start with www and no match to host" do expect(subject).to_not be_a_cname_to_domain_to_pages end end From cf8d395d73faa0f07934b5caa4f22b155fea16ed Mon Sep 17 00:00:00 2001 From: Fabian Aguilar Gomez Date: Fri, 12 Apr 2024 13:23:43 -0500 Subject: [PATCH 14/21] Update domain_spec.rb --- spec/github_pages_health_check/domain_spec.rb | 36 +++++++++++++++++++ 1 file changed, 36 insertions(+) diff --git a/spec/github_pages_health_check/domain_spec.rb b/spec/github_pages_health_check/domain_spec.rb index 47333a6..2161a99 100644 --- a/spec/github_pages_health_check/domain_spec.rb +++ b/spec/github_pages_health_check/domain_spec.rb @@ -280,6 +280,42 @@ end end + context "CNAME with same host but no www" do + let(:cname) { "blog.fontawesome.it" } + let(:domain) { "fontawesome.it" } + let(:ip) { "185.199.108.153" } + before(:each) do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), + a_packet + ] + end + end + + it "CNAME does not start with www and no match to host" do + expect(subject).to_not be_a_cname_to_domain_to_pages + end + end + + context "CNAME starts with www but different host" do + let(:cname) { "www.fontawesome.it" } + let(:domain) { "awesomefont.it" } + let(:ip) { "185.199.108.153" } + before(:each) do + allow(subject).to receive(:dns) do + [ + Dnsruby::RR.create("#{cname}. 1000 IN CNAME #{domain}"), + a_packet + ] + end + end + + it "CNAME does not match to host" do + expect(subject).to_not be_a_cname_to_domain_to_pages + end + end + context "CNAME to Domain that doesn't go to Pages" do let(:cname) { "www.fontawesome.it" } let(:domain) { "fontawesome.it" } From d67d170d3439a98f44d1a99e73fdc3d57fedece4 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Fri, 12 Apr 2024 13:38:55 -0500 Subject: [PATCH 15/21] add check for domain name --- lib/github-pages-health-check/domain.rb | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 15db5fe..da0634c 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -410,8 +410,8 @@ def cname cnames = dns.take_while { |answer| answer.type == Dnsruby::Types::CNAME } return if cnames.empty? - # check to see if the CNAME starts with www - @wwwcname ||= cnames.last.name.to_s.start_with?("www") + # check to see if the CNAME starts with www and domain name is the same + @wwwcname ||= cnames.last.name.to_s.start_with?("www") && cnames.last.name.to_s.end_with?(cnames.last.domainname.to_s) @cname ||= Domain.new(cnames.last.cname.to_s) end From a2b1ada3e35a867a7dfe87b54b049200331456e2 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Fri, 12 Apr 2024 13:40:57 -0500 Subject: [PATCH 16/21] lint --- lib/github-pages-health-check/domain.rb | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index da0634c..d36fcac 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -411,7 +411,9 @@ def cname return if cnames.empty? # check to see if the CNAME starts with www and domain name is the same - @wwwcname ||= cnames.last.name.to_s.start_with?("www") && cnames.last.name.to_s.end_with?(cnames.last.domainname.to_s) + @wwwcname ||= cnames.last.name.to_s.start_with?("www") && + cnames.last.name.to_s.end_with?(cnames.last.domainname.to_s) + @cname ||= Domain.new(cnames.last.cname.to_s) end From 0ca4bb0fcae046650c320369fd85efd03fd3d7b2 Mon Sep 17 00:00:00 2001 From: tsusdere Date: Fri, 12 Apr 2024 13:45:06 -0500 Subject: [PATCH 17/21] add method to check --- lib/github-pages-health-check/domain.rb | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index d36fcac..ac709a3 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -410,13 +410,16 @@ def cname cnames = dns.take_while { |answer| answer.type == Dnsruby::Types::CNAME } return if cnames.empty? - # check to see if the CNAME starts with www and domain name is the same - @wwwcname ||= cnames.last.name.to_s.start_with?("www") && - cnames.last.name.to_s.end_with?(cnames.last.domainname.to_s) - + www_cname(cname.last) @cname ||= Domain.new(cnames.last.cname.to_s) end + # Check if we have a 'www.' CNAME that matches the domain + def www_cname(cname) + @wwwcname || = cname.name.to_s.start_with("www.") && + cname.name.to_s.end_with?(cname.domainname.to_s) + end + def mx_records_present? return unless dns? From 2beccba21057e31d9c4b84db43452bb5b1e590d2 Mon Sep 17 00:00:00 2001 From: Fabian Aguilar Gomez Date: Fri, 12 Apr 2024 13:45:55 -0500 Subject: [PATCH 18/21] Update domain.rb --- lib/github-pages-health-check/domain.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index ac709a3..7c455de 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -410,7 +410,7 @@ def cname cnames = dns.take_while { |answer| answer.type == Dnsruby::Types::CNAME } return if cnames.empty? - www_cname(cname.last) + www_cname(cnames.last) @cname ||= Domain.new(cnames.last.cname.to_s) end From 4e3f79a49ea7419c7f170be5d2d72722e0118de0 Mon Sep 17 00:00:00 2001 From: Fabian Aguilar Gomez Date: Fri, 12 Apr 2024 13:47:21 -0500 Subject: [PATCH 19/21] Update domain.rb --- lib/github-pages-health-check/domain.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index 7c455de..d3d5e26 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -416,7 +416,7 @@ def cname # Check if we have a 'www.' CNAME that matches the domain def www_cname(cname) - @wwwcname || = cname.name.to_s.start_with("www.") && + @wwwcname ||= cname.name.to_s.start_with("www.") && cname.name.to_s.end_with?(cname.domainname.to_s) end From 68a64e84914d6468c7d1e8fb93d4b0c3eef34d34 Mon Sep 17 00:00:00 2001 From: Fabian Aguilar Gomez Date: Fri, 12 Apr 2024 13:48:46 -0500 Subject: [PATCH 20/21] Update domain.rb --- lib/github-pages-health-check/domain.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index d3d5e26..f2b7363 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -416,7 +416,7 @@ def cname # Check if we have a 'www.' CNAME that matches the domain def www_cname(cname) - @wwwcname ||= cname.name.to_s.start_with("www.") && + @wwwcname ||= cname.name.to_s.start_with?("www.") && cname.name.to_s.end_with?(cname.domainname.to_s) end From 49e4dad4eed41895a2244c8c0a7d974ec1f7b1af Mon Sep 17 00:00:00 2001 From: tsusdere Date: Fri, 12 Apr 2024 13:51:34 -0500 Subject: [PATCH 21/21] rubocop fix --- lib/github-pages-health-check/domain.rb | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/lib/github-pages-health-check/domain.rb b/lib/github-pages-health-check/domain.rb index f2b7363..f36bf7d 100644 --- a/lib/github-pages-health-check/domain.rb +++ b/lib/github-pages-health-check/domain.rb @@ -248,7 +248,7 @@ def cname_to_github_user_domain? def cname_to_domain_to_pages? a_record_to_pages = dns.select { |d| d.type == Dnsruby::Types::A && d.name.to_s == host }.first - return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? && @wwwcname + return false unless a_record_to_pages && cname? && !cname_to_pages_dot_github_dot_com? && @www_cname CURRENT_IP_ADDRESSES.include?(a_record_to_pages.address.to_s.downcase) end @@ -416,7 +416,7 @@ def cname # Check if we have a 'www.' CNAME that matches the domain def www_cname(cname) - @wwwcname ||= cname.name.to_s.start_with?("www.") && + @www_cname ||= cname.name.to_s.start_with?("www.") && cname.name.to_s.end_with?(cname.domainname.to_s) end