gitlab-org--gitlab-foss/app/finders
Yorick Peterse 6f3c490107
Refactor AutocompleteController
This refactors the AutocompleteController according to the guidelines
and boundaries discussed in
https://gitlab.com/gitlab-org/gitlab-ce/issues/49653. Specifically,
ActiveRecord logic is moved to different finders, which are then used in
the controller. View logic in turn is moved to presenters, instead of
directly using ActiveRecord's "to_json" method.

The finder MoveToProjectFinder is also adjusted according to the
abstraction guidelines and boundaries, resulting in a much more simple
finder.

By using finders (and other abstractions) more actively, we can push a
lot of logic out of the controller. We also remove the need for various
"before_action" hooks, though this could be achieved without using
finders as well.

The various finders related to AutcompleteController have also been
moved into a namespace. This removes the need for calling everything
"AutocompleteSmurfFinder", instead you can use
"Autocomplete::SmurfFinder".
2018-08-20 13:53:00 +02:00
..
admin Remove code for dynamically generating routes 2018-07-25 16:41:29 +02:00
autocomplete Refactor AutocompleteController 2018-08-20 13:53:00 +02:00
concerns Port read_cross_project ability from EE 2018-02-22 17:11:36 +01:00
access_requests_finder.rb Use Ability.allowed? instead of current_user.can? in AccessRequestsFinder 2016-09-28 08:46:59 +02:00
awarded_emoji_finder.rb Refactor AutocompleteController 2018-08-20 13:53:00 +02:00
branches_finder.rb Add overview of branches and a filter for active/stale branches 2018-03-06 21:28:14 +09:00
clusters_finder.rb Use attr_reader instead of instance variables 2017-11-28 14:39:18 +01:00
contributed_projects_finder.rb Tweaks, refactoring, and specs 2016-03-20 21:04:07 +01:00
environments_finder.rb Revert "Enable Style/DotPosition" 2017-02-23 09:33:19 -06:00
events_finder.rb Port read_cross_project ability from EE 2018-02-22 17:11:36 +01:00
fork_projects_finder.rb Introduce ForkProjectsFinder class 2017-09-20 08:27:16 +10:00
group_descendants_finder.rb Revert "Don't include projects shared as group-descendants" 2018-04-18 17:15:52 +02:00
group_finder.rb Merge branch 'jej-group-name-disclosure' into 'security' 2017-03-29 19:18:38 -07:00
group_members_finder.rb Backport of "Add assignee lists to boards" 2018-06-07 20:54:24 +00:00
group_projects_finder.rb Reduce queries in GroupProjectsFinder 2018-05-28 13:52:37 +02:00
groups_finder.rb Add min_access_level filter to groups API 2018-07-23 20:57:50 +02:00
issuable_finder.rb Extract EE-specific lines from issuable finders 2018-07-30 10:12:04 +01:00
issues_finder.rb Simplify issuable finder queries 2018-06-06 12:29:45 +01:00
joined_groups_finder.rb Address feedback 2016-03-22 00:09:20 +01:00
labels_finder.rb Move search param check into own method in app/finders/labels_finder.rb 2018-07-31 12:46:37 +03:00
license_template_finder.rb Introduce a LicenseTemplate model and LicenseTemplateFinder helper 2018-08-15 07:38:18 +01:00
members_finder.rb Backport of "Add assignee lists to boards" 2018-06-07 20:54:24 +00:00
merge_request_target_project_finder.rb Prevent new merge requests for archived projects 2018-04-11 10:51:14 +02:00
merge_requests_finder.rb Add locked state to merge request API 2018-06-28 07:12:00 -07:00
milestones_finder.rb Port read_cross_project ability from EE 2018-02-22 17:11:36 +01:00
notes_finder.rb Changes tab VUE refactoring 2018-06-21 12:22:40 +00:00
personal_access_tokens_finder.rb Adds Rubocop rule for line break after guard clause 2017-11-16 17:58:29 +01:00
personal_projects_finder.rb Add an option to have a private profile on GitLab 2018-07-24 12:46:19 +00:00
pipeline_schedules_finder.rb Add Pipeline Schedules that supersedes experimental Trigger Schedule 2017-05-07 22:35:56 +00:00
pipelines_finder.rb Add pipeline lists to GraphQL 2018-07-04 10:53:39 +02:00
projects_finder.rb Add min_access_level filter to projects API 2018-07-23 20:57:50 +02:00
README.md
runner_jobs_finder.rb Refactorize jobs finding logic 2017-11-28 00:36:50 +01:00
snippets_finder.rb [Rails5] Fix snippets_finder arel queries 2018-06-14 11:20:11 +11:00
tags_finder.rb add specs for tags finder 2016-08-31 19:16:47 +01:00
todos_finder.rb Add changes from the EE 2018-08-06 14:18:21 +02:00
union_finder.rb Tweaks, refactoring, and specs 2016-03-20 21:04:07 +01:00
user_finder.rb Refactor AutocompleteController 2018-08-20 13:53:00 +02:00
user_recent_events_finder.rb Add an option to have a private profile on GitLab 2018-07-24 12:46:19 +00:00
users_finder.rb Add 2FA filter to users API for admins only 2018-04-23 11:54:45 +03:00

Finders

This type of classes responsible for collection items based on different conditions. To prevent lookup methods in models like this:

class Project
  def issues_for_user_filtered_by(user, filter)
    # A lot of logic not related to project model itself
  end
end

issues = project.issues_for_user_filtered_by(user, params)

Better use this:

issues = IssuesFinder.new(project, user, filter).execute

It will help keep models thiner.