diff options
author | Sanad Liaquat <sliaquat@gitlab.com> | 2018-09-21 14:10:20 +0000 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2018-09-21 14:10:20 +0000 |
commit | 0896d6942d30e3cc743c85dcc8fe9699a2a02289 (patch) | |
tree | 05d2e8d6808de79160e4b2a7aefa64bea2c3d001 /rubocop/cop | |
parent | f93200897703a7610ee054d050ef92acdc7eeb1f (diff) | |
download | gitlab-ce-0896d6942d30e3cc743c85dcc8fe9699a2a02289.tar.gz |
Fix leading slash in redirects and add cop
Diffstat (limited to 'rubocop/cop')
-rw-r--r-- | rubocop/cop/avoid_route_redirect_leading_slash.rb | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/rubocop/cop/avoid_route_redirect_leading_slash.rb b/rubocop/cop/avoid_route_redirect_leading_slash.rb new file mode 100644 index 00000000000..7ac1c881269 --- /dev/null +++ b/rubocop/cop/avoid_route_redirect_leading_slash.rb @@ -0,0 +1,52 @@ +# frozen_string_literal: true + +module RuboCop + module Cop + # Checks for a leading '/' in route redirects + # For more information see: https://gitlab.com/gitlab-org/gitlab-ce/issues/50645 + # + # @example + # # bad + # root to: redirect('/-/instance/statistics/conversational_development_index') + # + # # good + # root to: redirect('-/instance/statistics/conversational_development_index') + # + + class AvoidRouteRedirectLeadingSlash < RuboCop::Cop::Cop + MSG = 'Do not use a leading "/" in route redirects' + + def_node_matcher :leading_slash_in_redirect?, <<~PATTERN + (send nil? :redirect (str #has_leading_slash?)) + PATTERN + + def on_send(node) + return unless in_routes?(node) + return unless leading_slash_in_redirect?(node) + + add_offense(node) + end + + def has_leading_slash?(str) + str.start_with?("/") + end + + def in_routes?(node) + path = node.location.expression.source_buffer.name + dirname = File.dirname(path) + filename = File.basename(path) + dirname.end_with?('config/routes') || filename.end_with?('routes.rb') + end + + def autocorrect(node) + lambda do |corrector| + corrector.replace(node.loc.expression, remove_leading_slash(node)) + end + end + + def remove_leading_slash(node) + node.source.sub('/', '') + end + end + end +end |