diff --git a/Library/Homebrew/rubocops/urls.rb b/Library/Homebrew/rubocops/urls.rb
index 5dbceeb83da1953dd0d252435bda3a1d0c88bf6e..b23883d0cda4cee9e2675e948d4b6261546c3ea3 100644
--- a/Library/Homebrew/rubocops/urls.rb
+++ b/Library/Homebrew/rubocops/urls.rb
@@ -316,23 +316,47 @@ module RuboCop
         end
       end
 
-      # This cop makes sure that git urls have both a `tag` and `revision`.
+      # This cop makes sure that git urls have both a `revision`.
       #
       # @api private
       class GitUrls < FormulaCop
         def audit_formula(_node, _class_node, _parent_class_node, body_node)
+          return unless formula_tap == "homebrew-core"
+
           find_method_calls_by_name(body_node, :url).each do |url|
             next unless string_content(parameters(url).first).match?(/\.git$/)
+            next if url_has_revision?(parameters(url).last)
+
+            offending_node(url)
+            problem "Formulae in homebrew/core should specify a revision for git urls"
+          end
+        end
+
+        def_node_matcher :url_has_revision?, <<~EOS
+          (hash <(pair (sym :revision) str) ...>)
+        EOS
+      end
+    end
+
+    module FormulaAuditStrict
+      # This cop makes sure that git urls have both a `tag`.
+      #
+      # @api private
+      class GitUrls < FormulaCop
+        def audit_formula(_node, _class_node, _parent_class_node, body_node)
+          return unless formula_tap == "homebrew-core"
 
-            next if url_has_tag_and_revision?(parameters(url).last)
+          find_method_calls_by_name(body_node, :url).each do |url|
+            next unless string_content(parameters(url).first).match?(/\.git$/)
+            next if url_has_tag?(parameters(url).last)
 
             offending_node(url)
-            problem "Specify a `tag` and `revision` for git urls"
+            problem "Formulae in homebrew/core should specify a tag for git urls"
           end
         end
 
-        def_node_matcher :url_has_tag_and_revision?, <<~EOS
-          (hash <(pair (sym :tag) str) (pair (sym :revision) str) ...>)
+        def_node_matcher :url_has_tag?, <<~EOS
+          (hash <(pair (sym :tag) str) ...>)
         EOS
       end
     end
diff --git a/Library/Homebrew/test/rubocops/urls_spec.rb b/Library/Homebrew/test/rubocops/urls_spec.rb
index 1d6e7e88e5bccb5fd6584c56a793515c638ebbb0..e36f40493a7240c82015dd723c9c0eadc756e35e 100644
--- a/Library/Homebrew/test/rubocops/urls_spec.rb
+++ b/Library/Homebrew/test/rubocops/urls_spec.rb
@@ -282,7 +282,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
 
   context "when a git URL is used" do
     it "reports no offenses with a non-git url" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://foo.com"
@@ -291,7 +291,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports no offenses with both a tag and a revision" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
@@ -302,7 +302,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports no offenses with both a tag, revision and `shallow` before" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
@@ -314,7 +314,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports no offenses with both a tag, revision and `shallow` after" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
@@ -326,45 +326,140 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports an offense with no `revision`" do
-      expect_offense(<<~RUBY)
+      expect_offense(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
-          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls
+          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a revision for git urls
               tag: "v1.0.0"
         end
       RUBY
     end
 
     it "reports an offense with no `revision` and `shallow`" do
-      expect_offense(<<~RUBY)
+      expect_offense(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
-          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls
+          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a revision for git urls
               shallow: false,
               tag:     "v1.0.0"
         end
       RUBY
     end
 
+    it "reports no offenses with no `tag`" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git",
+              revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
+        end
+      RUBY
+    end
+
+    it "reports no offenses with no `tag` and `shallow`" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git",
+              revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
+              shallow:  false
+        end
+      RUBY
+    end
+
+    it "reports no offenses with missing arguments in `head`" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://foo.com"
+          head do
+            url "https://github.com/foo/bar.git"
+          end
+        end
+      RUBY
+    end
+
+    it "reports no offenses with missing arguments in `devel`" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://foo.com"
+          devel do
+            url "https://github.com/foo/bar.git"
+          end
+        end
+      RUBY
+    end
+
+    it "reports no offenses for non-core taps" do
+      expect_no_offenses(<<~RUBY)
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git"
+        end
+      RUBY
+    end
+  end
+end
+
+describe RuboCop::Cop::FormulaAuditStrict::GitUrls do
+  subject(:cop) { described_class.new }
+
+  context "when a git URL is used" do
+    it "reports no offenses with both a tag and a revision" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git",
+              tag:      "v1.0.0",
+              revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
+        end
+      RUBY
+    end
+
+    it "reports no offenses with both a tag, revision and `shallow` before" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git",
+              shallow:  false,
+              tag:      "v1.0.0",
+              revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
+        end
+      RUBY
+    end
+
+    it "reports no offenses with both a tag, revision and `shallow` after" do
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git",
+              tag:      "v1.0.0",
+              revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
+              shallow:  false
+        end
+      RUBY
+    end
+
     it "reports an offense with no `tag`" do
-      expect_offense(<<~RUBY)
+      expect_offense(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
-          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls
+          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a tag for git urls
               revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
         end
       RUBY
     end
 
     it "reports an offense with no `tag` and `shallow`" do
-      expect_offense(<<~RUBY)
+      expect_offense(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://github.com/foo/bar.git",
-          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Specify a `tag` and `revision` for git urls
+          ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ Formulae in homebrew/core should specify a tag for git urls
               revision: "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa",
               shallow:  false
         end
@@ -372,7 +467,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports no offenses with missing arguments in `head`" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://foo.com"
@@ -384,7 +479,7 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
     end
 
     it "reports no offenses with missing arguments in `devel`" do
-      expect_no_offenses(<<~RUBY)
+      expect_no_offenses(<<~RUBY, "/homebrew-core/")
         class Foo < Formula
           desc "foo"
           url "https://foo.com"
@@ -394,5 +489,14 @@ describe RuboCop::Cop::FormulaAudit::GitUrls do
         end
       RUBY
     end
+
+    it "reports no offenses for non-core taps" do
+      expect_no_offenses(<<~RUBY)
+        class Foo < Formula
+          desc "foo"
+          url "https://github.com/foo/bar.git"
+        end
+      RUBY
+    end
   end
 end