Class: Brakeman::AppTree

Inherits:
Object
  • Object
show all
Defined in:
lib/brakeman/app_tree.rb

Constant Summary collapse

VIEW_EXTENSIONS =
%w[html.erb html.haml rhtml js.erb html.slim].join(",")

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(root, init_options = {}) ⇒ AppTree

Returns a new instance of AppTree.



59
60
61
62
63
64
65
66
67
68
69
70
71
72
# File 'lib/brakeman/app_tree.rb', line 59

def initialize(root, init_options = {})
  @root = root
  @project_root_path = Pathname.new(@root)
  @skip_files = init_options[:skip_files]
  @only_files = init_options[:only_files]
  @additional_libs_path = init_options[:additional_libs_path] || []
  @engine_paths = init_options[:engine_paths] || []
  @absolute_engine_paths = @engine_paths.select { |path| path.start_with?(File::SEPARATOR) }
  @relative_engine_paths = @engine_paths - @absolute_engine_paths
  @skip_vendor = init_options[:skip_vendor]
  @follow_symlinks = init_options[:follow_symlinks]
  @gemspec = nil
  @root_search_pattern = nil
end

Instance Attribute Details

#rootObject (readonly)

Returns the value of attribute root.



8
9
10
# File 'lib/brakeman/app_tree.rb', line 8

def root
  @root
end

Class Method Details

.from_options(options) ⇒ Object



10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/brakeman/app_tree.rb', line 10

def self.from_options(options)
  root = File.expand_path options[:app_path]

  # Convert files into Regexp for matching
  init_options = {}
  if options[:skip_files]
    init_options[:skip_files] = regex_for_paths(options[:skip_files])
  end

  if options[:only_files]
    init_options[:only_files] = regex_for_paths(options[:only_files])
  end
  init_options[:additional_libs_path] = options[:additional_libs_path]
  init_options[:engine_paths] = options[:engine_paths]
  init_options[:skip_vendor] = options[:skip_vendor]
  init_options[:follow_symlinks] = options[:follow_symlinks]

  new(root, init_options)
end

Instance Method Details

#controller_pathsObject



112
113
114
# File 'lib/brakeman/app_tree.rb', line 112

def controller_paths
  @controller_paths ||= prioritize_concerns(find_paths("app/**/controllers"))
end

#exists?(path) ⇒ Boolean

Returns:

  • (Boolean)


96
97
98
99
100
101
102
# File 'lib/brakeman/app_tree.rb', line 96

def exists?(path)
  if path.is_a? Brakeman::FilePath
    path.exists?
  else
    File.exist?(File.join(@root, path))
  end
end

#expand_path(path) ⇒ Object

Should only be used by Brakeman::FilePath. Use AppTree#file_path(path).absolute instead.



81
82
83
# File 'lib/brakeman/app_tree.rb', line 81

def expand_path(path)
  File.expand_path(path, @root)
end

#file_path(path) ⇒ Object

Create a new Brakeman::FilePath



75
76
77
# File 'lib/brakeman/app_tree.rb', line 75

def file_path(path)
  Brakeman::FilePath.from_app_tree(self, path)
end

#gemspecObject



136
137
138
139
140
141
142
143
144
145
146
# File 'lib/brakeman/app_tree.rb', line 136

def gemspec
  return @gemspec unless @gemspec.nil?

  gemspecs =  Dir.glob(File.join(@root, "*.gemspec"))

  if gemspecs.length > 1 or gemspecs.empty?
    @gemspec = false
  else
    @gemspec = file_path(File.basename(gemspecs.first))
  end
end

#initializer_pathsObject



108
109
110
# File 'lib/brakeman/app_tree.rb', line 108

def initializer_paths
  @initializer_paths ||= prioritize_concerns(find_paths("config/initializers"))
end

#layout_exists?(name) ⇒ Boolean

Returns:

  • (Boolean)


125
126
127
# File 'lib/brakeman/app_tree.rb', line 125

def layout_exists?(name)
  !Dir.glob("#{root_search_pattern}app/views/layouts/#{name}.html.{erb,haml,slim}").empty?
end

#lib_pathsObject



129
130
131
132
133
134
# File 'lib/brakeman/app_tree.rb', line 129

def lib_paths
  @lib_files ||= find_paths("lib").reject { |path| path.relative.include? "/generators/" or path.relative.include? "lib/tasks/" or path.relative.include? "lib/templates/" } +
                 find_additional_lib_paths +
                 find_helper_paths +
                 find_job_paths
end

#model_pathsObject



116
117
118
# File 'lib/brakeman/app_tree.rb', line 116

def model_paths
  @model_paths ||= prioritize_concerns(find_paths("app/**/models"))
end

#relative_path(path) ⇒ Object

Should only be used by Brakeman::FilePath Use AppTree#file_path(path).relative instead.



87
88
89
90
91
92
93
94
# File 'lib/brakeman/app_tree.rb', line 87

def relative_path(path)
  pname = Pathname.new path
  if path and not path.empty? and pname.absolute?
    pname.relative_path_from(Pathname.new(self.root)).to_s
  else
    path
  end
end

#ruby_file_pathsObject



104
105
106
# File 'lib/brakeman/app_tree.rb', line 104

def ruby_file_paths
  find_paths(".").uniq
end

#template_pathsObject



120
121
122
123
# File 'lib/brakeman/app_tree.rb', line 120

def template_paths
  @template_paths ||= find_paths(".", "*.{#{VIEW_EXTENSIONS}}") +
    find_paths("**", "*.{erb,haml,slim}").reject { |path| File.basename(path).count(".") > 1 }
end